NCBI C++ ToolKit
Entrez2_id_.hpp
Go to the documentation of this file.

Go to the SVN repository for this file.

1 /* $Id$
2  * ===========================================================================
3  *
4  * PUBLIC DOMAIN NOTICE
5  * National Center for Biotechnology Information
6  *
7  * This software/database is a "United States Government Work" under the
8  * terms of the United States Copyright Act. It was written as part of
9  * the author's official duties as a United States Government employee and
10  * thus cannot be copyrighted. This software/database is freely available
11  * to the public for use. The National Library of Medicine and the U.S.
12  * Government have not placed any restriction on its use or reproduction.
13  *
14  * Although all reasonable efforts have been taken to ensure the accuracy
15  * and reliability of the software and data, the NLM and the U.S.
16  * Government do not and cannot warrant the performance or results that
17  * may be obtained by using this software or data. The NLM and the U.S.
18  * Government disclaim all warranties, express or implied, including
19  * warranties of performance, merchantability or fitness for any particular
20  * purpose.
21  *
22  * Please cite the author in any work or product based on this material.
23  *
24  * ===========================================================================
25  *
26  */
27 
28 /// @file Entrez2_id_.hpp
29 /// Data storage class.
30 ///
31 /// This file was generated by application DATATOOL
32 /// using the following specifications:
33 /// <a href="/IEB/ToolBox/CPP_DOC/lxr/source/src/objects/entrez2/entrez2.asn">entrez2.asn</a>
34 /// and additional tune-up parameters:
35 /// <a href="/IEB/ToolBox/CPP_DOC/lxr/source/src/objects/entrez2/entrez2.def">entrez2.def</a>
36 ///
37 /// ATTENTION:
38 /// Don't edit or commit this file into CVS as this file will
39 /// be overridden (by DATATOOL) without warning!
40 
41 #ifndef OBJECTS_ENTREZ2_ENTREZ2_ID_BASE_HPP
42 #define OBJECTS_ENTREZ2_ENTREZ2_ID_BASE_HPP
43 
44 // standard includes
45 #include <serial/serialbase.hpp>
46 
47 // generated includes
49 
51 
52 #ifndef BEGIN_objects_SCOPE
53 # define BEGIN_objects_SCOPE BEGIN_SCOPE(objects)
54 # define END_objects_SCOPE END_SCOPE(objects)
55 #endif
56 BEGIN_objects_SCOPE // namespace ncbi::objects::
57 
58 
59 // generated classes
60 
61 
62 /** @addtogroup dataspec_NCBI_Entrez2
63  *
64  * @{
65  */
66 
67 /////////////////////////////////////////////////////////////////////////////
68 /// a single UID
69 ///
70 /// CEntrez2_id_Base --
71 ///
72 
74 {
76 public:
77  // constructor
78  CEntrez2_id_Base(void);
79  // destructor
80  virtual ~CEntrez2_id_Base(void);
81 
82  // type info
84 
85  // types
88 
89  // member index
90  enum class E_memberIndex {
91  e__allMandatory = 0,
92  e_db,
93  e_uid
94  };
96 
97  // getters
98  // setters
99 
100  /// Check if a value has been assigned to Db data member.
101  ///
102  /// Data member Db is mandatory;
103  /// its type is defined as 'typedef CEntrez2_db_id TDb'
104  /// @return
105  /// - true, if a value has been assigned.
106  /// - false, otherwise.
107  bool IsSetDb(void) const;
108 
109  /// Check if it is safe to call GetDb method.
110  ///
111  /// @return
112  /// - true, if the data member is getatable.
113  /// - false, otherwise.
114  bool CanGetDb(void) const;
115 
116  /// Reset Db data member.
117  void ResetDb(void);
118 
119  /// Get the Db member data.
120  ///
121  /// @return
122  /// Reference to the member data.
123  const TDb& GetDb(void) const;
124 
125  /// Assign a value to Db data member.
126  ///
127  /// @param value
128  /// Value to assign
129  void SetDb(const TDb& value);
130 
131  /// Assign a value to Db data member.
132  ///
133  /// @return
134  /// Reference to the data value.
135  TDb& SetDb(void);
136 
137  /// Check if a value has been assigned to Uid data member.
138  ///
139  /// Data member Uid is mandatory;
140  /// its type is defined as 'typedef NCBI_NS_NCBI::TEntrezId TUid'
141  /// @return
142  /// - true, if a value has been assigned.
143  /// - false, otherwise.
144  bool IsSetUid(void) const;
145 
146  /// Check if it is safe to call GetUid method.
147  ///
148  /// @return
149  /// - true, if the data member is getatable.
150  /// - false, otherwise.
151  bool CanGetUid(void) const;
152 
153  /// Reset Uid data member.
154  void ResetUid(void);
155 
156  /// Get the Uid member data.
157  ///
158  /// @return
159  /// Copy of the member data.
160  TUid GetUid(void) const;
161 
162  /// Assign a value to Uid data member.
163  ///
164  /// @param value
165  /// Value to assign
166  void SetUid(TUid value);
167 
168  /// Assign a value to Uid data member.
169  ///
170  /// @return
171  /// Reference to the data value.
172  TUid& SetUid(void);
173 
174  /// Reset the whole object
175  virtual void Reset(void);
176 
177 
178 private:
179  // Prohibit copy constructor and assignment operator
182 
183  // data
184  Uint4 m_set_State[1];
187 };
188 
189 /* @} */
190 
191 
192 
193 
194 
195 ///////////////////////////////////////////////////////////
196 ///////////////////// inline methods //////////////////////
197 ///////////////////////////////////////////////////////////
198 inline
200 {
201  return ((m_set_State[0] & 0x3) != 0);
202 }
203 
204 inline
206 {
207  return IsSetDb();
208 }
209 
210 inline
212 {
213  if (!CanGetDb()) {
214  ThrowUnassigned(0);
215  }
216  return m_Db;
217 }
218 
219 inline
221 {
222  m_Db = value;
223  m_set_State[0] |= 0x3;
224 }
225 
226 inline
228 {
229  m_set_State[0] |= 0x1;
230  return m_Db;
231 }
232 
233 inline
235 {
236  return ((m_set_State[0] & 0xc) != 0);
237 }
238 
239 inline
241 {
242  return IsSetUid();
243 }
244 
245 inline
247 {
248  m_Uid = 0;
249  m_set_State[0] &= ~0xc;
250 }
251 
252 inline
254 {
255  if (!CanGetUid()) {
256  ThrowUnassigned(1);
257  }
258  return reinterpret_cast<const TUid&>(m_Uid);
259 }
260 
261 inline
263 {
264  reinterpret_cast<TUid&>(m_Uid) = value;
265  m_set_State[0] |= 0xc;
266 }
267 
268 inline
270 {
271 #ifdef _DEBUG
272  if (!IsSetUid()) {
273  memset(&m_Uid,UnassignedByte(),sizeof(m_Uid));
274  }
275 #endif
276  m_set_State[0] |= 0x4;
277  return reinterpret_cast<TUid&>(m_Uid);
278 }
279 
280 ///////////////////////////////////////////////////////////
281 ////////////////// end of inline methods //////////////////
282 ///////////////////////////////////////////////////////////
283 
284 
285 
286 
287 
288 END_objects_SCOPE // namespace ncbi::objects::
289 
291 
292 
293 #endif // OBJECTS_ENTREZ2_ENTREZ2_ID_BASE_HPP
User-defined methods of the data storage class.
CEntrez2_db_id –.
a single UID
Definition: Entrez2_id_.hpp:74
Base class for all serializable objects.
Definition: serialbase.hpp:150
char value[7]
Definition: config.c:431
SStrictId_Entrez::TId TEntrezId
TEntrezId type for entrez ids which require the same strictness as TGi.
Definition: ncbimisc.hpp:1041
Int8 TIntId
Definition: ncbimisc.hpp:999
static char UnassignedByte(void)
Definition: serialbase.hpp:181
void ThrowUnassigned(TMemberIndex index) const
uint32_t Uint4
4-byte (32-bit) unsigned integer
Definition: ncbitype.h:103
#define END_NCBI_SCOPE
End previously defined NCBI scope.
Definition: ncbistl.hpp:103
#define BEGIN_NCBI_SCOPE
Define ncbi namespace.
Definition: ncbistl.hpp:100
#define NCBI_ENTREZ2_EXPORT
Definition: ncbi_export.h:464
Tparent::CMemberIndex< E_memberIndex, 3 > TmemberIndex
Definition: Entrez2_id_.hpp:95
TDb & SetDb(void)
Assign a value to Db data member.
CSerialObject Tparent
Definition: Entrez2_id_.hpp:75
void ResetUid(void)
Reset Uid data member.
bool CanGetUid(void) const
Check if it is safe to call GetUid method.
CEntrez2_db_id m_Db
Uint4 m_set_State[1]
TUid & SetUid(void)
Assign a value to Uid data member.
TUid GetUid(void) const
Get the Uid member data.
ncbi::TIntId m_Uid
bool IsSetUid(void) const
Check if a value has been assigned to Uid data member.
CEntrez2_id_Base & operator=(const CEntrez2_id_Base &)
NCBI_NS_NCBI::TEntrezId TUid
Definition: Entrez2_id_.hpp:87
CEntrez2_id_Base(const CEntrez2_id_Base &)
CEntrez2_db_id TDb
Definition: Entrez2_id_.hpp:86
bool CanGetDb(void) const
Check if it is safe to call GetDb method.
bool IsSetDb(void) const
Check if a value has been assigned to Db data member.
const TDb & GetDb(void) const
Get the Db member data.
Modified on Tue Nov 28 02:25:25 2023 by modify_doxy.py rev. 669887