NCBI C++ ToolKit
Biostruc_descr_.cpp
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  * File Description:
27  * This code was generated by application DATATOOL
28  * using the following specifications:
29  * 'mmdb1.asn'.
30  *
31  * ATTENTION:
32  * Don't edit or commit this file into CVS as this file will
33  * be overridden (by DATATOOL) without warning!
34  * ===========================================================================
35  */
36 
37 // standard includes
38 #include <ncbi_pch.hpp>
39 #include <serial/serialimpl.hpp>
40 
41 // generated includes
44 #include <objects/pub/Pub.hpp>
46 
47 BEGIN_objects_SCOPE // namespace ncbi::objects::
48 
49 
50 // generated classes
51 
53 {
54  if ( m_choice != e_not_set )
56 }
57 
59 {
60  switch ( m_choice ) {
61  case e_Name:
62  case e_Pdb_comment:
63  case e_Other_comment:
64  m_string.Destruct();
65  break;
66  case e_History:
67  case e_Attribution:
68  m_object->RemoveReference();
69  break;
70  default:
71  break;
72  }
74 }
75 
76 void CBiostruc_descr_Base::DoSelect(E_Choice index, NCBI_NS_NCBI::CObjectMemoryPool* pool)
77 {
78  switch ( index ) {
79  case e_History:
80  (m_object = new(pool) ncbi::objects::CBiostruc_history())->AddReference();
81  break;
82  case e_Attribution:
83  (m_object = new(pool) ncbi::objects::CPub())->AddReference();
84  break;
85  case e_Name:
86  case e_Pdb_comment:
87  case e_Other_comment:
88  m_string.Construct();
89  break;
90  default:
91  break;
92  }
93  m_choice = index;
94 }
95 
96 const char* const CBiostruc_descr_Base::sm_SelectionNames[] = {
97  "not set",
98  "name",
99  "pdb-comment",
100  "other-comment",
101  "history",
102  "attribution"
103 };
104 
106 {
107  return NCBI_NS_NCBI::CInvalidChoiceSelection::GetName(index, sm_SelectionNames, sizeof(sm_SelectionNames)/sizeof(sm_SelectionNames[0]));
108 }
109 
111 {
112  throw NCBI_NS_NCBI::CInvalidChoiceSelection(DIAG_COMPILE_INFO, this, m_choice, index, sm_SelectionNames, sizeof(sm_SelectionNames)/sizeof(sm_SelectionNames[0]));
113 }
114 
116 {
118  *m_string = value;
119 }
120 
122 {
124  *m_string = value;
125 }
126 
128 {
130  *m_string = value;
131 }
132 
134 {
136  return *static_cast<const THistory*>(m_object);
137 }
138 
140 {
142  return *static_cast<THistory*>(m_object);
143 }
144 
146 {
147  THistory* ptr = &value;
148  if ( m_choice != e_History || m_object != ptr ) {
149  ResetSelection();
150  (m_object = ptr)->AddReference();
152  }
153 }
154 
156 {
158  return *static_cast<const TAttribution*>(m_object);
159 }
160 
162 {
164  return *static_cast<TAttribution*>(m_object);
165 }
166 
168 {
169  TAttribution* ptr = &value;
170  if ( m_choice != e_Attribution || m_object != ptr ) {
171  ResetSelection();
172  (m_object = ptr)->AddReference();
174  }
175 }
176 
177 // helper methods
178 
179 // type info
181 {
182  SET_CHOICE_MODULE("MMDB");
183  ADD_NAMED_BUF_CHOICE_VARIANT("name", m_string, STD, (string));
184  ADD_NAMED_BUF_CHOICE_VARIANT("pdb-comment", m_string, STD, (string));
185  ADD_NAMED_BUF_CHOICE_VARIANT("other-comment", m_string, STD, (string));
186  ADD_NAMED_REF_CHOICE_VARIANT("history", m_object, CBiostruc_history);
187  ADD_NAMED_REF_CHOICE_VARIANT("attribution", m_object, CPub);
188  info->CodeVersion(22400);
189  info->DataSpec(ncbi::EDataSpec::eASN);
190 }
192 
193 // constructor
195  : m_choice(e_not_set)
196 {
197 }
198 
199 // destructor
201 {
202  Reset();
203 }
204 
205 
206 
207 END_objects_SCOPE // namespace ncbi::objects::
208 
210 
User-defined methods of the data storage class.
BEGIN_NAMED_BASE_CHOICE_INFO("Biostruc-descr", CBiostruc_descr)
User-defined methods of the data storage class.
CBiostruc_descr –.
CBiostruc_history –.
Definition: Pub.hpp:56
string
Definition: cgiapp.hpp:687
#define DIAG_COMPILE_INFO
Make compile time diagnostic information object to use in CNcbiDiag and CException.
Definition: ncbidiag.hpp:170
#define ADD_NAMED_REF_CHOICE_VARIANT(MemberAlias, MemberName, ClassName)
Definition: serialimpl.hpp:400
#define END_CHOICE_INFO
Definition: serialimpl.hpp:506
#define SET_CHOICE_MODULE(ModuleName)
Definition: serialimpl.hpp:500
#define ADD_NAMED_BUF_CHOICE_VARIANT(MemberAlias, MemberName, TypeMacro, TypeMacroArgs)
Definition: serialimpl.hpp:385
@ eDoNotResetVariant
Definition: serialbase.hpp:78
void AddReference(void) const
Add reference to object.
Definition: ncbiobj.hpp:489
#define END_NCBI_SCOPE
End previously defined NCBI scope.
Definition: ncbistl.hpp:103
#define BEGIN_NCBI_SCOPE
Define ncbi namespace.
Definition: ncbistl.hpp:100
TAttribution & SetAttribution(void)
Select the variant.
void Select(E_Choice index, EResetVariant reset=eDoResetVariant)
Select the requested variant if needed.
virtual void Reset(void)
Reset the whole object.
NCBI_NS_NCBI::CUnionBuffer< NCBI_NS_STD::string > m_string
THistory & SetHistory(void)
Select the variant.
TName & SetName(void)
Select the variant.
void DoSelect(E_Choice index, CObjectMemoryPool *pool=0)
void ThrowInvalidSelection(E_Choice index) const
Throw 'InvalidSelection' exception.
void CheckSelected(E_Choice index) const
Verify selection, throw exception if it differs from the expected.
static const char *const sm_SelectionNames[]
E_Choice
Choice variants.
static string SelectionName(E_Choice index)
Retrieve selection name (for diagnostic purposes).
const THistory & GetHistory(void) const
Get the variant data.
TPdb_comment & SetPdb_comment(void)
Select the variant.
TOther_comment & SetOther_comment(void)
Select the variant.
NCBI_NS_NCBI::CSerialObject * m_object
virtual void ResetSelection(void)
Reset the selection (set it to e_not_set).
virtual ~CBiostruc_descr_Base(void)
const TAttribution & GetAttribution(void) const
Get the variant data.
@ e_not_set
No variant selected.
@ e_not_set
static MDB_envinfo info
Definition: mdb_load.c:37
const GenericPointer< typename T::ValueType > T2 value
Definition: pointer.h:1227
Modified on Fri May 03 15:53:45 2024 by modify_doxy.py rev. 669887