ATLAS Offline Software
Loading...
Searching...
No Matches
JetTagInfoCnv Class Referenceabstract

#include <JetTagInfoCnv.h>

Inheritance diagram for JetTagInfoCnv:
Collaboration diagram for JetTagInfoCnv:

Public Types

typedef T_AthenaPoolCustomCnv< JetTagInfo, Analysis::JetTagInfo_tlp3BaseType

Public Member Functions

 JetTagInfoCnv (ISvcLocator *svcloc)
 Init our base class.
virtual StatusCode finalize () override
virtual long repSvcType () const override
virtual StatusCode createObj (IOpaqueAddress *pAddr, DataObject *&pObj) override
 Create a transient object from a POOL persistent representation.
virtual StatusCode createRep (DataObject *pObj, IOpaqueAddress *&pAddr) override
 Create a POOL persistent representation for a transient object.
virtual StatusCode fillRepRefs (IOpaqueAddress *pAddr, DataObject *pObj) override
 Create a POOL persistent representation for a transient object.
const ServiceHandle< StoreGateSvc > & detStore () const
 Handle to DetectorStore.
void addTrack (TIDA::Track *t)
const std::vector< TIDA::Track * > & tracks () const
void clear ()
void selectTracks (const TrigInDetTrackCollection *trigtracks)
void selectTracks (const Rec::TrackParticleContainer *trigtracks)
void selectTracks (const Analysis::MuonContainer *muontracks)
bool msgLvl (const MSG::Level lvl) const
 Test the output level.
MsgStream & msg () const
 The standard message stream.
MsgStream & msg (const MSG::Level lvl) const
 The standard message stream.
void setLevel (MSG::Level lvl)
 Change the current logging level.
virtual bool registerExtendingCnv (AthenaConverterTLPExtension *cnv)
 Register extending converter (that is, another converter that will extent this converter) and all his elemental converters.
virtual bool registerExtendingCnv (IConverter *cnv)
void usingTPCnvForReading (TopLevelTPCnvBase &baseTLPcnv)
unsigned short getTPCnvID ()
 Returns the ID of the main top-level TP converter.
TopLevelTPCnvBasegetTopLevelTPCnvForReading ()
 returns the current top-level TP converter.
void resetTPCnvForReading ()
 Reset to 0 the TL TP converter for reading.
virtual void readExtendingObjects (void *baseObj)
 Read all component persistent objects.
virtual void deletePersistentObjects ()
 Delete persistent objects held by attached extending converters (used mainly in case of abort)

Static Public Member Functions

static const CLIDclassID ()
static long storageType ()

Protected Types

typedef std::map< std::string, RootTypeClassMap
typedef ClassMap::const_iterator ClassMapIt
typedef std::mutex CallMutex
typedef std::map< unsigned, AthenaConverterTLPExtension * > extCnvMap_t
typedef std::map< TopLevelTPCnvBase *, extCnvMap_t * > extCnvMapMap_t

Protected Member Functions

StatusCode initialize (void)
 Make sure to pass on the init!
AthenaPoolTopLevelTPCnvBasegetTopLevelTPCnv (void)
 Return the top level TP converter (which is always used for writing)
AthenaPoolCnvTPExtensionclone (void)
 Clone this Athena Converter.
void readObjectFromPool (const std::string &obj)
 Read the persistant bit in.
virtual void readObject (const std::string &token) override
 Read the extending object.
virtual std::unique_ptr< const TokenwriteObject (const std::string &key, const std::string &output) override
 Write the persistent object to POOL.
virtual BaseTypebaseAthenaPoolCnv ()
 return the original AthenaPool converter this one was cloned from if not cloned this returns self if not registered this returns NULL
virtual void wasClonedFrom (AthenaConverterTLPExtension *orig_converter) override
 remember the original converter this one was cloned from
virtual bool needsCloning () const override
 tells if this converter needs to be cloned (true after the converter has been registered once already)
virtual void setToken (const std::string &token) override
 Set the token (in std::string representation) and classID for the object that will be read next.
PpoolReadObject ()
 Read object of type P.
void poolReadObject (TopLevelTPCnvBase &tlp_converter)
 Read object of type P (plus all extending objects) using the indicated top-level TP converter.
virtual const std::string name () const override
 Get the name of this converter (anything that identifies it).
virtual Analysis::JetTagInfo_tlp3createPersistent (JetTagInfo *) override
 no-op
virtual PERScreatePersistent (TRANS *obj)=0
virtual JetTagInfocreateTransient () override
virtual PERScreatePersistentWithKey (TRANS *obj, const std::string &) override
 method to be implemented by the developer.
virtual TRANS * createTransientWithKey (const std::string &) override
 method to be implemented by the developer.
void keepPoolObj (PERS *obj, const std::string &output)
 Remember the POOL object to be written out (will be deleted after commit)
virtual StatusCode transToPers (TRANS *, PERS *&) override
 Obsolete methods replaced by createPersistent() and createTransient() obsolete.
virtual StatusCode persToTrans (TRANS *&, PERS *) override
 obsolete
virtual StatusCode DataObjectToPers (DataObject *pObj, IOpaqueAddress *&pAddr) override
 Convert an object into Persistent.
virtual StatusCode DataObjectToPool (IOpaqueAddress *pAddr, DataObject *pObj) override
 Write an object into POOL.
virtual StatusCode PoolToDataObject (DataObject *&pObj, const Token *token, const std::string &key) override
 Read an object from POOL.
virtual StatusCode cleanUp (const std::string &output) override
 Callback from the CleanupSvc to delete persistent object in the local list.
template<class P>
Placement setPlacementForP (P &p, const std::string &key, const std::string &output)
 Set POOL placement for type P.
template<class P>
StatusCode objectToPool (P *pObj, std::unique_ptr< Token > &token, const std::string &key, const std::string &output)
 Write an object into POOL returning its token.
template<class P>
StatusCode poolToObject (const Token *&token, P *&pObj)
 Read an object from POOL.
virtual bool compareClassGuid (const Guid &clid) const
 Compare POOL class GUID with the one of the object being read.
virtual Placement setPlacement (const std::string &key, const std::string &output)
 Set POOL placement.
virtual Placement setPlacementWithType (const std::string &tname, const std::string &key, const std::string &output)
 Set POOL placement hint for a given type.
virtual const DataObject * getDataObject () const
double phiCorr (double phi)
void ipCorr (double d0, double z0, double &d0c, double &z0c, double phi0, double eta, double pt)
void usingTPCnvForReading (void *cnv)

Protected Attributes

BaseTypem_originalExtendingCnv
 pointer to the original Gaudi converter - only this one is registered in the framework and has to be used for all I/O operations
std::map< std::string, std::vector< std::unique_ptr< PERS > > > m_persObjLists
 Local cache for persistent objects created by this converter, grouped by processing slot These objects are deleted after a commit.
std::mutex m_pListMutex
 protection mutex for m_persObjLists
Guid m_classID
ServiceHandle< StoreGateSvcm_detStore
ServiceHandle< IAthenaPoolCnvSvcm_athenaPoolCnvSvc
RootType m_classDesc
std::string m_className
ClassMap m_classDescs
std::string m_containerPrefix
std::string m_containerNameHint
std::string m_branchNameHint
const DataObject * m_dataObject
const Tokenm_i_poolToken
CallMutex m_conv_mut
double m_beamX
double m_beamY
double m_beamZ
std::vector< TIDA::Track * > m_tracks
extCnvMap_t m_extendingConverters
 map of Athena converters extending this one
extCnvMapMap_t m_extCnvMapMap
TopLevelTPCnvBasem_TLCnvForReading
 additional Top Level TP converter used only for reading tells which converter is used in case of reading old versions (as different versions have different converters) NOT owned byt his class
std::vector< AthenaConverterTLPExtension * > m_clonedExtendingCnvs
 list of duplicated converters to delete at the end held in the original converter

Private Member Functions

void initMessaging () const
 Initialize our message level and MessageSvc.

Private Attributes

Analysis::JetTagInfoCnv_tlp3 m_TPConverter
Analysis::JetTagInfoCnv_tlp2 m_TPConverter_p2
Analysis::JetTagInfoCnv_tlp1 m_TPConverter_p1
std::string m_nm
 Message source name.
boost::thread_specific_ptr< MsgStream > m_msg_tls
 MsgStream instance (a std::cout like with print-out levels)
std::atomic< IMessageSvc * > m_imsg { nullptr }
 MessageSvc pointer.
std::atomic< MSG::Level > m_lvl { MSG::NIL }
 Current logging level.
std::atomic_flag m_initialized ATLAS_THREAD_SAFE = ATOMIC_FLAG_INIT
 Messaging initialized (initMessaging)

Friends

class CnvFactory< JetTagInfoCnv >

Detailed Description

Definition at line 25 of file JetTagInfoCnv.h.

Member Typedef Documentation

◆ BaseType

◆ CallMutex

typedef std::mutex AthenaPoolConverter::CallMutex
protectedinherited

Definition at line 132 of file AthenaPoolConverter.h.

◆ ClassMap

typedef std::map<std::string, RootType> AthenaPoolConverter::ClassMap
protectedinherited

Definition at line 120 of file AthenaPoolConverter.h.

◆ ClassMapIt

typedef ClassMap::const_iterator AthenaPoolConverter::ClassMapIt
protectedinherited

Definition at line 121 of file AthenaPoolConverter.h.

◆ extCnvMap_t

typedef std::map<unsigned, AthenaConverterTLPExtension*> AthenaConverterTLPExtension::extCnvMap_t
protectedinherited

Definition at line 133 of file AthenaConverterTLPExtension.h.

◆ extCnvMapMap_t

Definition at line 138 of file AthenaConverterTLPExtension.h.

Constructor & Destructor Documentation

◆ JetTagInfoCnv()

JetTagInfoCnv::JetTagInfoCnv ( ISvcLocator * svcloc)

Init our base class.

Definition at line 23 of file JetTagInfoCnv.cxx.

24 : JetTagInfoCnvBase (loc)
25{
26}
T_AthenaPoolExtendingCnv< JetTagInfo, Analysis::JetTagInfo_tlp3 > JetTagInfoCnvBase
The Athena Pool Converter for TagInfo guys.

Member Function Documentation

◆ addTrack()

void Converter::addTrack ( TIDA::Track * t)
inlineinherited

Definition at line 45 of file Converter.h.

45 {
46 m_tracks.push_back(t);
47 }
std::vector< TIDA::Track * > m_tracks
Definition Converter.h:321

◆ baseAthenaPoolCnv()

virtual BaseType * T_AthenaPoolExtendingCnv< JetTagInfo, Analysis::JetTagInfo_tlp3 >::baseAthenaPoolCnv ( )
inlineprotectedvirtualinherited

return the original AthenaPool converter this one was cloned from if not cloned this returns self if not registered this returns NULL

Definition at line 58 of file T_AthenaPoolExtendingCnv.h.

◆ classID()

template<class TRANS, class PERS>
const CLID & T_AthenaPoolCustCnv< TRANS, PERS >::classID ( )
staticinherited
Returns
class ID.

◆ cleanUp()

template<class TRANS, class PERS>
virtual StatusCode T_AthenaPoolCustomCnvWithKey< TRANS, PERS >::cleanUp ( const std::string & output)
overrideprotectedvirtualinherited

Callback from the CleanupSvc to delete persistent object in the local list.

Reimplemented from AthenaPoolConverter.

◆ clear()

void Converter::clear ( )
inlineinherited

Definition at line 53 of file Converter.h.

53{m_tracks.clear();}

◆ clone()

AthenaPoolCnvTPExtension * JetTagInfoCnv::clone ( void )
inlineprotectedvirtual

Clone this Athena Converter.

Returns the cloned instance

Reimplemented from AthenaConverterTLPExtension.

Definition at line 39 of file JetTagInfoCnv.h.

40 {
41 return new JetTagInfoCnv(0);
42 }
JetTagInfoCnv(ISvcLocator *svcloc)
Init our base class.

◆ compareClassGuid()

template<class TRANS, class PERS>
virtual bool T_AthenaPoolCustCnv< TRANS, PERS >::compareClassGuid ( const Guid & clid) const
protectedvirtualinherited

Compare POOL class GUID with the one of the object being read.

Parameters
clid[IN] GUID to compare
Returns
true if the type of the object about to be read matches the GUID

◆ createObj()

StatusCode AthenaPoolConverter::createObj ( IOpaqueAddress * pAddr,
DataObject *& pObj )
overridevirtualinherited

Create a transient object from a POOL persistent representation.

Parameters
pAddr[IN] IOpaqueAddress of POOL persistent representation.
pObj[OUT] pointer to the transient object.

Reimplemented in T_AthenaPoolCoolMultChanCnv< COLL_T, ELEM_T, ELEM_P >, T_AthenaPoolCoolMultChanCnv< AlignableTransformContainer, AlignableTransform_TRANS, AlignableTransform_PERS >, T_AthenaPoolCoolMultChanCnv< LArAutoCorrComplete, LArAutoCorrTransType, LArAutoCorrPersType >, T_AthenaPoolCoolMultChanCnv< LArAutoCorrMC, LArAutoCorrTransType, LArAutoCorrPersType >, T_AthenaPoolCoolMultChanCnv< LArCaliWaveContainer, LArCaliWaveTransType, LArCaliWavePersType >, T_AthenaPoolCoolMultChanCnv< LArDSPThresholdsComplete, LArDSPThrTransType, LArDSPThrPersType >, T_AthenaPoolCoolMultChanCnv< LArHVScaleCorrComplete, LArConditionsSubset< LArSingleFloatP >, LArSingleFloatSubset_p1 >, T_AthenaPoolCoolMultChanCnv< LArOFCBinComplete, LArOFCBinTransType, LArOFCBinPersType >, T_AthenaPoolCoolMultChanCnv< LArOFCComplete, LArOFCTransType, LArOFCPersType >, T_AthenaPoolCoolMultChanCnv< LArPedestalComplete, LArPedTransType, LArPedPersType >, T_AthenaPoolCoolMultChanCnv< LArPhysWaveContainer, LArPhysWaveTransType, LArPhysWavePersType >, T_AthenaPoolCoolMultChanCnv< LArRampComplete, LArRampTransType, LArRampPersType >, T_AthenaPoolCoolMultChanCnv< LArRampMC, LArRampTransType, LArRampPersType >, T_AthenaPoolCoolMultChanCnv< LArShape32MC, LArShapeTransType, LArShapePersType >, T_AthenaPoolCoolMultChanCnv< LArShapeComplete, LArShapeTransType2, LArShapePersType2 >, and T_AthenaPoolCoolMultChanCnv< TransientClass, LArConditionsSubset< LArSingleFloatP >, LArSingleFloatSubset_p1 >.

Definition at line 62 of file AthenaPoolConverter.cxx.

62 {
63 TokenAddress* tokAddr = dynamic_cast<TokenAddress*>(pAddr);
64
65 bool ownTokAddr = false;
66 if (tokAddr == nullptr || tokAddr->getToken() == nullptr) {
67 ownTokAddr = true;
68 auto token = std::make_unique<Token>();
69 token->fromString(*(pAddr->par()));
70 GenericAddress* genAddr = dynamic_cast<GenericAddress*>(pAddr);
71 if (not genAddr){
72 ATH_MSG_ERROR("Dynamic cast failed in AthenaPoolConverter::createObj");
73 //clean up
74 return StatusCode::FAILURE;
75 }
76 tokAddr = new TokenAddress(*genAddr, std::move(token));
77 }
78 if( tokAddr->ipar()[0] > 0 and tokAddr->getToken()->auxString().empty() ) {
79 char text[32];
80 const std::string contextStr = std::format("[CTXT={:08X}]", static_cast<int>(*(pAddr->ipar())));
81 std::strncpy(text, contextStr.c_str(), sizeof(text) - 1);
82 text[sizeof(text) - 1] = '\0';
83 tokAddr->getToken()->setAuxString(text);
84 }
85 ATH_MSG_VERBOSE("createObj: " << tokAddr->getToken()->toString() << ", CTX=" << tokAddr->ipar()[0]
86 << ", auxStr=" << tokAddr->getToken()->auxString() );
87 std::lock_guard<CallMutex> lock(m_conv_mut);
88 m_i_poolToken = tokAddr->getToken();
89 try {
90 std::string key = pAddr->par()[1];
91 if (!PoolToDataObject(pObj, tokAddr->getToken(), key).isSuccess()) {
92 ATH_MSG_ERROR("createObj PoolToDataObject() failed, Token = " << (tokAddr->getToken() ? tokAddr->getToken()->toString() : "NULL"));
93 pObj = nullptr;
94 }
95 } catch (std::exception& e) {
96 ATH_MSG_ERROR("createObj - caught exception: " << e.what());
97 pObj = nullptr;
98 }
99 if (pObj == nullptr) {
100 ATH_MSG_ERROR("createObj failed to get DataObject, Token = " << (tokAddr->getToken() ? tokAddr->getToken()->toString() : "NULL"));
101 }
102 if (ownTokAddr) {
103 delete tokAddr; tokAddr = nullptr;
104 }
105 m_i_poolToken = nullptr;
106 if (pObj == nullptr) {
107 return StatusCode::FAILURE;
108 }
109 return StatusCode::SUCCESS;
110}
#define ATH_MSG_ERROR(x)
#define ATH_MSG_VERBOSE(x)
virtual StatusCode PoolToDataObject(DataObject *&pObj, const Token *token, const std::string &key)=0
Read an object from POOL.
Token * getToken()
const std::string & auxString() const
Access auxiliary string.
Definition Token.h:91
Token & setAuxString(const std::string &auxString)
Set auxiliary string.
Definition Token.h:93
virtual const std::string toString() const
Retrieve the string representation of the token.
Definition Token.cxx:134

◆ createPersistent() [1/2]

template<class TRANS, class PERS>
virtual PERS * T_AthenaPoolCustomCnv< TRANS, PERS >::createPersistent ( TRANS * obj)
protectedpure virtualinherited

Implemented in AFP_SiDigiCollectionCnv, AFP_SIDLocRecoEvCollectionCnv, AFP_SIDSimHitCollectionCnv, AFP_TDDigiCollectionCnv, AFP_TDLocRecoEvCollectionCnv, AFP_TDSimHitCollectionCnv, ALFA_CLinkEventCnv, ALFA_DigitCollectionCnv, ALFA_GloRecEvCollectionCnv, ALFA_HitCollectionCnv, ALFA_LocRecCorrEvCollectionCnv, ALFA_LocRecCorrODEvCollectionCnv, ALFA_LocRecEvCollectionCnv, ALFA_LocRecODEvCollectionCnv, ALFA_ODDigitCollectionCnv, ALFA_ODHitCollectionCnv, ALFA_RawDataContainerCnv, ALFA_RawDataContainerCnv_charge, AthExDecayCnv, AthExElephantinoCnv, AthExFatObjectCnv, BCM_RDO_ContainerCnv, CaloCalibrationHitContainerCnv, CaloRingsContainerCnv, CaloTopoTowerContainerCnv, CaloTowerContainerCnv, ChamberT0sCnv, ClusterSplitProbabilityContainerCnv, CMMCPHitsCollectionCnv, CMMEtSumsCollectionCnv, CMMJetHitsCollectionCnv, CMMRoICnv, CMXCPHitsCollectionCnv, CMXCPTobCollectionCnv, CMXEtSumsCollectionCnv, CMXJetHitsCollectionCnv, CMXJetTobCollectionCnv, CMXRoICnv, CombinedMuonFeatureCnv, CombinedMuonFeatureContainerCnv, CPMHitsCollectionCnv, CPMRoICollectionCnv, CPMTobRoICollectionCnv, CPMTowerCollectionCnv, CscPrepDataContainerCnv, CscSimDataCollectionCnv, CSCSimHitCollectionCnv, CscStripPrepDataContainerCnv, CTP_DecisionCnv, CTP_RDOCnv, DataHeaderCnv, DetailedTrackTruthCollectionCnv, eflowObjectContainerCnv, egammaContainerCnv, egDetailContainerCnv, ElectronContainerCnv, ElectronMuonTopoInfoContainerCnv, EventBookkeeperCnv, EventBookkeeperCollectionCnv, EventInfoCnv, EventShapeStoreCnv, GenericMuonSimHitCollectionCnv, HGTD_ALTIROC_RDO_ContainerCnv, HGTD_ClusterContainerCnv, HGTD_RDO_ContainerCnv, HLTResultCnv, IDCInDetBSErrContainerCnv, INav4MomAssocsCnv, INav4MomLinkContainerCnv, InDetBSErrContainerCnv, InDetLowBetaCandidateCnv, InDetLowBetaContainerCnv, InDetSimDataCollectionCnv, IParticleLinkContainerCnv, IsoMuonFeatureCnv, IsoMuonFeatureContainerCnv, JEMEtSumsCollectionCnv, JEMHitsCollectionCnv, JEMRoICollectionCnv, JEMTobRoICollectionCnv, JetCollectionCnv, JetElementCollectionCnv, LArDigitContainerCnv, LArFebErrorSummaryCnv, LArHitContainerCnv, LArHitFloatContainerCnv, LArLATOMEHeaderContainerCnv, LArNoisyROSummaryCnv, LArPedestalMCCnv, LArRawEventContainerCnv< T, P, C >, LArTTL1ContainerCnv, LUCID_DigitContainerCnv, LUCID_RawDataContainerCnv, LUCID_SimHitCollectionCnv, LumiBlockCollectionCnv, LVL1_ROICnv, Lvl1ResultCnv, McEventCollectionCnv, MdtPrepDataContainerCnv, MDTSimHitCollectionCnv, MissingEtCaloCnv, MissingETCnv, MissingETCompositionCnv, MissingEtTruthCnv, MM_RawDataContainerCnv, MMPrepDataContainerCnv, MMSimHitCollectionCnv, MuCTPI_RDOCnv, MuCTPIL1TopoCnv, MuonCaloEnergyContainerCnv, MuonContainerCnv, MuonFeatureCnv, MuonFeatureContainerCnv, MuonFeatureDetailsCnv, MuonFeatureDetailsContainerCnv, MuonRdoContainerTPCnv< T, P, CONV >, MuonSimDataCollectionCnv, MuonSpShowerContainerCnv, NSW_PadTriggerDataContainerCnv, NSW_TrigRawDataContainerCnv, PhotonContainerCnv, PixelClusterContainerCnv, PixelGangedClusterAmbiguitiesCnv, PixelRDO_ContainerCnv, PRD_MultiTruthCollectionCnv, RecoTimingObjCnv, RingerRingsCnv, RingerRingsContainerCnv, RODHeaderCollectionCnv, RoIBResultCnv, RpcByteStreamErrorContainerCnv, RpcCoinDataContainerCnv, RpcPrepDataContainerCnv, RpcSectorLogicContainerCnv, RPCSimHitCollectionCnv, SCT_ClusterContainerCnv, SCT_FlaggedCondDataCnv, SCT_RDO_ContainerCnv, SegmentCollectionCnv, SiHitCollectionCnv, SimulationHitCollectionCnv, SkimDecisionCnv, SkimDecisionCollectionCnv, STGC_RawDataContainerCnv, sTgcPrepDataContainerCnv, sTGCSimHitCollectionCnv, T_AthenaPoolExtendingCnv< TRANS, PERS >, T_AthenaPoolLegacyCnv< TRANS, PERS, LEGACY >, T_AthenaPoolLegacyCnv< TRANS, PERS, LEGACY >::LegacyCnv, T_AthenaPoolViewVectorCnv< DV >, TauDetailsContainerCnv, TauJetContainerCnv, TBADCRawContCnv, TBBPCContCnv, TBEventInfoCnv, TBLArDigitContainerCnv, TBMWPCContCnv, TBPhaseCnv, TBScintillatorContCnv, TBTailCatcherCnv, TBTDCCnv, TBTDCRawContCnv, TBTrackCnv, TBTrackInfoCnv, TBTriggerPatternUnitCnv, TgcCoinDataContainerCnv, TgcPrepDataContainerCnv, TGCSimHitCollectionCnv, TileBeamElemContainerCnv, TileCellContainerCnv, TileCosmicMuonContainerCnv, TileDigitsContainerCnv, TileHitContainerCnv, TileHitVectorCnv, TileL2ContainerCnv, TileMuContainerCnv, TileMuFeatureCnv, TileMuFeatureContainerCnv, TileMuonReceiverContainerCnv, TileRawChannelContainerCnv, TileTrackMuFeatureContainerCnv, TileTTL1ContainerCnv, TrackParticleContainerCnv, TrackParticleTruthCollectionCnv, TrackParticleTruthCollectionContainerCnv, TrackRecordCollectionCnv, TrackTruthCollectionCnv, TrigCaloClusterContainerCnv, TrigCompositeCnv, TrigCompositeContainerCnv, TrigDecisionCnv, TrigEFBjetContainerCnv, TrigEFBphysContainerCnv, TrigElectronContainerCnv, TrigEMClusterCnv, TrigEMClusterContainerCnv, TriggerTowerCollectionCnv, TrigHisto1DCnv, TrigHisto1DContainerCnv, TrigHisto2DCnv, TrigHisto2DContainerCnv, TrigInDetTrackCollectionCnv, TrigInDetTrackTruthMapCnv, TrigL2BjetContainerCnv, TrigL2BphysContainerCnv, TrigMissingETCnv, TrigMissingETContainerCnv, TrigMonConfigCnv, TrigMonConfigCollectionCnv, TrigMonEventCnv, TrigMonEventCollectionCnv, TrigMuonClusterFeatureCnv, TrigMuonClusterFeatureContainerCnv, TrigMuonEFContainerCnv, TrigMuonEFInfoContainerCnv, TrigMuonEFIsolationContainerCnv, TrigOperationalInfoCnv, TrigOperationalInfoCollectionCnv, TrigPassBitsCnv, TrigPassBitsCollectionCnv, TrigPassFlagsCnv, TrigPassFlagsCollectionCnv, TrigPhotonContainerCnv, TrigRNNOutputCnv, TrigRNNOutputContainerCnv, TrigRoiDescriptorCnv, TrigRoiDescriptorCollectionCnv, TrigSpacePointCountsCnv, TrigSpacePointCountsCollectionCnv, TrigT2JetCnv, TrigT2JetContainerCnv, TrigT2MbtsBitsCnv, TrigT2MbtsBitsContainerCnv, TrigTauClusterCnv, TrigTauClusterContainerCnv, TrigTauClusterDetailsCnv, TrigTauClusterDetailsContainerCnv, TrigTauCnv, TrigTauContainerCnv, TrigTauTracksInfoCnv, TrigTauTracksInfoCollectionCnv, TrigTrackCountsCnv, TrigTrackCountsCollectionCnv, TrigTrtHitCountsCnv, TrigTrtHitCountsCollectionCnv, TrigVertexCollectionCnv, TrigVertexCountsCnv, TrigVertexCountsCollectionCnv, TRT_BSErrContainerCnv, TRT_BSIdErrContainerCnv, TRT_DriftCircleContainerCnv, TRT_RDO_ContainerCnv, TRTUncompressedHitCollectionCnv, TruthEtIsolationsContainerCnv, TruthParticleContainerCnv, V0ContainerCnv, VxContainerCnv, ZDC_SimFiberHit_CollectionCnv, ZdcDigitsCollectionCnv, and ZdcRawChannelCollectionCnv.

◆ createPersistent() [2/2]

virtual Analysis::JetTagInfo_tlp3 * T_AthenaPoolExtendingCnv< JetTagInfo, Analysis::JetTagInfo_tlp3 >::createPersistent ( JetTagInfo * )
inlineoverrideprotectedvirtualinherited

no-op

Definition at line 91 of file T_AthenaPoolExtendingCnv.h.

91{ return 0; }

◆ createPersistentWithKey()

template<class TRANS, class PERS>
virtual PERS * T_AthenaPoolCustomCnv< TRANS, PERS >::createPersistentWithKey ( TRANS * obj,
const std::string & key )
overrideprotectedvirtualinherited

method to be implemented by the developer.

It should create the persistent representation of the object, using the default top-level TP converter.

Parameters
obj[IN] transient object
Returns
the created persistent representation (by pointer)

Implements T_AthenaPoolCustomCnvWithKey< TRANS, PERS >.

◆ createRep()

StatusCode AthenaPoolConverter::createRep ( DataObject * pObj,
IOpaqueAddress *& pAddr )
overridevirtualinherited

Create a POOL persistent representation for a transient object.

Parameters
pObj[IN] pointer to the transient object.
pAddr[OUT] IOpaqueAddress of POOL persistent representation.

Reimplemented in T_AthenaPoolCoolMultChanCnv< COLL_T, ELEM_T, ELEM_P >, T_AthenaPoolCoolMultChanCnv< AlignableTransformContainer, AlignableTransform_TRANS, AlignableTransform_PERS >, T_AthenaPoolCoolMultChanCnv< LArAutoCorrComplete, LArAutoCorrTransType, LArAutoCorrPersType >, T_AthenaPoolCoolMultChanCnv< LArAutoCorrMC, LArAutoCorrTransType, LArAutoCorrPersType >, T_AthenaPoolCoolMultChanCnv< LArCaliWaveContainer, LArCaliWaveTransType, LArCaliWavePersType >, T_AthenaPoolCoolMultChanCnv< LArDSPThresholdsComplete, LArDSPThrTransType, LArDSPThrPersType >, T_AthenaPoolCoolMultChanCnv< LArHVScaleCorrComplete, LArConditionsSubset< LArSingleFloatP >, LArSingleFloatSubset_p1 >, T_AthenaPoolCoolMultChanCnv< LArOFCBinComplete, LArOFCBinTransType, LArOFCBinPersType >, T_AthenaPoolCoolMultChanCnv< LArOFCComplete, LArOFCTransType, LArOFCPersType >, T_AthenaPoolCoolMultChanCnv< LArPedestalComplete, LArPedTransType, LArPedPersType >, T_AthenaPoolCoolMultChanCnv< LArPhysWaveContainer, LArPhysWaveTransType, LArPhysWavePersType >, T_AthenaPoolCoolMultChanCnv< LArRampComplete, LArRampTransType, LArRampPersType >, T_AthenaPoolCoolMultChanCnv< LArRampMC, LArRampTransType, LArRampPersType >, T_AthenaPoolCoolMultChanCnv< LArShape32MC, LArShapeTransType, LArShapePersType >, T_AthenaPoolCoolMultChanCnv< LArShapeComplete, LArShapeTransType2, LArShapePersType2 >, and T_AthenaPoolCoolMultChanCnv< TransientClass, LArConditionsSubset< LArSingleFloatP >, LArSingleFloatSubset_p1 >.

Definition at line 112 of file AthenaPoolConverter.cxx.

112 {
113 const SG::DataProxy* proxy = dynamic_cast<SG::DataProxy*>(pObj->registry());
114 if (proxy == nullptr) {
115 ATH_MSG_ERROR("AthenaPoolConverter CreateRep failed to cast DataProxy, key = " << pObj->name());
116 return StatusCode::FAILURE;
117 }
118 try {
119 std::lock_guard<CallMutex> lock(m_conv_mut);
120 if (!DataObjectToPers(pObj, pAddr).isSuccess()) {
121 ATH_MSG_ERROR("CreateRep failed, key = " << pObj->name());
122 return StatusCode::FAILURE;
123 }
124 } catch (std::exception& e) {
125 ATH_MSG_ERROR("createRep - caught exception: " << e.what());
126 return StatusCode::FAILURE;
127 }
128 const CLID clid = proxy->clID();
129 if (pAddr == nullptr) {
130 // Create a IOpaqueAddress for this object.
131 pAddr = new TokenAddress(this->storageType(), clid, "", "", 0, 0);
132 } else {
133 GenericAddress* gAddr = dynamic_cast<GenericAddress*>(pAddr);
134 if (gAddr != nullptr) {
135 gAddr->setSvcType(this->storageType());
136 }
137 }
138 return StatusCode::SUCCESS;
139}
uint32_t CLID
The Class ID type.
virtual StatusCode DataObjectToPers(DataObject *pObj, IOpaqueAddress *&pAddr)=0
Convert an object into Persistent.

◆ createTransient()

virtual JetTagInfo * T_AthenaPoolExtendingCnv< JetTagInfo, Analysis::JetTagInfo_tlp3 >::createTransient ( )
inlineoverrideprotectedvirtualinherited

Implements T_AthenaPoolCustomCnv< TRANS, PERS >.

Definition at line 92 of file T_AthenaPoolExtendingCnv.h.

92{ return 0; }

◆ createTransientWithKey()

template<class TRANS, class PERS>
virtual TRANS * T_AthenaPoolCustomCnv< TRANS, PERS >::createTransientWithKey ( const std::string & key)
overrideprotectedvirtualinherited

method to be implemented by the developer.

It has to find out the type of the persistent object to be read (by comparing GUIDs), read it using poolReadObject<P>(), call TLP converter to create a transient representation and return it. if the version 1 of poolReadObject is used, the persistent object HAS TO BE DELETED manually.

Implements T_AthenaPoolCustomCnvWithKey< TRANS, PERS >.

◆ DataObjectToPers()

template<class TRANS, class PERS>
virtual StatusCode T_AthenaPoolCustomCnvWithKey< TRANS, PERS >::DataObjectToPers ( DataObject * pObj,
IOpaqueAddress *& pAddr )
overrideprotectedvirtualinherited

Convert an object into Persistent.

Parameters
pObj[IN] pointer to the transient object.
key[IN] StoreGate key (string) - placement hint to generate POOL container name

Reimplemented from T_AthenaPoolCustCnv< TRANS, PERS >.

◆ DataObjectToPool()

template<class TRANS, class PERS>
virtual StatusCode T_AthenaPoolCustomCnvWithKey< TRANS, PERS >::DataObjectToPool ( IOpaqueAddress * pAddr,
DataObject * pObj )
overrideprotectedvirtualinherited

Write an object into POOL.

Parameters
pObj[IN] pointer to the transient object.
key[IN] StoreGate key (string) - placement hint to generate POOL container name

Reimplemented from T_AthenaPoolCustCnv< TRANS, PERS >.

Reimplemented in DataHeaderCnv, and T_AthenaPoolLegacyCnv< TRANS, PERS, LEGACY >.

◆ deletePersistentObjects()

void AthenaConverterTLPExtension::deletePersistentObjects ( )
virtualinherited

Delete persistent objects held by attached extending converters (used mainly in case of abort)

Definition at line 148 of file AthenaConverterTLPExtension.cxx.

149{
150 for( extCnvMap_t::const_iterator cnv = m_extendingConverters.begin();
151 cnv != m_extendingConverters.end(); ++cnv ) {
152 cnv->second->deletePersistentObjects();
153 }
154 for( size_t c = 0; c < m_clonedExtendingCnvs.size(); c++ )
156
158 // Can not do that - sometimes the converter is an automatic variable that is gone already
159 //if( m_TLCnvForReading ) m_TLCnvForReading->deleteTLPersObject();
160}
std::vector< AthenaConverterTLPExtension * > m_clonedExtendingCnvs
list of duplicated converters to delete at the end held in the original converter
virtual TopLevelTPCnvBase * getTopLevelTPCnv()=0
returns the main top-level TP converter
extCnvMap_t m_extendingConverters
map of Athena converters extending this one
virtual void deletePersistentObjects()
Delete persistent objects held by attached extending converters (used mainly in case of abort)
virtual void deleteTLPersObject()=0
Delete the persistent object owned by the converter.

◆ detStore()

const ServiceHandle< StoreGateSvc > & AthenaPoolConverter::detStore ( ) const
inlineinherited

Handle to DetectorStore.

Definition at line 69 of file AthenaPoolConverter.h.

69{ return m_detStore; }
ServiceHandle< StoreGateSvc > m_detStore

◆ fillRepRefs()

StatusCode AthenaPoolConverter::fillRepRefs ( IOpaqueAddress * pAddr,
DataObject * pObj )
overridevirtualinherited

Create a POOL persistent representation for a transient object.

Parameters
pAddr[IN] IOpaqueAddress of POOL persistent representation.
pObj[IN] pointer to the transient object.

Reimplemented in T_AthenaPoolCoolMultChanCnv< COLL_T, ELEM_T, ELEM_P >, T_AthenaPoolCoolMultChanCnv< AlignableTransformContainer, AlignableTransform_TRANS, AlignableTransform_PERS >, T_AthenaPoolCoolMultChanCnv< LArAutoCorrComplete, LArAutoCorrTransType, LArAutoCorrPersType >, T_AthenaPoolCoolMultChanCnv< LArAutoCorrMC, LArAutoCorrTransType, LArAutoCorrPersType >, T_AthenaPoolCoolMultChanCnv< LArCaliWaveContainer, LArCaliWaveTransType, LArCaliWavePersType >, T_AthenaPoolCoolMultChanCnv< LArDSPThresholdsComplete, LArDSPThrTransType, LArDSPThrPersType >, T_AthenaPoolCoolMultChanCnv< LArHVScaleCorrComplete, LArConditionsSubset< LArSingleFloatP >, LArSingleFloatSubset_p1 >, T_AthenaPoolCoolMultChanCnv< LArOFCBinComplete, LArOFCBinTransType, LArOFCBinPersType >, T_AthenaPoolCoolMultChanCnv< LArOFCComplete, LArOFCTransType, LArOFCPersType >, T_AthenaPoolCoolMultChanCnv< LArPedestalComplete, LArPedTransType, LArPedPersType >, T_AthenaPoolCoolMultChanCnv< LArPhysWaveContainer, LArPhysWaveTransType, LArPhysWavePersType >, T_AthenaPoolCoolMultChanCnv< LArRampComplete, LArRampTransType, LArRampPersType >, T_AthenaPoolCoolMultChanCnv< LArRampMC, LArRampTransType, LArRampPersType >, T_AthenaPoolCoolMultChanCnv< LArShape32MC, LArShapeTransType, LArShapePersType >, T_AthenaPoolCoolMultChanCnv< LArShapeComplete, LArShapeTransType2, LArShapePersType2 >, and T_AthenaPoolCoolMultChanCnv< TransientClass, LArConditionsSubset< LArSingleFloatP >, LArSingleFloatSubset_p1 >.

Definition at line 141 of file AthenaPoolConverter.cxx.

141 {
142 std::lock_guard<CallMutex> lock(m_conv_mut);
143 try {
144 if (!DataObjectToPool(pAddr, pObj).isSuccess()) {
145 ATH_MSG_ERROR("FillRepRefs failed, key = " << pObj->name());
146 return StatusCode::FAILURE;
147 }
148 } catch (std::exception& e) {
149 ATH_MSG_ERROR("fillRepRefs - caught exception: " << e.what());
150 return StatusCode::FAILURE;
151 }
152 return StatusCode::SUCCESS;
153}
virtual StatusCode DataObjectToPool(IOpaqueAddress *pAddr, DataObject *pObj)=0
Write an object into POOL.

◆ finalize()

StatusCode AthenaPoolConverter::finalize ( )
overridevirtualinherited

Definition at line 50 of file AthenaPoolConverter.cxx.

50 {
51 // Release AthenaPoolCnvSvc
52 if (!m_athenaPoolCnvSvc.release().isSuccess()) {
53 ATH_MSG_WARNING("Cannot release AthenaPoolCnvSvc.");
54 }
55 return(::Converter::finalize());
56}
#define ATH_MSG_WARNING(x)
ServiceHandle< IAthenaPoolCnvSvc > m_athenaPoolCnvSvc

◆ getDataObject()

const DataObject * AthenaPoolConverter::getDataObject ( ) const
protectedvirtualinherited
Returns
data object from the converter.

Definition at line 272 of file AthenaPoolConverter.cxx.

272 {
273 return(m_dataObject);
274}
const DataObject * m_dataObject

◆ getTopLevelTPCnv()

AthenaPoolTopLevelTPCnvBase * JetTagInfoCnv::getTopLevelTPCnv ( void )
inlineprotectedvirtual

Return the top level TP converter (which is always used for writing)

Implements T_AthenaPoolExtendingCnv< JetTagInfo, Analysis::JetTagInfo_tlp3 >.

Definition at line 35 of file JetTagInfoCnv.h.

36 {
37 return &m_TPConverter;
38 }
Analysis::JetTagInfoCnv_tlp3 m_TPConverter

◆ getTopLevelTPCnvForReading()

TopLevelTPCnvBase * AthenaConverterTLPExtension::getTopLevelTPCnvForReading ( )
inlineinherited

returns the current top-level TP converter.

This converter may be different from the main one in case of schema evolution

Definition at line 100 of file AthenaConverterTLPExtension.h.

100{ return m_TLCnvForReading; }
TopLevelTPCnvBase * m_TLCnvForReading
additional Top Level TP converter used only for reading tells which converter is used in case of read...

◆ getTPCnvID()

unsigned short AthenaConverterTLPExtension::getTPCnvID ( )
inherited

Returns the ID of the main top-level TP converter.

Definition at line 23 of file AthenaConverterTLPExtension.cxx.

23 {
25}
virtual unsigned short getConverterID()=0

◆ initialize()

StatusCode JetTagInfoCnv::initialize ( void )
protectedvirtual

Make sure to pass on the init!

Reimplemented from T_AthenaPoolCustCnv< TRANS, PERS >.

Definition at line 29 of file JetTagInfoCnv.cxx.

◆ initMessaging()

void AthMessaging::initMessaging ( ) const
privateinherited

Initialize our message level and MessageSvc.

This method should only be called once.

Definition at line 39 of file AthMessaging.cxx.

40{
42 // If user did not set an explicit level, set a default
43 if (m_lvl == MSG::NIL) {
44 m_lvl = m_imsg ?
45 static_cast<MSG::Level>( m_imsg.load()->outputLevel(m_nm) ) :
46 MSG::INFO;
47 }
48}
std::string m_nm
Message source name.
std::atomic< IMessageSvc * > m_imsg
MessageSvc pointer.
std::atomic< MSG::Level > m_lvl
Current logging level.
IMessageSvc * getMessageSvc(bool quiet=false)

◆ ipCorr()

void Converter::ipCorr ( double d0,
double z0,
double & d0c,
double & z0c,
double phi0,
double eta,
double pt )
inlineprotectedinherited

Definition at line 257 of file Converter.h.

257 {
258
259 double sn = sin(phi0);
260 double cs = cos(phi0);
261 double sd0 = (d0 != 0 ? d0/fabs(d0) : 1);
262 double spt = (pt != 0 ? pt/fabs(pt) : 1);
263
264 if (fabs(pt) >= 1*CLHEP::TeV) {
265
266 d0c = d0 + m_beamX*sn - m_beamY*cs;
267
268 } else {
269
270 double rc = fabs(pt)*15.0/(9.0*1.042);
271
272 double xc = (fabs(d0)-spt*sd0*rc)*cos(phi0+M_PI/2*sd0) - m_beamX;
273 double yc = (fabs(d0)-spt*sd0*rc)*sin(phi0+M_PI/2*sd0) - m_beamY;
274
275 double newphi;
276 double xd01,yd01,xd02,yd02;
277
278 if (xc == 0) {
279 xd01 = 0; yd01 = rc+yc;
280 xd02 = 0; yd02 = -rc+yc;
281 } else {
282 xd01 = xc+yc/xc*yc+sqrt(pow((xc+yc/xc*yc),2)-xc*xc-yc*yc+rc*rc); yd01 = yc/xc*xd01;
283 xd02 = xc+yc/xc*yc-sqrt(pow((xc+yc/xc*yc),2)-xc*xc-yc*yc+rc*rc); yd02 = yc/xc*xd02;
284 }
285
286 double r1 = sqrt(xd01*xd01+yd01*yd01);
287 double r2 = sqrt(xd02*xd02+yd02*yd02);
288
289 double phiV;
290
291 if (r1 < r2)
292 phiV = atan2(yd01,xd01);
293 else
294 phiV = atan2(yd02,xd02);
295
296 double phi1 = phiCorr(phiV+M_PI/2);
297 double phi2 = phiCorr(phiV-M_PI/2);
298
299 if (fabs(phiCorr(phi1-phi0))<=fabs(phiCorr(phi2-phi0)))
300 newphi = phi1;
301 else
302 newphi = phi2;
303
304 d0c = fabs(sqrt(xc*xc+yc*yc)-rc)*sin(phiV-newphi);
305
306 double theta=2*atan2(exp(-eta),1);
307 double theta_save=theta;
308 theta = theta - (1+spt)/2*M_PI;
309 if (theta>0) theta = theta_save;
310
311 double deltaz0= -spt*rc/tan(theta)*phiCorr(phiCorr(newphi)-phiCorr(phi0));
312 z0c = z0 + deltaz0;
313
314 }
315 }
#define M_PI
Scalar eta() const
pseudorapidity method
Scalar theta() const
theta method
static Double_t rc
constexpr int pow(int base, int exp) noexcept
double m_beamX
Definition Converter.h:320
double phiCorr(double phi)
Definition Converter.h:248
double m_beamY
Definition Converter.h:320

◆ keepPoolObj()

template<class TRANS, class PERS>
void T_AthenaPoolCustomCnvWithKey< TRANS, PERS >::keepPoolObj ( PERS * obj,
const std::string & output )
protectedinherited

Remember the POOL object to be written out (will be deleted after commit)

Parameters
obj[IN] persistent object

◆ msg() [1/2]

MsgStream & AthMessaging::msg ( ) const
inlineinherited

The standard message stream.

Returns a reference to the default message stream May not be invoked before sysInitialize() has been invoked.

Definition at line 163 of file AthMessaging.h.

164{
165 MsgStream* ms = m_msg_tls.get();
166 if (!ms) {
167 if (!m_initialized.test_and_set()) initMessaging();
168 ms = new MsgStream(m_imsg,m_nm);
169 m_msg_tls.reset( ms );
170 }
171
172 ms->setLevel (m_lvl);
173 return *ms;
174}
boost::thread_specific_ptr< MsgStream > m_msg_tls
MsgStream instance (a std::cout like with print-out levels)
void initMessaging() const
Initialize our message level and MessageSvc.

◆ msg() [2/2]

MsgStream & AthMessaging::msg ( const MSG::Level lvl) const
inlineinherited

The standard message stream.

Returns a reference to the default message stream May not be invoked before sysInitialize() has been invoked.

Definition at line 178 of file AthMessaging.h.

179{ return msg() << lvl; }
MsgStream & msg() const
The standard message stream.

◆ msgLvl()

bool AthMessaging::msgLvl ( const MSG::Level lvl) const
inlineinherited

Test the output level.

Parameters
lvlThe message level to test against
Returns
boolean Indicating if messages at given level will be printed
Return values
trueMessages at level "lvl" will be printed

Definition at line 151 of file AthMessaging.h.

152{
153 if (m_lvl <= lvl) {
154 msg() << lvl;
155 return true;
156 } else {
157 return false;
158 }
159}

◆ name()

virtual const std::string T_AthenaPoolExtendingCnv< JetTagInfo, Analysis::JetTagInfo_tlp3 >::name ( ) const
overrideprotectedvirtualinherited

Get the name of this converter (anything that identifies it).

Used for logging

Returns
Name of this converter

Reimplemented from AthenaConverterTLPExtension.

◆ needsCloning()

virtual bool T_AthenaPoolExtendingCnv< JetTagInfo, Analysis::JetTagInfo_tlp3 >::needsCloning ( ) const
inlineoverrideprotectedvirtualinherited

tells if this converter needs to be cloned (true after the converter has been registered once already)

Reimplemented from AthenaConverterTLPExtension.

Definition at line 65 of file T_AthenaPoolExtendingCnv.h.

65{ return m_originalExtendingCnv != 0; }

◆ objectToPool()

template<class TRANS, class PERS>
template<class P>
StatusCode T_AthenaPoolCustCnv< TRANS, PERS >::objectToPool ( P * pObj,
std::unique_ptr< Token > & token,
const std::string & key,
const std::string & output )
protectedinherited

Write an object into POOL returning its token.

Parameters
pObj[IN] pointer to the object to be written.
token[OUT] POOL token of the persistent representation.
key[IN] StoreGate key (string) - placement hint to generate POOL container name

◆ persToTrans()

template<class TRANS, class PERS>
virtual StatusCode T_AthenaPoolCustomCnvWithKey< TRANS, PERS >::persToTrans ( TRANS *& ,
PERS *  )
inlineoverrideprotectedvirtualinherited

obsolete

Implements T_AthenaPoolCustCnv< TRANS, PERS >.

Definition at line 96 of file T_AthenaPoolCustomCnv.h.

96{ return(StatusCode::FAILURE); }
This templated class extends T_AthenaPoolCustCnv to provide management of the persistent objects crea...

◆ phiCorr()

double Converter::phiCorr ( double phi)
inlineprotectedinherited

Definition at line 248 of file Converter.h.

248 {
249
250 if (phi < -TMath::Pi()) phi += 2*TMath::Pi();
251 if (phi > TMath::Pi()) phi -= 2*TMath::Pi();
252
253 return phi;
254 }
Scalar phi() const
phi method

◆ poolReadObject() [1/2]

P * T_AthenaPoolExtendingCnv< JetTagInfo, Analysis::JetTagInfo_tlp3 >::poolReadObject ( )
protectedinherited

Read object of type P.

This is an exception-throwing version of poolToObject() plus reading of all extending objects. Version 1 - (see createTransient() above)

Returns
object read from POOL (by pointer) deprecated - use poolReadObject(TLPCnv)

◆ poolReadObject() [2/2]

void T_AthenaPoolExtendingCnv< JetTagInfo, Analysis::JetTagInfo_tlp3 >::poolReadObject ( TopLevelTPCnvBase & tlp_converter)
protectedinherited

Read object of type P (plus all extending objects) using the indicated top-level TP converter.

Version 2 - (see createTransient() above) NOTE: the TLP converter will delete the persistent object after createTransient()

Parameters
tlp_converter[IN] top-level TP converter to be used when reading

◆ PoolToDataObject()

template<class TRANS, class PERS>
virtual StatusCode T_AthenaPoolCustomCnvWithKey< TRANS, PERS >::PoolToDataObject ( DataObject *& pObj,
const Token * token,
const std::string & key )
overrideprotectedvirtualinherited

Read an object from POOL.

Parameters
pObj[OUT] pointer to the transient object.
token[IN] POOL token of the persistent representation.
key[IN] SG key of the object being read.

Reimplemented from T_AthenaPoolCustCnv< TRANS, PERS >.

◆ poolToObject()

template<class TRANS, class PERS>
template<class P>
StatusCode T_AthenaPoolCustCnv< TRANS, PERS >::poolToObject ( const Token *& token,
P *& pObj )
protectedinherited

Read an object from POOL.

Parameters
token[IN] POOL token of the persistent representation.
pObj[OUT] pointer to the object read.

◆ readExtendingObjects()

void AthenaConverterTLPExtension::readExtendingObjects ( void * baseObj)
virtualinherited

Read all component persistent objects.

Parameters
baseObj[IN] pointer to the principal persistent object holding the list of tokens for all component persistent objects to read

Definition at line 99 of file AthenaConverterTLPExtension.cxx.

100{
101 // m_TLCnvForReading may be 0 if reading pre-TP object
102 if( m_TLCnvForReading ) {
103 TPCnvTokenList_p1 *tokens = m_TLCnvForReading->getTokenListVarFrom( baseObj );
104 if( tokens && tokens->size() ) {
105 // find which extending converter "set" to use
106 extCnvMap_t *extendingConverters;
108 // use the newest TP converters
109 extendingConverters = &m_extendingConverters;
110 } else {
111 extCnvMapMap_t::const_iterator extCnvMapIter = m_extCnvMapMap.find(m_TLCnvForReading);
112 if( extCnvMapIter == m_extCnvMapMap.end() ) {
113 throw std::runtime_error("Extending TP converter not available");
114 }
115 extendingConverters = extCnvMapIter->second;
116 }
117 // load the remaining "pieces" of this object
118 for( TPCnvTokenList_p1::const_iterator it = tokens->begin(); it != tokens->end(); ++it ) {
119 if( it->token().size() < 36 ) {
120 ostringstream err;
121 err << "Corrupted Token in the list of extensions. Token='" << it->token() << "'"
122 << " CnvID=" << it->converterID() << ", Token list size=" << tokens->size();
123 throw std::runtime_error(err.str());
124 }
125 extCnvMap_t::const_iterator cnv = extendingConverters->find( it->converterID() );
126 if( cnv == extendingConverters->end() ) {
127 ostringstream err;
128 err << "Extending TP converter not loaded! "
129 << "missing ExtCnvID=" << it->converterID()
130 << " corresponding POOL token: " << it->token();
131 throw std::runtime_error(err.str());
132 }
133// std::cout << "--->>--- readExtendingObjects: "
134// << " converter ID=" << it->converterID()
135// << " token=" << it->token() << ", AP converter=" << cnv->second << std::endl;
136
137 cnv->second->readObject( it->token() );
138 TopLevelTPCnvBase *extTPCnv = cnv->second->getTopLevelTPCnvForReading();
140 }
141 }
142 }
143}
std::map< unsigned, AthenaConverterTLPExtension * > extCnvMap_t
virtual void addTPConvertersForReadingTo(TopLevelTPCnvBase *dest)
copy all extending converters from this top level converter to "dest" top level converter - for readi...

◆ readObject()

virtual void T_AthenaPoolExtendingCnv< JetTagInfo, Analysis::JetTagInfo_tlp3 >::readObject ( const std::string & )
inlineoverrideprotectedvirtualinherited

Read the extending object.

Parameters
token[IN] Token of the object to read

Reimplemented from AthenaConverterTLPExtension.

Definition at line 49 of file T_AthenaPoolExtendingCnv.h.

49{ this->readObjectFromPool(token); }
This templated class extends T_AthenaPoolCustomCnv to provide additional/chaged functionality for Ath...
virtual void readObjectFromPool(const std::string &token)=0

◆ readObjectFromPool()

void JetTagInfoCnv::readObjectFromPool ( const std::string & obj)
protectedvirtual

Read the persistant bit in.

Fortunately, we don't have to do anything at all for this.

The POOL token which will be used for reading from POOL.

And use the GUID to select what we want

Implements T_AthenaPoolExtendingCnv< JetTagInfo, Analysis::JetTagInfo_tlp3 >.

Definition at line 37 of file JetTagInfoCnv.cxx.

38{
39 static const pool::Guid p1_guid ("977E2E76-4DA6-4A4B-87A8-2E41353DB9F4");
40 static const pool::Guid p2_guid ("50E644C1-E247-41B0-B873-416362824A21");
41 static const pool::Guid p3_guid ("8A57BABD-C361-4796-93CD-E8171EF06BC7");
42
44
45 setToken (token);
46
48
49 if(compareClassGuid (p3_guid)){
51 }
52 else if (compareClassGuid (p2_guid)) {
54 } else if (compareClassGuid (p1_guid)) {
56 } else {
57 throw runtime_error ("Unsupported version of JetTagInfo_tlp1 (unknonw GUID)");
58 }
59}
bool compareClassGuid(const Guid &guid) const
Analysis::JetTagInfoCnv_tlp1 m_TPConverter_p1
Analysis::JetTagInfoCnv_tlp2 m_TPConverter_p2
virtual void setToken(const std::string &token) override

◆ registerExtendingCnv() [1/2]

virtual bool AthenaPoolCnvTPExtension::registerExtendingCnv ( AthenaConverterTLPExtension * cnv)
inlinevirtualinherited

Register extending converter (that is, another converter that will extent this converter) and all his elemental converters.

Parameters
cnv[IN] pointer to extending Athena converter

Reimplemented from AthenaConverterTLPExtension.

Definition at line 19 of file AthenaPoolCnvTPExtension.h.

19 {
21 }
virtual bool registerExtendingCnv(AthenaConverterTLPExtension *cnv)
Register extending converter (that is, another converter that will extent this converter) and all his...

◆ registerExtendingCnv() [2/2]

virtual bool AthenaPoolCnvTPExtension::registerExtendingCnv ( IConverter * cnv)
inlinevirtualinherited

Definition at line 23 of file AthenaPoolCnvTPExtension.h.

23 {
24 AthenaConverterTLPExtension *extending_converter = dynamic_cast<AthenaPoolCnvTPExtension*>(cnv);
25 // if the converter passed is not an extending converter, we can't do anything
26 if( !extending_converter )
27 throw std::runtime_error("Attempt to register extending AthenaPool converter that does not inherit from AthenaPoolCnvTPExtension");
28 return AthenaConverterTLPExtension::registerExtendingCnv( extending_converter );
29 }

◆ repSvcType()

long AthenaPoolConverter::repSvcType ( ) const
overridevirtualinherited

Definition at line 58 of file AthenaPoolConverter.cxx.

58 {
60}
int type() const
Access to full type.
Definition DbType.h:65
static const DbType POOL_StorageType
Definition DbType.h:98

◆ resetTPCnvForReading()

void AthenaConverterTLPExtension::resetTPCnvForReading ( )
inlineinherited

Reset to 0 the TL TP converter for reading.

Prevents the use of the previous TP converter if none was set before reading the next object Called automatically after reading an object.

Definition at line 111 of file AthenaConverterTLPExtension.h.

111{ m_TLCnvForReading = 0; }

◆ selectTracks() [1/3]

void Converter::selectTracks ( const Analysis::MuonContainer * muontracks)
inlineinherited

Definition at line 177 of file Converter.h.

177 {
178
179 static int hpmap[20] = { 0, 1, 2, 7, 8, 9, 3, 4, 5, 6, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19 };
180
181 Analysis::MuonContainer::const_iterator muonitr = muontracks->begin();
182 Analysis::MuonContainer::const_iterator muonend = muontracks->end();
183
184 while(muonitr!=muonend) {
185
186 bool hasInDet = (*muonitr)->hasInDetTrackParticle();
187 const Rec::TrackParticle *trackitr=NULL;
188 if(hasInDet) trackitr=(*muonitr)->inDetTrackParticle();
189 muonitr++;
190 if(!hasInDet) continue;
191
192 const Trk::MeasuredPerigee* measPer = trackitr->measuredPerigee();
193
194 CLHEP::HepVector perigeeParams = measPer->parameters();
195 double pT = measPer->pT();
196 double eta = measPer->eta();
197 double phi = perigeeParams[Trk::phi0];
198 double z0 = perigeeParams[Trk::z0];
199 double d0 = perigeeParams[Trk::d0];
200 //double theta = perigeeParams[Trk::theta];
201
202 double deta = 1;
203 double dphi = 1;
204 double dz0 = 1;
205 double dd0 = 1;
206 double dpT = 1;
207
208 // Check number of hits
209 // NB: a spacepoint is two offline "hits", so a pixel spacepoint is really
210 // 2 "hits" and an offline SCT "hit" is really a 1D cluster, so two intersetcting
211 // stereo clusters making a spacepoint are two "hits"
212 const Trk::TrackSummary *summary = trackitr->trackSummary();
213 int nBlayerHits = 2*summary->get(Trk::numberOfBLayerHits);
215 int nSctHits = summary->get(Trk::numberOfSCTHits);
216 int nStrawHits = summary->get(Trk::numberOfTRTHits);
217 int nTrHits = summary->get(Trk::numberOfTRTHighThresholdHits);
218
219 int nSiHits = nPixelHits + nSctHits;
220
221 const Trk::FitQuality *quality = trackitr->fitQuality();
222 double chi2 = quality->chiSquared();
223 double dof = quality->quality->numberDoF();
224
225 unsigned bitmap = 0;
226
227 for ( int ih=0 ; ih<20 ; ih++ ) {
228 if ( summary->isHit(Trk::DetectorType(ih)) ) bitmap |= ( 1<<hpmap[ih] );
229 }
230
231 // Shift d0 and z0 according to beam position
232 ipCorr(d0, z0, d0, z0, phi, eta, pT);
233
234 // Create and save Track
235 TIDA::Track* t = new TIDA::Track(eta, phi, z0, d0, pT, chi2, dof,
236 deta, dphi, dz0, dd0, dpT,
237 nBlayerHits, nPixelHits, nSctHits, nSiHits,
238 nStrawHits, nTrHits, bitmap, 0,
239 -1) ;
240
241 addTrack(t);
242 }
243
244 }
void addTrack(TIDA::Track *t)
Definition Converter.h:45
void ipCorr(double d0, double z0, double &d0c, double &z0c, double phi0, double eta, double pt)
Definition Converter.h:257
DataModel_detail::const_iterator< DataVector > const_iterator
Definition DataVector.h:838
const_iterator end() const noexcept
Return a const_iterator pointing past the end of the collection.
const_iterator begin() const noexcept
Return a const_iterator pointing at the beginning of the collection.
const Trk::Perigee * measuredPerigee() const
Accessor method for Perigee.
int numberDoF() const
returns the number of degrees of freedom of the overall track or vertex fit as integer
Definition FitQuality.h:60
double chiSquared() const
returns the of the overall track fit
Definition FitQuality.h:56
double eta() const
Access method for pseudorapidity - from momentum.
double pT() const
Access method for transverse momentum.
const FitQuality * fitQuality() const
accessor function for FitQuality.
const TrackSummary * trackSummary() const
accessor function for TrackSummary.
double chi2(TH1 *h0, TH1 *h1)
float nSiHits(const U &p)
float nPixelHits(const U &p)
@ phi0
Definition ParamDefs.h:65
@ d0
Definition ParamDefs.h:63
@ z0
Definition ParamDefs.h:64
DetectorType
enumerates the various detector types currently accessible from the isHit() method.
@ numberOfPixelHits
number of pixel layers on track with absence of hits
@ numberOfBLayerHits
these are the hits in the 0th pixel layer?
@ numberOfTRTHighThresholdHits
total number of TRT hits which pass the high threshold
Perigee MeasuredPerigee

◆ selectTracks() [2/3]

void Converter::selectTracks ( const Rec::TrackParticleContainer * trigtracks)
inlineinherited

Definition at line 111 of file Converter.h.

111 {
112
113 Rec::TrackParticleContainer::const_iterator trackitr = trigtracks->begin();
114 Rec::TrackParticleContainer::const_iterator trackend = trigtracks->end();
115
116 static int hpmap[20] = { 0, 1, 2, 7, 8, 9, 3, 4, 5, 6, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19 };
117
118 while ( trackitr!=trackend ) {
119
120 const Trk::MeasuredPerigee* measPer = (*trackitr)->measuredPerigee();
121
122 CLHEP::HepVector perigeeParams = measPer->parameters();
123 double pT = measPer->pT();
124 double eta = measPer->eta();
125 double phi = perigeeParams[Trk::phi0];
126 double z0 = perigeeParams[Trk::z0];
127 double d0 = perigeeParams[Trk::d0];
128 //double theta = perigeeParams[Trk::theta];
129
130 double deta = 1;
131 double dphi = 1;
132 double dz0 = 1;
133 double dd0 = 1;
134 double dpT = 1;
135
136 // Check number of hits
137 // NB: a spacepoint is two offline "hits", so a pixel spacepoint is really
138 // 2 "hits" and an offline SCT "hit" is really a 1D cluster, so two intersetcting
139 // stereo clusters making a spacepoint are two "hits"
140 const Trk::TrackSummary *summary = (*trackitr)->trackSummary();
141 int nBlayerHits = 2*summary->get(Trk::numberOfBLayerHits);
143 int nSctHits = summary->get(Trk::numberOfSCTHits);
144 int nStrawHits = summary->get(Trk::numberOfTRTHits);
145 int nTrHits = summary->get(Trk::numberOfTRTHighThresholdHits);
146 int nSiHits = nPixelHits + nSctHits;
147 bool expectBL = false; // Not stored for Rec::TrackParticle
148
149 const Trk::FitQuality *quality = (*trackitr)->fitQuality();
150 double chi2 = quality->chiSquared();
151 double dof = quality->numberDoF();
152
153 unsigned bitmap = 0;
154
155 for ( int ih=0 ; ih<20 ; ih++ ) {
156 if ( summary->isHit(Trk::DetectorType(ih)) ) bitmap |= ( 1<<hpmap[ih] );
157 }
158
159 // Shift d0 and z0 according to beam position
160 ipCorr(d0, z0, d0, z0, phi, eta, pT);
161
162 // Create and save Track
163 TIDA::Track* t = new TIDA::Track(eta, phi, z0, d0, pT, chi2, dof,
164 deta, dphi, dz0, dd0, dpT,
165 nBlayerHits, nPixelHits, nSctHits, nSiHits,
166 nStrawHits, nTrHits, bitmap, 0,
167 -1,
168 expectBL) ;
169
170 addTrack(t);
171 trackitr++;
172 }
173
174 }

◆ selectTracks() [3/3]

void Converter::selectTracks ( const TrigInDetTrackCollection * trigtracks)
inlineinherited

Definition at line 56 of file Converter.h.

56 {
57
58 TrigInDetTrackCollection::const_iterator trackitr = trigtracks->begin();
59 TrigInDetTrackCollection::const_iterator trackend = trigtracks->end();
60
61 while ( trackitr!=trackend ) {
62
63 double eta = (*trackitr)->param()->eta();
64 double phi = (*trackitr)->param()->phi0();
65 double z0 = (*trackitr)->param()->z0();
66 double pT = (*trackitr)->param()->pT();
67 double d0 = (*trackitr)->param()->a0();
68 //double theta = 2*atan2(exp(-(*trackitr)->param()->eta()),1);
69
70 double deta = (*trackitr)->param()->eeta();
71 double dphi = (*trackitr)->param()->ephi0();
72 double dz0 = (*trackitr)->param()->ez0();
73 double dpT = (*trackitr)->param()->epT();
74 double dd0 = (*trackitr)->param()->ea0();
75
76 int algoid = (*trackitr)->algorithmId();
77
78 int nBlayerHits = ((*trackitr)->HitPattern() & 0x1);
79 int nPixelHits = 2*(*trackitr)->NPixelSpacePoints(); // NB: for comparison with offline
80 int nSctHits = 2*(*trackitr)->NSCT_SpacePoints(); // a spacepoint is 2 "hits"
81 int nStrawHits = (*trackitr)->NStrawHits();
82 int nTrHits = (*trackitr)->NTRHits();
83
84 int nSiHits = nPixelHits + nSctHits;
85 bool expectBL = false; //not available with TrigInDetTrack
86
87 unsigned hitPattern = (*trackitr)->HitPattern();
88 unsigned multiPattern = 0;
89
90 double chi2 = (*trackitr)->chi2();
91 double dof = 0;
92
93 // Shift d0 and z0 according to beam position
94 ipCorr(d0, z0, d0, z0, phi, eta, pT);
95
96 // Create and save Track
97 TIDA::Track* t = new TIDA::Track(eta, phi, z0, d0, pT, chi2, dof,
98 deta, dphi, dz0, dd0, dpT,
99 nBlayerHits, nPixelHits, nSctHits, nSiHits,
100 nStrawHits, nTrHits, hitPattern, multiPattern,
101 algoid,
102 expectBL ) ;
103
104 addTrack(t);
105 trackitr++;
106 }
107 }

◆ setLevel()

void AthMessaging::setLevel ( MSG::Level lvl)
inherited

Change the current logging level.

Use this rather than msg().setLevel() for proper operation with MT.

Definition at line 28 of file AthMessaging.cxx.

29{
30 m_lvl = lvl;
31}

◆ setPlacement()

virtual Placement T_AthenaPoolCnvBase< TRANS >::setPlacement ( const std::string & key,
const std::string & output )
protectedvirtualinherited

Set POOL placement.

Implements AthenaPoolConverter.

◆ setPlacementForP()

template<class TRANS, class PERS>
template<class P>
Placement T_AthenaPoolCustCnv< TRANS, PERS >::setPlacementForP ( P & p,
const std::string & key,
const std::string & output )
protectedinherited

Set POOL placement for type P.

◆ setPlacementWithType()

Placement AthenaPoolConverter::setPlacementWithType ( const std::string & tname,
const std::string & key,
const std::string & output )
protectedvirtualinherited

Set POOL placement hint for a given type.

Parameters
tname[IN] type name.
key[IN] SG key.

Definition at line 176 of file AthenaPoolConverter.cxx.

176 {
177 Placement placement;
178 // Override streaming parameters from StreamTool if requested.
179 std::string::size_type pos1 = output.find('[');
180 std::string outputConnectionSpec = output.substr(0, pos1);
181 int tech = 0;
182 m_athenaPoolCnvSvc->decodeOutputSpec(outputConnectionSpec, tech).ignore();
183 // Set DB and Container names
184 placement.setFileName(outputConnectionSpec);
185
186 std::string containerPrefix = m_containerPrefix;
187 if( containerPrefix == "Default" ) {
189 }
191 std::string containerName;
192
193 // Get Technology from containerPrefix
194 std::size_t colonPos = containerPrefix.find(':');
195 if (colonPos != std::string::npos) {
196 dhContainerPrefix = containerPrefix.substr(0, colonPos + 1) + dhContainerPrefix;
197 }
198
199 // Override streaming parameters from StreamTool if requested.
200 std::string containerNameHint = m_containerNameHint;
201 std::string branchNameHint = m_branchNameHint;
202 std::string containerFriendPostfix;
203 while (pos1 != std::string::npos) {
204 const std::string::size_type pos2 = output.find('=', pos1);
205 const std::string thisKey = output.substr(pos1 + 1, pos2 - pos1 - 1);
206 const std::string::size_type pos3 = output.find(']', pos2);
207 const std::string value = output.substr(pos2 + 1, pos3 - pos2 - 1);
208 if (thisKey == "OutputCollection") {
209 dhContainerPrefix = std::move(value);
210 } else if (thisKey == "PoolContainerPrefix") {
211 containerPrefix = std::move(value);
212 } else if (thisKey == "TopLevelContainerName") {
213 containerNameHint = std::move(value);
214 } else if (thisKey == "SubLevelBranchName") {
215 branchNameHint = std::move(value);
216 } else if (thisKey == "PoolContainerFriendPostfix") {
217 containerFriendPostfix = std::move(value);
218 }
219 pos1 = output.find('[', pos3);
220 }
221
222 // --- Special types: DataHeader & Form
223 if( tname.compare(0, 10, "DataHeader") == 0 ) {
224 if( tname.compare(10, 4, "Form") == 0 ) {
225 containerName = dhContainerPrefix + "Form" + "(" + tname + ")";
226 } else {
227 if (key[key.size() - 1] == '/') {
228 containerName = dhContainerPrefix + "(" + key + tname + ")";
229 } else {
230 containerName = dhContainerPrefix + "(" + tname + ")";
231 }
232 }
233 }
234 // AttributeList - writing attributes separately to EventTag container group
235 else if (tname.compare(0, 13, "AttributeList") == 0) {
236 // Find the right storage type and name for EventTag values
237 if( pool::ROOTRNTUPLE_StorageType.exactMatch(tech) ) {
238 containerName = std::string(APRDefaults::RNTupleNames::EventTag) + "(" + key + ")";
239 } else {
240 // no indexing needed (nothing points to Tags)
241 // safe to set tech here - it will not be overwritten by decodeOutput
243 containerName = std::string(APRDefaults::TTreeNames::EventTag) + "(" + key + ")";
244 }
245 }
246 // all other object types
247 else {
248 const std::string typeTok = "<type>", keyTok = "<key>";
249 containerName = containerPrefix + containerFriendPostfix + containerNameHint;
250 if (!branchNameHint.empty()) {
251 containerName += "(" + branchNameHint + ")";
252 }
253 const std::size_t pos1 = containerName.find(typeTok);
254 if (pos1 != std::string::npos) {
255 containerName.replace(pos1, typeTok.size(), tname);
256 }
257 const std::size_t pos2 = containerName.find(keyTok);
258 if (pos2 != std::string::npos) {
259 if (key.empty()) {
260 containerName.replace(pos2, keyTok.size(), tname);
261 } else {
262 containerName.replace(pos2, keyTok.size(), key);
263 }
264 }
265 }
266 m_athenaPoolCnvSvc->decodeOutputSpec(containerName, tech).ignore();
267 placement.setContainerName(containerName);
268 placement.setTechnology(tech);
269 return(placement);
270}
Placement & setContainerName(const std::string &containerName)
Set container name.
Definition Placement.h:34
Placement & setFileName(const std::string &fileName)
Set file name.
Definition Placement.h:30
Placement & setTechnology(int technology)
Set technology type.
Definition Placement.h:38
bool exactMatch(const DbType &typ) const
Definition DbType.h:72
output
Definition merge.py:16
static const DbType ROOTTREE_StorageType
Definition DbType.h:101
static const DbType ROOTRNTUPLE_StorageType
Definition DbType.h:103
static constexpr const char * EventData
Definition APRDefaults.h:18
static constexpr const char * EventTag
Definition APRDefaults.h:19
static constexpr const char * DataHeader
Definition APRDefaults.h:20
static constexpr const char * DataHeader
Definition APRDefaults.h:14
static constexpr const char * EventTag
Definition APRDefaults.h:13
static constexpr const char * EventData
Definition APRDefaults.h:12

◆ setToken()

virtual void T_AthenaPoolExtendingCnv< JetTagInfo, Analysis::JetTagInfo_tlp3 >::setToken ( const std::string & token)
overrideprotectedvirtualinherited

Set the token (in std::string representation) and classID for the object that will be read next.

Required by compareClassGuid() and poolReadObject(). Only extending converter needs to call this method explicitely

Parameters
token[IN] token for the object to be read

Reimplemented from T_AthenaPoolCustCnv< TRANS, PERS >.

◆ storageType()

long AthenaPoolConverter::storageType ( )
staticinherited
Returns
storage type.

Definition at line 155 of file AthenaPoolConverter.cxx.

155 {
157}

◆ tracks()

const std::vector< TIDA::Track * > & Converter::tracks ( ) const
inlineinherited

Definition at line 50 of file Converter.h.

50{return m_tracks;}

◆ transToPers()

template<class TRANS, class PERS>
virtual StatusCode T_AthenaPoolCustomCnvWithKey< TRANS, PERS >::transToPers ( TRANS * ,
PERS *&  )
inlineoverrideprotectedvirtualinherited

Obsolete methods replaced by createPersistent() and createTransient() obsolete.

Implements T_AthenaPoolCustCnv< TRANS, PERS >.

Definition at line 94 of file T_AthenaPoolCustomCnv.h.

94{ return(StatusCode::FAILURE); }

◆ usingTPCnvForReading() [1/2]

void AthenaConverterTLPExtension::usingTPCnvForReading ( void * cnv)
protectedinherited

Definition at line 59 of file AthenaConverterTLPExtension.cxx.

60{
61 usingTPCnvForReading( *reinterpret_cast<TopLevelTPCnvBase*>( cnv ) );
62}
void usingTPCnvForReading(TopLevelTPCnvBase &cnv)
Sets top-level TP converter to be used for reading the next object.

◆ usingTPCnvForReading() [2/2]

void AthenaPoolCnvTPExtension::usingTPCnvForReading ( TopLevelTPCnvBase & baseTLPcnv)
inlineinherited

Definition at line 31 of file AthenaPoolCnvTPExtension.h.

31 {
33 }

◆ wasClonedFrom()

virtual void T_AthenaPoolExtendingCnv< JetTagInfo, Analysis::JetTagInfo_tlp3 >::wasClonedFrom ( AthenaConverterTLPExtension * orig_converter)
overrideprotectedvirtualinherited

remember the original converter this one was cloned from

Reimplemented from AthenaConverterTLPExtension.

◆ writeObject()

virtual std::unique_ptr< const Token > T_AthenaPoolExtendingCnv< JetTagInfo, Analysis::JetTagInfo_tlp3 >::writeObject ( const std::string & key,
const std::string & output )
overrideprotectedvirtualinherited

Write the persistent object to POOL.

Parameters
key[IN] StoreGate key (string) - placement hint to generate POOL container name

Reimplemented from AthenaConverterTLPExtension.

◆ CnvFactory< JetTagInfoCnv >

friend class CnvFactory< JetTagInfoCnv >
friend

Definition at line 21 of file JetTagInfoCnv.h.

Member Data Documentation

◆ ATLAS_THREAD_SAFE

std::atomic_flag m_initialized AthMessaging::ATLAS_THREAD_SAFE = ATOMIC_FLAG_INIT
mutableprivateinherited

Messaging initialized (initMessaging)

Definition at line 141 of file AthMessaging.h.

◆ m_athenaPoolCnvSvc

ServiceHandle<IAthenaPoolCnvSvc> AthenaPoolConverter::m_athenaPoolCnvSvc
protectedinherited

Definition at line 117 of file AthenaPoolConverter.h.

◆ m_beamX

double Converter::m_beamX
protectedinherited

Definition at line 320 of file Converter.h.

◆ m_beamY

double Converter::m_beamY
protectedinherited

Definition at line 320 of file Converter.h.

◆ m_beamZ

double Converter::m_beamZ
protectedinherited

Definition at line 320 of file Converter.h.

◆ m_branchNameHint

std::string AthenaPoolConverter::m_branchNameHint
protectedinherited

Definition at line 127 of file AthenaPoolConverter.h.

◆ m_classDesc

RootType AthenaPoolConverter::m_classDesc
protectedinherited

Definition at line 118 of file AthenaPoolConverter.h.

◆ m_classDescs

ClassMap AthenaPoolConverter::m_classDescs
protectedinherited

Definition at line 123 of file AthenaPoolConverter.h.

◆ m_classID

template<class TRANS, class PERS>
Guid T_AthenaPoolCustCnv< TRANS, PERS >::m_classID
protectedinherited

Definition at line 96 of file T_AthenaPoolCustCnv.h.

◆ m_className

std::string AthenaPoolConverter::m_className
protectedinherited

Definition at line 122 of file AthenaPoolConverter.h.

◆ m_clonedExtendingCnvs

std::vector< AthenaConverterTLPExtension* > AthenaConverterTLPExtension::m_clonedExtendingCnvs
protectedinherited

list of duplicated converters to delete at the end held in the original converter

Definition at line 151 of file AthenaConverterTLPExtension.h.

◆ m_containerNameHint

std::string AthenaPoolConverter::m_containerNameHint
protectedinherited

Definition at line 126 of file AthenaPoolConverter.h.

◆ m_containerPrefix

std::string AthenaPoolConverter::m_containerPrefix
protectedinherited

Definition at line 125 of file AthenaPoolConverter.h.

◆ m_conv_mut

CallMutex AthenaPoolConverter::m_conv_mut
protectedinherited

Definition at line 133 of file AthenaPoolConverter.h.

◆ m_dataObject

const DataObject* AthenaPoolConverter::m_dataObject
protectedinherited

Definition at line 129 of file AthenaPoolConverter.h.

◆ m_detStore

ServiceHandle<StoreGateSvc> AthenaPoolConverter::m_detStore
protectedinherited

Definition at line 116 of file AthenaPoolConverter.h.

◆ m_extCnvMapMap

extCnvMapMap_t AthenaConverterTLPExtension::m_extCnvMapMap
protectedinherited

Definition at line 141 of file AthenaConverterTLPExtension.h.

◆ m_extendingConverters

extCnvMap_t AthenaConverterTLPExtension::m_extendingConverters
protectedinherited

map of Athena converters extending this one

Definition at line 136 of file AthenaConverterTLPExtension.h.

◆ m_i_poolToken

const Token* AthenaPoolConverter::m_i_poolToken
protectedinherited

Definition at line 130 of file AthenaPoolConverter.h.

◆ m_imsg

std::atomic<IMessageSvc*> AthMessaging::m_imsg { nullptr }
mutableprivateinherited

MessageSvc pointer.

Definition at line 135 of file AthMessaging.h.

135{ nullptr };

◆ m_lvl

std::atomic<MSG::Level> AthMessaging::m_lvl { MSG::NIL }
mutableprivateinherited

Current logging level.

Definition at line 138 of file AthMessaging.h.

138{ MSG::NIL };

◆ m_msg_tls

boost::thread_specific_ptr<MsgStream> AthMessaging::m_msg_tls
mutableprivateinherited

MsgStream instance (a std::cout like with print-out levels)

Definition at line 132 of file AthMessaging.h.

◆ m_nm

std::string AthMessaging::m_nm
privateinherited

Message source name.

Definition at line 129 of file AthMessaging.h.

◆ m_originalExtendingCnv

BaseType* T_AthenaPoolExtendingCnv< JetTagInfo, Analysis::JetTagInfo_tlp3 >::m_originalExtendingCnv
protectedinherited

pointer to the original Gaudi converter - only this one is registered in the framework and has to be used for all I/O operations

Definition at line 95 of file T_AthenaPoolExtendingCnv.h.

◆ m_persObjLists

template<class TRANS, class PERS>
std::map<std::string, std::vector< std::unique_ptr<PERS> > > T_AthenaPoolCustomCnvWithKey< TRANS, PERS >::m_persObjLists
protectedinherited

Local cache for persistent objects created by this converter, grouped by processing slot These objects are deleted after a commit.

Definition at line 120 of file T_AthenaPoolCustomCnv.h.

◆ m_pListMutex

template<class TRANS, class PERS>
std::mutex T_AthenaPoolCustomCnvWithKey< TRANS, PERS >::m_pListMutex
protectedinherited

protection mutex for m_persObjLists

Definition at line 123 of file T_AthenaPoolCustomCnv.h.

◆ m_TLCnvForReading

TopLevelTPCnvBase* AthenaConverterTLPExtension::m_TLCnvForReading
protectedinherited

additional Top Level TP converter used only for reading tells which converter is used in case of reading old versions (as different versions have different converters) NOT owned byt his class

Definition at line 147 of file AthenaConverterTLPExtension.h.

◆ m_TPConverter

Analysis::JetTagInfoCnv_tlp3 JetTagInfoCnv::m_TPConverter
private

Definition at line 46 of file JetTagInfoCnv.h.

◆ m_TPConverter_p1

Analysis::JetTagInfoCnv_tlp1 JetTagInfoCnv::m_TPConverter_p1
private

Definition at line 48 of file JetTagInfoCnv.h.

◆ m_TPConverter_p2

Analysis::JetTagInfoCnv_tlp2 JetTagInfoCnv::m_TPConverter_p2
private

Definition at line 47 of file JetTagInfoCnv.h.

◆ m_tracks

std::vector<TIDA::Track*> Converter::m_tracks
protectedinherited

Definition at line 321 of file Converter.h.


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