NCBI C++ ToolKit
GC_Replicon_.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  * 'genome_collection.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
45 
46 BEGIN_objects_SCOPE // namespace ncbi::objects::
47 
48 
49 // generated classes
50 
52 {
53  if ( m_choice != e_not_set )
55 }
56 
58 {
59  switch ( m_choice ) {
60  case e_Set:
61  m_Set.Destruct();
62  break;
63  case e_Single:
64  m_object->RemoveReference();
65  break;
66  default:
67  break;
68  }
69  m_choice = e_not_set;
70 }
71 
72 void CGC_Replicon_Base::C_Sequence::DoSelect(E_Choice index, NCBI_NS_NCBI::CObjectMemoryPool* pool)
73 {
74  switch ( index ) {
75  case e_Single:
76  (m_object = new(pool) ncbi::objects::CGC_Sequence())->AddReference();
77  break;
78  case e_Set:
79  m_Set.Construct();
80  break;
81  default:
82  break;
83  }
84  m_choice = index;
85 }
86 
88  "not set",
89  "single",
90  "set"
91 };
92 
94 {
95  return NCBI_NS_NCBI::CInvalidChoiceSelection::GetName(index, sm_SelectionNames, sizeof(sm_SelectionNames)/sizeof(sm_SelectionNames[0]));
96 }
97 
99 {
100  throw NCBI_NS_NCBI::CInvalidChoiceSelection(DIAG_COMPILE_INFO, this, m_choice, index, sm_SelectionNames, sizeof(sm_SelectionNames)/sizeof(sm_SelectionNames[0]));
101 }
102 
104 {
105  CheckSelected(e_Single);
106  return *static_cast<const TSingle*>(m_object);
107 }
108 
110 {
111  Select(e_Single, NCBI_NS_NCBI::eDoNotResetVariant);
112  return *static_cast<TSingle*>(m_object);
113 }
114 
116 {
117  TSingle* ptr = &value;
118  if ( m_choice != e_Single || m_object != ptr ) {
119  ResetSelection();
120  (m_object = ptr)->AddReference();
121  m_choice = e_Single;
122  }
123 }
124 
125 // helper methods
126 
127 // type info
129 {
130  SET_INTERNAL_NAME("GC-Replicon", "sequence");
131  SET_CHOICE_MODULE("NCBI-GenomeCollection");
132  ADD_NAMED_REF_CHOICE_VARIANT("single", m_object, CGC_Sequence);
133  ADD_NAMED_BUF_CHOICE_VARIANT("set", m_Set, STL_list_set, (STL_CRef, (CLASS, (CGC_Sequence))));
134  info->CodeVersion(22301);
135  info->DataSpec(ncbi::EDataSpec::eASN);
136 }
138 
139 // constructor
141  : m_choice(e_not_set)
142 {
143 }
144 
145 // destructor
147 {
148  Reset();
149 }
150 
151 
153 {
154  m_Name.erase();
155  m_set_State[0] &= ~0x3;
156 }
157 
159 {
160  m_Local_name.erase();
161  m_set_State[0] &= ~0xc;
162 }
163 
165 {
166  if ( !m_Sequence ) {
167  m_Sequence.Reset(new TSequence());
168  return;
169  }
170  (*m_Sequence).Reset();
171 }
172 
174 {
175  m_Sequence.Reset(&value);
176 }
177 
179 {
180  ResetName();
181  ResetLocal_name();
182  ResetSequence();
183 }
184 
186 {
187  SET_CLASS_MODULE("NCBI-GenomeCollection");
188  ADD_NAMED_STD_MEMBER("name", m_Name)->SetSetFlag(MEMBER_PTR(m_set_State[0]))->SetOptional();
189  ADD_NAMED_STD_MEMBER("local-name", m_Local_name)->SetSetFlag(MEMBER_PTR(m_set_State[0]))->SetOptional();
190  ADD_NAMED_REF_MEMBER("sequence", m_Sequence, C_Sequence);
191  info->RandomOrder();
192  info->CodeVersion(22301);
193  info->DataSpec(ncbi::EDataSpec::eASN);
194 }
196 
197 // constructor
199 {
200  memset(m_set_State,0,sizeof(m_set_State));
201  if ( !IsAllocatedInPool() ) {
202  ResetSequence();
203  }
204 }
205 
206 // destructor
208 {
209 }
210 
211 
212 
213 END_objects_SCOPE // namespace ncbi::objects::
214 
216 
User-defined methods of the data storage class.
BEGIN_NAMED_CHOICE_INFO("", CGC_Replicon_Base::C_Sequence)
BEGIN_NAMED_BASE_CLASS_INFO("GC-Replicon", CGC_Replicon)
User-defined methods of the data storage class.
the sequence(s) representing this molecule in the case of 2L and 2R - the molecule is represented by ...
char value[7]
Definition: config.c:431
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 MEMBER_PTR(MemberName)
Definition: serialimpl.hpp:284
#define ADD_NAMED_REF_MEMBER(MemberAlias, MemberName, ClassName)
Definition: serialimpl.hpp:357
#define END_CLASS_INFO
Definition: serialimpl.hpp:456
#define ADD_NAMED_REF_CHOICE_VARIANT(MemberAlias, MemberName, ClassName)
Definition: serialimpl.hpp:400
#define ADD_NAMED_STD_MEMBER(MemberAlias, MemberName)
Definition: serialimpl.hpp:345
#define SET_CLASS_MODULE(ModuleName)
Definition: serialimpl.hpp:444
#define END_CHOICE_INFO
Definition: serialimpl.hpp:506
#define SET_INTERNAL_NAME(OwnerName, MemberName)
Definition: serialimpl.hpp:447
#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
bool IsAllocatedInPool(void) const THROWS_NONE
Check if object is allocated in memory pool (not system heap)
Definition: ncbiobj.hpp:461
#define END_NCBI_SCOPE
End previously defined NCBI scope.
Definition: ncbistl.hpp:103
#define BEGIN_NCBI_SCOPE
Define ncbi namespace.
Definition: ncbistl.hpp:100
static string SelectionName(E_Choice index)
Retrieve selection name (for diagnostic purposes).
static const char *const sm_SelectionNames[]
void DoSelect(E_Choice index, CObjectMemoryPool *pool=0)
CRef< TSequence > m_Sequence
void ResetName(void)
Reset Name data member.
C_Sequence TSequence
void ThrowInvalidSelection(E_Choice index) const
Throw 'InvalidSelection' exception.
void ResetLocal_name(void)
Reset Local_name data member.
void ResetSequence(void)
Reset Sequence data member.
virtual ~CGC_Replicon_Base(void)
TSingle & SetSingle(void)
Select the variant.
const TSingle & GetSingle(void) const
Get the variant data.
void Reset(void)
Reset the whole object.
TSequence & SetSequence(void)
Assign a value to Sequence data member.
void ResetSelection(void)
Reset the selection (set it to e_not_set).
virtual void Reset(void)
Reset the whole object.
@ e_not_set
No variant selected.
@ e_not_set
static MDB_envinfo info
Definition: mdb_load.c:37
Modified on Sat Dec 09 04:46:10 2023 by modify_doxy.py rev. 669887