ATLAS Offline Software
Loading...
Searching...
No Matches
TrackCollectionCnv_tlp2 Class Reference

#include <TrackCollectionCnv_tlp2.h>

Inheritance diagram for TrackCollectionCnv_tlp2:

Public Types

typedef TrackCollectionCnv_p2::Trans_t TRANS
typedef Trk::TrackCollection_tlp2 PERS
typedef Gaudi::PluginService::Factory< ITPCnvBase *()> Factory

Public Member Functions

 TrackCollectionCnv_tlp2 ()
virtual ~TrackCollectionCnv_tlp2 ()
virtual void setPStorage (Trk::TrackCollection_tlp2 *storage)
 A stub for a method that should be provided by the converter creator.
virtual TPCnvTokenList_p1getTokenListVar ()
 Return the list of tokens to the objects extending the object owned by this converter.
TRANScreateTransient (MsgStream &log)
 Create transient representation of the persistent object known to this converter.
TRANScreateTransientWithKey (const std::string &key, MsgStream &log)
 Create transient representation of the persistent object known to this converter.
virtual Trk::TrackCollection_tlp2createPersistent (const TRANS *transObj, MsgStream &log)
 Create persistent representation of transObj.
virtual Trk::TrackCollection_tlp2createPersistentWithKey (const TRANS *transObj, const std::string &key, MsgStream &log)
 Create persistent representation of transObj.
void addMainTPConverter ()
 Add the main TP converter to the internal list - should be called from user-defined constructor.
void setMainCnvPStorage (STORAGE *storage)
 Set the persistent storage space for the main TP converter.
virtual unsigned short getConverterID () override
 Returns this converter's ID.
virtual const std::type_info & transientTInfo () const override
 return C++ type id of the transient class this converter is for
virtual const std::type_info & persistentTInfo () const override
 return C++ type id of the persistent class this converter is for
virtual void persToTransUntyped (const void *pers, void *trans, MsgStream &log) override
 Convert persistent object representation to transient.
virtual void transToPersUntyped (const void *trans, void *pers, MsgStream &log) override
 Convert transient object representation to persistent.
virtual void persToTransWithKeyUntyped (const void *pers, void *trans, const std::string &, MsgStream &log) override
 Convert persistent object representation to transient.
virtual void transToPersWithKeyUntyped (const void *trans, void *pers, const std::string &, MsgStream &log) override
 Convert transient object representation to persistent.
virtual void persToTrans (const PERS *pers, TRANS *trans, MsgStream &msg)
virtual void transToPers (const TRANS *trans, PERS *pers, MsgStream &msg)
virtual bool hasTLPersObject () const override
 Returns true if the converter has a persistent object.
virtual void createTLPersObject () override
 Create persistent object - the converter keeps it.
virtual void deleteTLPersObject () override
 Delete the persistent object owned by the converter.
Trk::TrackCollection_tlp2getTLPersObject ()
const Trk::TrackCollection_tlp2getTLPersObject () const
Trk::TrackCollection_tlp2releaseTLPersObject ()
 @release the persistent object from this converter
virtual void * getTLPersObjectAsVoid () override
virtual const void * getTLPersObjectAsVoid () const override
virtual void clearTLPersObject () override
 Discard the persistent object.
virtual void setTLPersObject (void *persObj) override
 Take ownership of the persistent object.
virtual TPCnvTokenList_p1getTokenListVarFrom (void *persObj) override
 Return the list of tokens to the objects extending the object NOT owned by this converter.
virtual void addTPConverter (ITPConverter *cnv)
 Add a TP converter to this top level converter.
virtual void addTPConverterForReading (ITPConverter *cnv)
 Add a TP converter to this top level converter but only for reading.
virtual void addExtTPConverterForReading (ITPConverter *cnv)
 add extending TP converter to this top level converter - to the list consulted when reading only.
virtual void addTPConvertersTo (TopLevelTPCnvBase *dest)
 copy all extending converters from this top level converter to "dest" top level converter
virtual void addTPConvertersForReadingTo (TopLevelTPCnvBase *dest)
 copy all extending converters from this top level converter to "dest" top level converter - for reading
ITPConverterconverterForType (const std::type_info &info) const
 Find and return a TP converter for a given C++ type info.
ITPConverterconverterForRef (const TPObjRef &ref) const
 Find and return a TP converter for persistent type referenced by ref.

Protected Types

typedef std::map< unsigned, ITPConverter * > convIdMap_t

Protected Member Functions

void rememberConverter (TopLevelTPCnvBase *cnv)
 Remember that elemental TP converters from the given top-level converter are already registered.
bool hasConvertersFrom (TopLevelTPCnvBase *cnv)
 Check if TP converters from a given top-level converter were already registered in this converter.

Protected Attributes

TrackCnv_p2 m_tracksCnv
TrackStateOnSurfaceCnv_p2 m_trackStatesCnv
RIO_OnTrackCnv_p1 m_RIOsCnv
PseudoMeasurementOnTrackCnv_p1 m_pseudoMeasurementOnTrackCnv
CompetingRIOsOnTrackCnv_p1 m_crotCnv
MeasuredAtaDiscCnv_p1 m_measuredAtaDiscsCnv
MeasuredAtaCylinderCnv_p1 m_measuredAtaCylindersCnv
MeasuredAtaPlaneCnv_p1 m_measuredAtaPlanesCnv
MeasuredAtaStraightLineCnv_p1 m_measuredAtaStraightLinesCnv
AtaDiscCnv_p1 m_ataDiscsCnv
AtaCylinderCnv_p1 m_ataCylindersCnv
AtaPlaneCnv_p1 m_ataPlanesCnv
AtaStraightLineCnv_p1 m_ataStraightLinesCnv
PerigeeSurfaceCnv_p1 m_perigeeSurfacesCnv
PerigeeCnv_p1 m_perigeesCnv
MeasuredPerigeeCnv_p1 m_measuredPerigeesCnv
TrackParametersCnv_p1 m_parametersCnv
DiscSurfaceCnv_p1 m_discSurfacesCnv
PlaneSurfaceCnv_p1 m_planeSurfacesCnv
CylinderSurfaceCnv_p1 m_cylinderSurfacesCnv
StraightLineSurfaceCnv_p1 m_straightLineSurfacesCnv
DetElementSurfaceCnv_p1 m_detElSurfCnv
SurfaceCnv_p1 m_surfacesCnv
CylinderBoundsCnv_p1 m_cylinderBoundsCnv
DiamondBoundsCnv_p1 m_diamondBoundsCnv
RotatedDiamondBoundsCnv_p1 m_rotatedDiamondBoundsCnv
DiscBoundsCnv_p1 m_discBoundsCnv
RectangleBoundsCnv_p1 m_rectangleBoundsCnv
TrapezoidBoundsCnv_p1 m_trapesoidBoundsCnv
RotatedTrapezoidBoundsCnv_p1 m_rotatedTrapesoidBoundsCnv
FitQualityCnv_p1 m_fitQualitiesCnv
CovarianceMatrixCnv_p1 m_covarianceMatricesCnv
ErrorMatrixCnv_p1 m_errorMatricesCnv
MaterialEffectsBaseCnv_p1 m_matEffectsBaseCnv
EnergyLossCnv_p1 m_energyLossCnv
MaterialEffectsOnTrackCnv_p2 m_materialEffectsCnv
EstimatedBremOnTrackCnv_p1 m_estimatedBremCnv
LocalDirectionCnv_p1 m_localDirectionsCnv
LocalPositionCnv_p1 m_localPositionsCnv
LocalParametersCnv_p1 m_localParametersCnv
TrackCollectionCnv_p2 m_mainConverter
Trk::TrackCollection_tlp2m_tlPersObject
 The persistent object this conveter is working on.
convIdMap_t m_convIdMap
 Map of elemental TP converters indexed by their ID - used for reading.
TPConverterTypeMap< ITPConverterm_converters
 Map of elemental TP converters indexed by transient typeid - used for writing.
std::set< TopLevelTPCnvBase * > m_registeredTLConverters
 Set top-level converters from which elemental TP converters were registered.
unsigned m_typeIDCount
 Counter used to create typed IDs used in the transient Ref.

Private Member Functions

virtual void addTPConverterForWriting (ITPConverter *cnv)
 add TP converter to the list of converters consulted when writing - internal method.

Detailed Description

Definition at line 56 of file TrackCollectionCnv_tlp2.h.

Member Typedef Documentation

◆ convIdMap_t

typedef std::map<unsigned, ITPConverter*> TopLevelTPCnvBase::convIdMap_t
protectedinherited

Definition at line 174 of file TopLevelTPCnvBase.h.

◆ Factory

typedef Gaudi::PluginService::Factory<ITPCnvBase*()> ITPCnvBase::Factory
inherited

Definition at line 26 of file ITPCnvBase.h.

◆ PERS

◆ TRANS

Constructor & Destructor Documentation

◆ TrackCollectionCnv_tlp2()

TrackCollectionCnv_tlp2::TrackCollectionCnv_tlp2 ( )

Definition at line 8 of file TrackCollectionCnv_tlp2.cxx.

9{
10 // Add all converters defined in this top level converter:
11 // never change the order of adding converters!
13
16
19
24
29
34
40
47
58
60
61 // Added with Tag TrkEventTPCnv-00-16-00
63}
RotatedTrapezoidBoundsCnv_p1 m_rotatedTrapesoidBoundsCnv
MeasuredAtaCylinderCnv_p1 m_measuredAtaCylindersCnv
TrackStateOnSurfaceCnv_p2 m_trackStatesCnv
PseudoMeasurementOnTrackCnv_p1 m_pseudoMeasurementOnTrackCnv
MeasuredAtaPlaneCnv_p1 m_measuredAtaPlanesCnv
DiamondBoundsCnv_p1 m_diamondBoundsCnv
MeasuredAtaStraightLineCnv_p1 m_measuredAtaStraightLinesCnv
TrackParametersCnv_p1 m_parametersCnv
PlaneSurfaceCnv_p1 m_planeSurfacesCnv
RectangleBoundsCnv_p1 m_rectangleBoundsCnv
LocalPositionCnv_p1 m_localPositionsCnv
LocalDirectionCnv_p1 m_localDirectionsCnv
MaterialEffectsBaseCnv_p1 m_matEffectsBaseCnv
CovarianceMatrixCnv_p1 m_covarianceMatricesCnv
DetElementSurfaceCnv_p1 m_detElSurfCnv
TrapezoidBoundsCnv_p1 m_trapesoidBoundsCnv
StraightLineSurfaceCnv_p1 m_straightLineSurfacesCnv
AtaStraightLineCnv_p1 m_ataStraightLinesCnv
CylinderSurfaceCnv_p1 m_cylinderSurfacesCnv
PerigeeSurfaceCnv_p1 m_perigeeSurfacesCnv
MaterialEffectsOnTrackCnv_p2 m_materialEffectsCnv
MeasuredAtaDiscCnv_p1 m_measuredAtaDiscsCnv
EstimatedBremOnTrackCnv_p1 m_estimatedBremCnv
CylinderBoundsCnv_p1 m_cylinderBoundsCnv
MeasuredPerigeeCnv_p1 m_measuredPerigeesCnv
LocalParametersCnv_p1 m_localParametersCnv
CompetingRIOsOnTrackCnv_p1 m_crotCnv

◆ ~TrackCollectionCnv_tlp2()

virtual TrackCollectionCnv_tlp2::~TrackCollectionCnv_tlp2 ( )
inlinevirtual

Definition at line 62 of file TrackCollectionCnv_tlp2.h.

62{}

Member Function Documentation

◆ addExtTPConverterForReading()

add extending TP converter to this top level converter - to the list consulted when reading only.

Parameters
cnv[IN] the TP converter to be added

Definition at line 60 of file TopLevelTPCnvBase.cxx.

48{
49 // for reading, converters are selected based on our own typeID value
50 // which comes from the Ref
51 // Ref contains top level converter ID + local type ID
52 m_convIdMap[ converter->typeID().value() ] = converter;
53
54// std::cout << " **addExtTPConverterForReading - adding converter for " << converter->transientTInfo().name() << " CnvID=" << converter->typeID().value() << std::endl;
55 converter->setRuntimeTopConverter( this );
56}
TopLevelTPConverter is the final and most specialized template for all top-level TP converters.

◆ addMainTPConverter()

void TopLevelTPConverter< TrackCollectionCnv_p2, Trk::TrackCollection_tlp2 >::addMainTPConverter ( )
inlineinherited

Add the main TP converter to the internal list - should be called from user-defined constructor.

Definition at line 146 of file TopLevelTPConverter.h.

◆ addTPConverter()

void TopLevelTPCnvBase::addTPConverter ( ITPConverter * cnv)
virtualinherited

Add a TP converter to this top level converter.

Parameters
cnv[IN] the TP converter to be added

Definition at line 42 of file TopLevelTPCnvBase.cxx.

◆ addTPConverterForReading()

Add a TP converter to this top level converter but only for reading.

Old converters that read schema evolved objects should be added only for reading.

Parameters
cnv[IN] the TP converter to be added

Definition at line 48 of file TopLevelTPCnvBase.cxx.

20{
21 // for reading, converters are selected based on their typeID value
22 // which comes from the Ref
23 // Ref contains top level converter ID + local type ID
26
27// std::cout << " **addTPConverter - adding converter for " << converter->transientTInfo().name() << " CnvID=" << full_typeID.value() << std::endl;
28 converter->setTopConverter( this, full_typeID );
29}

◆ addTPConverterForWriting()

void TopLevelTPCnvBase::addTPConverterForWriting ( ITPConverter * cnv)
privatevirtualinherited

add TP converter to the list of converters consulted when writing - internal method.

Parameters
cnv[IN] the TP converter to be added

Definition at line 54 of file TopLevelTPCnvBase.cxx.

34{
35 // add converter to the map keyed by type_info
36 // this map is used to find a converter when writing
38 if( m_converters.findConverter( info ) ) {
39 // adding a second converter for the same type will mess up things
40 const std::string error("Duplicate TP converter for class ");
41 throw std::runtime_error( error + info.name() );
42 }
43 m_converters.addConverter( converter, info );
44}
virtual const std::type_info & transientTInfo() const override
return C++ type id of the transient class this converter is for

◆ addTPConvertersForReadingTo()

copy all extending converters from this top level converter to "dest" top level converter - for reading

Parameters
dest[IN] destination converter which will receive all elemental TP converters that this one has

Definition at line 74 of file TopLevelTPCnvBase.cxx.

79{
80 // check if we have done this already, and if so then exit
81 if( cnv->hasConvertersFrom( this ) ) {
82 return;
83 }
84 // copy all TP converters to another topLevel conveter
85 for( convIdMap_t::const_iterator itr = m_convIdMap.begin();
86 itr != m_convIdMap.end(); ++itr ) {
88 }
89 // prevent attempts to add the same converters again
90 cnv->rememberConverter( this );
91}
virtual void addExtTPConverterForReading(ITPConverter *cnv)
add extending TP converter to this top level converter - to the list consulted when reading only.
void rememberConverter(TopLevelTPCnvBase *cnv)
Remember that elemental TP converters from the given top-level converter are already registered.
bool hasConvertersFrom(TopLevelTPCnvBase *cnv)
Check if TP converters from a given top-level converter were already registered in this converter.

◆ addTPConvertersTo()

copy all extending converters from this top level converter to "dest" top level converter

copy all TP converters to another topLevel conveter

Parameters
dest[IN] destination converter which will receive all elemental TP converters that this one has

Definition at line 67 of file TopLevelTPCnvBase.cxx.

61{
62 // loop over all registered converters
63 for( convIdMap_t::const_iterator itr = m_convIdMap.begin();
64 itr != m_convIdMap.end(); ++itr ) {
65 // check if the converter is in the list of R/W converters
66 if( m_converters.findConverter( itr->second->transientTInfo() ) == itr->second ) {
67 // this is a R/W converter, add it for writing too
69 }
70 // add the convterter for reading
72 }
73 // prevent adding of the same converter again
74 cnv->rememberConverter( this );
75}

◆ clearTLPersObject()

virtual void TopLevelTPCnvBaseP< Trk::TrackCollection_tlp2 >::clearTLPersObject ( )
inlineoverridevirtualinherited

Discard the persistent object.

Definition at line 99 of file TopLevelTPCnvBaseP.h.

◆ converterForRef()

Find and return a TP converter for persistent type referenced by ref.

Parameters
ref[IN] TP reference of a persistent object
Returns
ITPConverter* pointer to the TP converter for ref

Definition at line 89 of file TopLevelTPCnvBase.h.

89 {
90 convIdMap_t::const_iterator iter = m_convIdMap.find( ref.typeID() );
91 return (iter == m_convIdMap.end())?
92 0 : iter->second;
93 }

◆ converterForType()

ITPConverter * TopLevelTPCnvBase::converterForType ( const std::type_info & info) const
inlineinherited

Find and return a TP converter for a given C++ type info.

Parameters
info[IN] C++ type info reference to the transient type
Returns
ITPConverter* pointer to the TP converter for type info

Definition at line 80 of file TopLevelTPCnvBase.h.

80 {
81 return m_converters.findConverter( info );
82 }

◆ createPersistent()

virtual Trk::TrackCollection_tlp2 * TopLevelTPConverter< TrackCollectionCnv_p2, Trk::TrackCollection_tlp2 >::createPersistent ( const TRANS * transObj,
MsgStream & log )
inlinevirtualinherited

Create persistent representation of transObj.

Parameters
transObj[IN] pointer to the transient representation
log[IN] message stream for output
Returns
TL_PRES* persistent object passed by a pointer

Definition at line 110 of file TopLevelTPConverter.h.

111 {
112 // create a new persistent object (empty)
113 this->createTLPersObject();
114 // do transToPers conversion, fill in the persistent object
115 m_mainConverter.virt_toPersistent(transObj, log);
116 // take the persistent object away from the TL converter
117 TL_PERS *ret = this->getTLPersObject();
118 // important to clear so createTransient() will not try to delete it (and crash)
119 this->clearTLPersObject();
120 return ret;
121 }

◆ createPersistentWithKey()

virtual Trk::TrackCollection_tlp2 * TopLevelTPConverter< TrackCollectionCnv_p2, Trk::TrackCollection_tlp2 >::createPersistentWithKey ( const TRANS * transObj,
const std::string & key,
MsgStream & log )
inlinevirtualinherited

Create persistent representation of transObj.

Parameters
transObj[IN] pointer to the transient representation
key[IN] SG key of the object being converted.
log[IN] message stream for output
Returns
TL_PRES* persistent object passed by a pointer

Definition at line 129 of file TopLevelTPConverter.h.

132 {
133 // create a new persistent object (empty)
134 this->createTLPersObject();
135 // do transToPers conversion, fill in the persistent object
136 m_mainConverter.virt_toPersistentWithKey(transObj, key, log);
137 // take the persistent object away from the TL converter
138 TL_PERS *ret = this->getTLPersObject();
139 // important to clear so createTransient() will not try to delete it (and crash)
140 this->clearTLPersObject();
141 return ret;
142 }

◆ createTLPersObject()

virtual void TopLevelTPCnvBaseP< Trk::TrackCollection_tlp2 >::createTLPersObject ( )
inlineoverridevirtualinherited

Create persistent object - the converter keeps it.

Definition at line 57 of file TopLevelTPCnvBaseP.h.

57 {
58 m_tlPersObject = new TL_PERS();
60 }
virtual void setPStorage(Trk::TrackCollection_tlp2 *persObj) override=0

◆ createTransient()

TRANS * TopLevelTPConverter< TrackCollectionCnv_p2, Trk::TrackCollection_tlp2 >::createTransient ( MsgStream & log)
inlineinherited

Create transient representation of the persistent object known to this converter.

NOTE: If the persistent object is owned by the converter, it will be deleted

Parameters
log[IN] message stream for output
Returns
TRANS* transient object passed by a pointer

Definition at line 62 of file TopLevelTPConverter.h.

62 {
63 // 0 is the index of the main and only one top level object
64 TRANS *transObj = m_mainConverter.virt_createTransFromPStore( 0, log );
65 this->deleteTLPersObject();
66 return transObj;
67 }

◆ createTransientWithKey()

TRANS * TopLevelTPConverter< TrackCollectionCnv_p2, Trk::TrackCollection_tlp2 >::createTransientWithKey ( const std::string & key,
MsgStream & log )
inlineinherited

Create transient representation of the persistent object known to this converter.

NOTE: If the persistent object is owned by the converter, it will be deleted

Parameters
key[IN] SG key of the object being converted
log[IN] message stream for output
Returns
TRANS* transient object passed by a pointer

Definition at line 78 of file TopLevelTPConverter.h.

80 {
81 // 0 is the index of the main and only one top level object
82 TRANS *transObj = m_mainConverter.virt_createTransFromPStoreWithKey( 0, key, log );
83 this->deleteTLPersObject();
84 return transObj;
85 }

◆ deleteTLPersObject()

virtual void TopLevelTPCnvBaseP< Trk::TrackCollection_tlp2 >::deleteTLPersObject ( )
inlineoverridevirtualinherited

Delete the persistent object owned by the converter.

Definition at line 64 of file TopLevelTPCnvBaseP.h.

64 {
65 if( m_tlPersObject ) {
66 delete m_tlPersObject;
68 }
69 }

◆ getConverterID()

virtual unsigned short TopLevelTPConverter< TrackCollectionCnv_p2, Trk::TrackCollection_tlp2 >::getConverterID ( void )
inlineoverridevirtualinherited

Returns this converter's ID.

By default it is 0. Should be overwritten in extending converters

Returns
this converter's ID

Implements TopLevelTPCnvBase.

Definition at line 159 of file TopLevelTPConverter.h.

159{ return 0; }

◆ getTLPersObject() [1/2]

Trk::TrackCollection_tlp2 * TopLevelTPCnvBaseP< Trk::TrackCollection_tlp2 >::getTLPersObject ( )
inlineinherited
Returns
pointer to the persistent object owned by this converter

Definition at line 72 of file TopLevelTPCnvBaseP.h.

72 {
73 return m_tlPersObject;
74 }

◆ getTLPersObject() [2/2]

const Trk::TrackCollection_tlp2 * TopLevelTPCnvBaseP< Trk::TrackCollection_tlp2 >::getTLPersObject ( ) const
inlineinherited
Returns
pointer to the persistent object owned by this converter

Definition at line 77 of file TopLevelTPCnvBaseP.h.

77 {
78 return m_tlPersObject;
79 }

◆ getTLPersObjectAsVoid() [1/2]

virtual const void * TopLevelTPCnvBaseP< Trk::TrackCollection_tlp2 >::getTLPersObjectAsVoid ( ) const
inlineoverridevirtualinherited

Returns
pointer to the persistent object owned by this converter as void*

Definition at line 94 of file TopLevelTPCnvBaseP.h.

94 {
95 return getTLPersObject();
96 }

◆ getTLPersObjectAsVoid() [2/2]

virtual void * TopLevelTPCnvBaseP< Trk::TrackCollection_tlp2 >::getTLPersObjectAsVoid ( )
inlineoverridevirtualinherited

Returns
pointer to the persistent object owned by this converter as void*

Definition at line 89 of file TopLevelTPCnvBaseP.h.

89 {
90 return getTLPersObject();
91 }

◆ getTokenListVar()

virtual TPCnvTokenList_p1 * TrackCollectionCnv_tlp2::getTokenListVar ( )
inlinevirtual

Return the list of tokens to the objects extending the object owned by this converter.

This method is needed only in a conveter which has extensions. It needs to be implemented in the top-level converter by the user

Returns
pointer to the token list from the persistent object

Reimplemented from TopLevelTPCnvBaseP< Trk::TrackCollection_tlp2 >.

Definition at line 68 of file TrackCollectionCnv_tlp2.h.

68{ return &(getTLPersObject()->m_tokenList); }

◆ getTokenListVarFrom()

virtual TPCnvTokenList_p1 * TopLevelTPCnvBaseP< Trk::TrackCollection_tlp2 >::getTokenListVarFrom ( void * persObj)
inlineoverridevirtualinherited

Return the list of tokens to the objects extending the object NOT owned by this converter.

Parameters
persObj[IN] persistent object from which contains list of tokens. Passes as void* - if the type is wrong, it may crash
Returns
pointer to the token list from persObj

Definition at line 115 of file TopLevelTPCnvBaseP.h.

115 {
116 // avoid setting up the pointer to persistent object
117 // (can lead to deleting it twice, if the user deletes too)
119 m_tlPersObject = reinterpret_cast<TL_PERS*>( persObj );
122 return toklist;
123 }

◆ hasConvertersFrom()

bool TopLevelTPCnvBase::hasConvertersFrom ( TopLevelTPCnvBase * cnv)
inlineprotectedinherited

Check if TP converters from a given top-level converter were already registered in this converter.

Parameters
cnv[IN] top-level converter to check
Returns
true if TP converters from cnv were already registered

Definition at line 166 of file TopLevelTPCnvBase.h.

◆ hasTLPersObject()

virtual bool TopLevelTPCnvBaseP< Trk::TrackCollection_tlp2 >::hasTLPersObject ( ) const
inlineoverridevirtualinherited

Returns true if the converter has a persistent object.

Definition at line 52 of file TopLevelTPCnvBaseP.h.

52 {
53 return m_tlPersObject;
54 }

◆ persistentTInfo()

virtual const std::type_info & TopLevelTPConverter< TrackCollectionCnv_p2, Trk::TrackCollection_tlp2 >::persistentTInfo ( ) const
inlineoverridevirtualinherited

return C++ type id of the persistent class this converter is for

Returns
std::type_info&

Implements ITPCnvBase.

Definition at line 169 of file TopLevelTPConverter.h.

◆ persToTrans()

virtual void TopLevelTPConverter< TrackCollectionCnv_p2, Trk::TrackCollection_tlp2 >::persToTrans ( const PERS * pers,
TRANS * trans,
MsgStream & msg )
inlinevirtualinherited

Definition at line 201 of file TopLevelTPConverter.h.

201 {
202 // FIXME: TPConverter uses the same non-const member m_pStorage
203 // for both reading and writing, but we want it to be const
204 // in the former case.
207 m_mainConverter.pstoreToTrans (0, trans, msg);
208 }

◆ persToTransUntyped()

virtual void TopLevelTPConverter< TrackCollectionCnv_p2, Trk::TrackCollection_tlp2 >::persToTransUntyped ( const void * pers,
void * trans,
MsgStream & log )
inlineoverridevirtualinherited

Convert persistent object representation to transient.

Parameters
pers[IN] void* pointer to the persistent object
trans[OUT] void* pointer to the empty transient object
log[IN] output message stream

Implements ITPCnvBase.

Definition at line 173 of file TopLevelTPConverter.h.

173 {
174 persToTrans( reinterpret_cast<const PERS*>(pers), reinterpret_cast<TRANS*>(trans), log );
175 }
virtual void persToTrans(const PERS *pers, TRANS *trans, MsgStream &msg)

◆ persToTransWithKeyUntyped()

virtual void TopLevelTPConverter< TrackCollectionCnv_p2, Trk::TrackCollection_tlp2 >::persToTransWithKeyUntyped ( const void * pers,
void * trans,
const std::string & ,
MsgStream & log )
inlineoverridevirtualinherited

Convert persistent object representation to transient.

Parameters
pers[IN] void* pointer to the persistent object
trans[OUT] void* pointer to the empty transient object
key[IN] SG key of object being read.
log[IN] output message stream

Reimplemented from ITPCnvBase.

Definition at line 183 of file TopLevelTPConverter.h.

187 {
188 persToTrans( reinterpret_cast<const PERS*>(pers), reinterpret_cast<TRANS*>(trans), log );
189 }

◆ releaseTLPersObject()

Trk::TrackCollection_tlp2 * TopLevelTPCnvBaseP< Trk::TrackCollection_tlp2 >::releaseTLPersObject ( )
inlineinherited

@release the persistent object from this converter

Definition at line 82 of file TopLevelTPCnvBaseP.h.

82 {
85 return tmp;
86 }

◆ rememberConverter()

void TopLevelTPCnvBase::rememberConverter ( TopLevelTPCnvBase * cnv)
inlineprotectedinherited

Remember that elemental TP converters from the given top-level converter are already registered.

Parameters
cnv[IN] top-level TP converter - source of the elemental TP converters

Definition at line 156 of file TopLevelTPCnvBase.h.

157 {
159 }

◆ setMainCnvPStorage()

void TopLevelTPConverter< TrackCollectionCnv_p2, Trk::TrackCollection_tlp2 >::setMainCnvPStorage ( STORAGE * storage)
inlineinherited

Set the persistent storage space for the main TP converter.

Definition at line 152 of file TopLevelTPConverter.h.

152 {
153 m_mainConverter.setPStorage( storage );
154 }

◆ setPStorage()

void TrackCollectionCnv_tlp2::setPStorage ( Trk::TrackCollection_tlp2 * persObj)
virtual

A stub for a method that should be provided by the converter creator.

In that methods all elemental TP converters that belong to this top-level converter need to be assigned to storage vectors in the persistent object.

Parameters
persObj[IN] persistent object

Implements TopLevelTPConverter< TrackCollectionCnv_p2, Trk::TrackCollection_tlp2 >.

Definition at line 67 of file TrackCollectionCnv_tlp2.cxx.

68{
69 // for implicit TrackCollection_p1 from the base class:
70 setMainCnvPStorage( &storage->m_trackCollections );
71
72 // for all converters defined in this top level converter
73 m_tracksCnv. setPStorage( &storage->m_tracks );
74 m_trackStatesCnv. setPStorage( &storage->m_trackStates );
75
76 m_RIOsCnv. setPStorage( &storage->m_RIOs );
77 m_pseudoMeasurementOnTrackCnv.setPStorage( &storage->m_pseudoMeasurementOnTrack );
78
79 m_measuredAtaDiscsCnv. setPStorage( &storage->m_measuredAtaSurfaces );
80 m_measuredAtaPlanesCnv. setPStorage( &storage->m_measuredAtaSurfaces );
81 m_measuredAtaCylindersCnv. setPStorage( &storage->m_measuredAtaSurfaces );
82 m_measuredAtaStraightLinesCnv.setPStorage( &storage->m_measuredAtaSurfaces );
83
84 m_ataDiscsCnv. setPStorage( &storage->m_ataSurfaces );
85 m_ataPlanesCnv. setPStorage( &storage->m_ataSurfaces );
86 m_ataCylindersCnv. setPStorage( &storage->m_ataSurfaces );
87 m_ataStraightLinesCnv. setPStorage( &storage->m_ataSurfaces );
88
89 m_perigeeSurfacesCnv. setPStorage( &storage->m_surfaces );
90 m_parametersCnv. setPStorage( &storage->m_parameters );
91 m_perigeesCnv. setPStorage( &storage->m_perigees );
92 m_measuredPerigeesCnv. setPStorage( &storage->m_measuredPerigees );
93
94 m_discSurfacesCnv. setPStorage( &storage->m_boundSurfaces );
95 m_planeSurfacesCnv. setPStorage( &storage->m_boundSurfaces );
96 m_cylinderSurfacesCnv. setPStorage( &storage->m_boundSurfaces );
97 m_straightLineSurfacesCnv. setPStorage( &storage->m_boundSurfaces );
98 m_surfacesCnv. setPStorage( &storage->m_surfaces );
99 m_cylinderBoundsCnv. setPStorage( &storage->m_cylinderBounds );
100 m_diamondBoundsCnv. setPStorage( &storage->m_diamondBounds );
101 m_discBoundsCnv. setPStorage( &storage->m_discBounds );
102 m_rectangleBoundsCnv. setPStorage( &storage->m_rectangleBounds );
103 m_trapesoidBoundsCnv. setPStorage( &storage->m_trapesoidBounds );
104 m_rotatedTrapesoidBoundsCnv. setPStorage( &storage->m_rotatedTrapesoidBounds);
105
106 m_fitQualitiesCnv. setPStorage( &storage->m_fitQualities );
107 m_covarianceMatricesCnv. setPStorage( &storage->m_hepSymMatrices );
108 m_errorMatricesCnv. setPStorage( &storage->m_hepSymMatrices );
109 m_matEffectsBaseCnv. setPStorage( &storage->m_matEffectsBases );
110 m_energyLossCnv. setPStorage( &storage->m_energyLosses );
111 m_materialEffectsCnv. setPStorage( &storage->m_materialEffects );
112 m_estimatedBremCnv. setPStorage( &storage->m_estimatedBrems );
113 m_localDirectionsCnv. setPStorage( &storage->m_localDirections );
114 m_localPositionsCnv. setPStorage( &storage->m_localPositions );
115 m_localParametersCnv. setPStorage( &storage->m_localParameters );
116 m_crotCnv. setPStorage( &storage->m_competingRotsOnTrack );
117 m_detElSurfCnv. setPStorage( &storage->m_detElementSurfaces );
118
119}
virtual void setPStorage(Trk::TrackCollection_tlp2 *storage)
A stub for a method that should be provided by the converter creator.

◆ setTLPersObject()

virtual void TopLevelTPCnvBaseP< Trk::TrackCollection_tlp2 >::setTLPersObject ( void * persObj)
inlineoverridevirtualinherited

Take ownership of the persistent object.

Also initialize all elemental TP converters to use that object.

Parameters
persObj[IN] the persistent object passed as void*

Definition at line 104 of file TopLevelTPCnvBaseP.h.

104 {
105 if( m_tlPersObject ) delete m_tlPersObject;
106 m_tlPersObject = reinterpret_cast<TL_PERS*>( persObj );
108 }

◆ transientTInfo()

virtual const std::type_info & TopLevelTPConverter< TrackCollectionCnv_p2, Trk::TrackCollection_tlp2 >::transientTInfo ( ) const
inlineoverridevirtualinherited

return C++ type id of the transient class this converter is for

Returns
std::type_info&

Implements ITPCnvBase.

Definition at line 166 of file TopLevelTPConverter.h.

166{ return typeid(TRANS); }

◆ transToPers()

virtual void TopLevelTPConverter< TrackCollectionCnv_p2, Trk::TrackCollection_tlp2 >::transToPers ( const TRANS * trans,
PERS * pers,
MsgStream & msg )
inlinevirtualinherited

Definition at line 210 of file TopLevelTPConverter.h.

210 {
211 this->setTLPersObject( pers );
212 m_mainConverter.virt_toPersistent(trans, msg);
213 this->clearTLPersObject();
214 }

◆ transToPersUntyped()

virtual void TopLevelTPConverter< TrackCollectionCnv_p2, Trk::TrackCollection_tlp2 >::transToPersUntyped ( const void * trans,
void * pers,
MsgStream & log )
inlineoverridevirtualinherited

Convert transient object representation to persistent.

Parameters
trans[IN] void* pointer to the transient object
pers[OUT] void* pointer to the empty persistent object
log[IN] output message stream

Implements ITPCnvBase.

Definition at line 178 of file TopLevelTPConverter.h.

178 {
179 transToPers( reinterpret_cast<const TRANS*>(trans), reinterpret_cast<PERS*>(pers), log );
180 }
virtual void transToPers(const TRANS *trans, PERS *pers, MsgStream &msg)

◆ transToPersWithKeyUntyped()

virtual void TopLevelTPConverter< TrackCollectionCnv_p2, Trk::TrackCollection_tlp2 >::transToPersWithKeyUntyped ( const void * trans,
void * pers,
const std::string & ,
MsgStream & log )
inlineoverridevirtualinherited

Convert transient object representation to persistent.

Parameters
trans[IN] void* pointer to the transient object
pers[OUT] void* pointer to the empty persistent object
key[IN] SG key of object being written.
log[IN] output message stream

Reimplemented from ITPCnvBase.

Definition at line 192 of file TopLevelTPConverter.h.

196 {
197 transToPers( reinterpret_cast<const TRANS*>(trans), reinterpret_cast<PERS*>(pers), log );
198 }

Member Data Documentation

◆ m_ataCylindersCnv

AtaCylinderCnv_p1 TrackCollectionCnv_tlp2::m_ataCylindersCnv
protected

Definition at line 85 of file TrackCollectionCnv_tlp2.h.

◆ m_ataDiscsCnv

AtaDiscCnv_p1 TrackCollectionCnv_tlp2::m_ataDiscsCnv
protected

Definition at line 84 of file TrackCollectionCnv_tlp2.h.

◆ m_ataPlanesCnv

AtaPlaneCnv_p1 TrackCollectionCnv_tlp2::m_ataPlanesCnv
protected

Definition at line 86 of file TrackCollectionCnv_tlp2.h.

◆ m_ataStraightLinesCnv

AtaStraightLineCnv_p1 TrackCollectionCnv_tlp2::m_ataStraightLinesCnv
protected

Definition at line 87 of file TrackCollectionCnv_tlp2.h.

◆ m_converters

Map of elemental TP converters indexed by transient typeid - used for writing.

Definition at line 180 of file TopLevelTPCnvBase.h.

◆ m_convIdMap

Map of elemental TP converters indexed by their ID - used for reading.

Definition at line 177 of file TopLevelTPCnvBase.h.

◆ m_covarianceMatricesCnv

CovarianceMatrixCnv_p1 TrackCollectionCnv_tlp2::m_covarianceMatricesCnv
protected

Definition at line 109 of file TrackCollectionCnv_tlp2.h.

◆ m_crotCnv

CompetingRIOsOnTrackCnv_p1 TrackCollectionCnv_tlp2::m_crotCnv
protected

Definition at line 78 of file TrackCollectionCnv_tlp2.h.

◆ m_cylinderBoundsCnv

CylinderBoundsCnv_p1 TrackCollectionCnv_tlp2::m_cylinderBoundsCnv
protected

Definition at line 100 of file TrackCollectionCnv_tlp2.h.

◆ m_cylinderSurfacesCnv

CylinderSurfaceCnv_p1 TrackCollectionCnv_tlp2::m_cylinderSurfacesCnv
protected

Definition at line 95 of file TrackCollectionCnv_tlp2.h.

◆ m_detElSurfCnv

DetElementSurfaceCnv_p1 TrackCollectionCnv_tlp2::m_detElSurfCnv
protected

Definition at line 97 of file TrackCollectionCnv_tlp2.h.

◆ m_diamondBoundsCnv

DiamondBoundsCnv_p1 TrackCollectionCnv_tlp2::m_diamondBoundsCnv
protected

Definition at line 101 of file TrackCollectionCnv_tlp2.h.

◆ m_discBoundsCnv

DiscBoundsCnv_p1 TrackCollectionCnv_tlp2::m_discBoundsCnv
protected

Definition at line 103 of file TrackCollectionCnv_tlp2.h.

◆ m_discSurfacesCnv

DiscSurfaceCnv_p1 TrackCollectionCnv_tlp2::m_discSurfacesCnv
protected

Definition at line 93 of file TrackCollectionCnv_tlp2.h.

◆ m_energyLossCnv

EnergyLossCnv_p1 TrackCollectionCnv_tlp2::m_energyLossCnv
protected

Definition at line 112 of file TrackCollectionCnv_tlp2.h.

◆ m_errorMatricesCnv

ErrorMatrixCnv_p1 TrackCollectionCnv_tlp2::m_errorMatricesCnv
protected

Definition at line 110 of file TrackCollectionCnv_tlp2.h.

◆ m_estimatedBremCnv

EstimatedBremOnTrackCnv_p1 TrackCollectionCnv_tlp2::m_estimatedBremCnv
protected

Definition at line 114 of file TrackCollectionCnv_tlp2.h.

◆ m_fitQualitiesCnv

FitQualityCnv_p1 TrackCollectionCnv_tlp2::m_fitQualitiesCnv
protected

Definition at line 108 of file TrackCollectionCnv_tlp2.h.

◆ m_localDirectionsCnv

LocalDirectionCnv_p1 TrackCollectionCnv_tlp2::m_localDirectionsCnv
protected

Definition at line 115 of file TrackCollectionCnv_tlp2.h.

◆ m_localParametersCnv

LocalParametersCnv_p1 TrackCollectionCnv_tlp2::m_localParametersCnv
protected

Definition at line 117 of file TrackCollectionCnv_tlp2.h.

◆ m_localPositionsCnv

LocalPositionCnv_p1 TrackCollectionCnv_tlp2::m_localPositionsCnv
protected

Definition at line 116 of file TrackCollectionCnv_tlp2.h.

◆ m_mainConverter

Definition at line 217 of file TopLevelTPConverter.h.

◆ m_matEffectsBaseCnv

MaterialEffectsBaseCnv_p1 TrackCollectionCnv_tlp2::m_matEffectsBaseCnv
protected

Definition at line 111 of file TrackCollectionCnv_tlp2.h.

◆ m_materialEffectsCnv

MaterialEffectsOnTrackCnv_p2 TrackCollectionCnv_tlp2::m_materialEffectsCnv
protected

Definition at line 113 of file TrackCollectionCnv_tlp2.h.

◆ m_measuredAtaCylindersCnv

MeasuredAtaCylinderCnv_p1 TrackCollectionCnv_tlp2::m_measuredAtaCylindersCnv
protected

Definition at line 81 of file TrackCollectionCnv_tlp2.h.

◆ m_measuredAtaDiscsCnv

MeasuredAtaDiscCnv_p1 TrackCollectionCnv_tlp2::m_measuredAtaDiscsCnv
protected

Definition at line 80 of file TrackCollectionCnv_tlp2.h.

◆ m_measuredAtaPlanesCnv

MeasuredAtaPlaneCnv_p1 TrackCollectionCnv_tlp2::m_measuredAtaPlanesCnv
protected

Definition at line 82 of file TrackCollectionCnv_tlp2.h.

◆ m_measuredAtaStraightLinesCnv

MeasuredAtaStraightLineCnv_p1 TrackCollectionCnv_tlp2::m_measuredAtaStraightLinesCnv
protected

Definition at line 83 of file TrackCollectionCnv_tlp2.h.

◆ m_measuredPerigeesCnv

MeasuredPerigeeCnv_p1 TrackCollectionCnv_tlp2::m_measuredPerigeesCnv
protected

Definition at line 90 of file TrackCollectionCnv_tlp2.h.

◆ m_parametersCnv

TrackParametersCnv_p1 TrackCollectionCnv_tlp2::m_parametersCnv
protected

Definition at line 91 of file TrackCollectionCnv_tlp2.h.

◆ m_perigeesCnv

PerigeeCnv_p1 TrackCollectionCnv_tlp2::m_perigeesCnv
protected

Definition at line 89 of file TrackCollectionCnv_tlp2.h.

◆ m_perigeeSurfacesCnv

PerigeeSurfaceCnv_p1 TrackCollectionCnv_tlp2::m_perigeeSurfacesCnv
protected

Definition at line 88 of file TrackCollectionCnv_tlp2.h.

◆ m_planeSurfacesCnv

PlaneSurfaceCnv_p1 TrackCollectionCnv_tlp2::m_planeSurfacesCnv
protected

Definition at line 94 of file TrackCollectionCnv_tlp2.h.

◆ m_pseudoMeasurementOnTrackCnv

PseudoMeasurementOnTrackCnv_p1 TrackCollectionCnv_tlp2::m_pseudoMeasurementOnTrackCnv
protected

Definition at line 77 of file TrackCollectionCnv_tlp2.h.

◆ m_rectangleBoundsCnv

RectangleBoundsCnv_p1 TrackCollectionCnv_tlp2::m_rectangleBoundsCnv
protected

Definition at line 104 of file TrackCollectionCnv_tlp2.h.

◆ m_registeredTLConverters

Set top-level converters from which elemental TP converters were registered.

Definition at line 184 of file TopLevelTPCnvBase.h.

◆ m_RIOsCnv

RIO_OnTrackCnv_p1 TrackCollectionCnv_tlp2::m_RIOsCnv
protected

Definition at line 76 of file TrackCollectionCnv_tlp2.h.

◆ m_rotatedDiamondBoundsCnv

RotatedDiamondBoundsCnv_p1 TrackCollectionCnv_tlp2::m_rotatedDiamondBoundsCnv
protected

Definition at line 102 of file TrackCollectionCnv_tlp2.h.

◆ m_rotatedTrapesoidBoundsCnv

RotatedTrapezoidBoundsCnv_p1 TrackCollectionCnv_tlp2::m_rotatedTrapesoidBoundsCnv
protected

Definition at line 106 of file TrackCollectionCnv_tlp2.h.

◆ m_straightLineSurfacesCnv

StraightLineSurfaceCnv_p1 TrackCollectionCnv_tlp2::m_straightLineSurfacesCnv
protected

Definition at line 96 of file TrackCollectionCnv_tlp2.h.

◆ m_surfacesCnv

SurfaceCnv_p1 TrackCollectionCnv_tlp2::m_surfacesCnv
protected

Definition at line 99 of file TrackCollectionCnv_tlp2.h.

◆ m_tlPersObject

The persistent object this conveter is working on.

Definition at line 128 of file TopLevelTPCnvBaseP.h.

◆ m_tracksCnv

TrackCnv_p2 TrackCollectionCnv_tlp2::m_tracksCnv
protected

Definition at line 73 of file TrackCollectionCnv_tlp2.h.

◆ m_trackStatesCnv

TrackStateOnSurfaceCnv_p2 TrackCollectionCnv_tlp2::m_trackStatesCnv
protected

Definition at line 74 of file TrackCollectionCnv_tlp2.h.

◆ m_trapesoidBoundsCnv

TrapezoidBoundsCnv_p1 TrackCollectionCnv_tlp2::m_trapesoidBoundsCnv
protected

Definition at line 105 of file TrackCollectionCnv_tlp2.h.

◆ m_typeIDCount

unsigned TopLevelTPCnvBase::m_typeIDCount
protectedinherited

Counter used to create typed IDs used in the transient Ref.

Definition at line 187 of file TopLevelTPCnvBase.h.


The documentation for this class was generated from the following files: