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

This class provides the converter to customize the saving of DataHeader. More...

#include <DataHeaderCnv.h>

Inheritance diagram for DataHeaderCnv:

Classes

struct  placementComp
 Cache for new DHForms created when writing, indexed by ref or placement. More...

Public Types

typedef T_AthenaPoolCustCnv< DataHeader, DataHeader_p6BaseType

Public Member Functions

 DataHeaderCnv (ISvcLocator *svcloc)
 ~DataHeaderCnv ()
virtual StatusCode initialize () override
 Gaudi Service Interface method implementations:
virtual StatusCode updateRep (IOpaqueAddress *pAddress, DataObject *pObject) override
 Extend base-class conversion methods.
virtual StatusCode updateRepRefs (IOpaqueAddress *pAddress, DataObject *pObject) override
virtual StatusCode DataObjectToPool (IOpaqueAddress *pAddr, DataObject *pObj) override
 Write an object into POOL.
std::unique_ptr< DataHeader_p5poolReadObject_p5 ()
std::unique_ptr< DataHeader_p6poolReadObject_p6 ()
DataHeader_p6createPersistent (DataHeader *transObj, DataHeaderForm_p6 *)
virtual DataHeadercreateTransient () override
virtual DataHeader_p6createPersistent (DataHeader *) override
virtual void handle (const Incident &incident) override
 Incident service handle listening for EndInputFile.
void clearInputDHFormCache (const std::string &dbGuid)
 Delete cached DHForms for a given input file GUID.
void removeBadElements (DataHeader *dh)
 Remove DataHeaderElements with incomplete (dbID="") refs.
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.

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

Protected Member Functions

virtual DataHeader_p6createPersistentWithKey (DataHeader *obj, const std::string &) override
 method to be implemented by the developer.
virtual PERScreatePersistentWithKey (TRANS *obj, const std::string &key)=0
 method to be implemented by the developer.
virtual DataHeadercreateTransientWithKey (const std::string &) override
 method to be implemented by the developer.
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.
void keepPoolObj (DataHeader_p6 *obj, const std::string &output)
 Remember the POOL object to be written out (will be deleted after commit)
void keepPoolObj (PERS *obj, const std::string &output)
 Remember the POOL object to be written out (will be deleted after commit)
virtual StatusCode transToPers (DataHeader *, DataHeader_p6 *&) override
 Obsolete methods replaced by createPersistent() and createTransient() obsolete.
virtual StatusCode persToTrans (DataHeader *&, DataHeader_p6 *) override
 obsolete
virtual StatusCode DataObjectToPers (DataObject *pObj, IOpaqueAddress *&pAddr) override
 Convert an object into Persistent.
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.
Placement setPlacementForP (P &p, const std::string &key, const std::string &output)
 Set POOL placement for type 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.
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 void setToken (const std::string &token)
 Set the token (in std::string representation) and classID for the object that will be read next.
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)

Protected Attributes

DataHeaderCnv_p6 m_tpOutConverter
DataHeaderCnv_p6 m_tpInConverter
RootType m_dhFormType
 cached shape of the DataHeaderForm_pN
bool m_oneDHForm = true
 if true write only one DataHeaderForm at the end (stop, finalize, or WriteDataHeaderForms incident) the value is read from AthenaPoolCnvSvc OneDataHeaderForm property
std::map< std::string, std::unique_ptr< DataHeaderForm_p6 >, placementCompm_persFormMap
std::map< std::string, std::unique_ptr< DataHeaderForm_p6 > > m_inputDHForms
 DHForm cache indexed by the DHForm reference (from DataHeader) that was used to read it.
std::map< std::string, unsigned > m_inDHFormCount
 How many DHForms for an input file are in the cache.
unsigned m_inDHFMapMaxsize {}
 Max DHForms to cache per input file.
std::map< std::string, std::string > m_lastGoodDHFRef
DataHeaderCnv_p5 m_tpInConverter_p5
 for use when reading DataHeader_p5
std::unique_ptr< DataHeaderForm_p5m_dhInForm5
std::string m_dhFormMdx
DataHeader_p6m_sharedWriterCachedDH = nullptr
 cached values for use with SharedWriter server
std::map< std::string, std::unique_ptr< DataHeaderForm_p6 > > m_sharedWriterCachedDHForm
 map of cached DHForms for DataHeader ID
std::string m_sharedWriterCachedDHKey
std::string m_sharedWriterCachedDHToken
std::map< std::string, std::vector< std::unique_ptr< DataHeader_p6 > > > 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

Private Member Functions

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

Private Attributes

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
 MessageSvc pointer.
std::atomic< MSG::Level > m_lvl
 Current logging level.
std::atomic_flag m_initialized ATLAS_THREAD_SAFE
 Messaging initialized (initMessaging)

Friends

class CnvFactory< DataHeaderCnv >

Detailed Description

This class provides the converter to customize the saving of DataHeader.

Definition at line 31 of file DataHeaderCnv.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.

Constructor & Destructor Documentation

◆ DataHeaderCnv()

DataHeaderCnv::DataHeaderCnv ( ISvcLocator * svcloc)

Definition at line 33 of file DataHeaderCnv.cxx.

33 :
34 DataHeaderCnvBase(svcloc, "DataHeaderCnv")
35{
36 m_classDesc = RootType( "DataHeader_p6" );
37}
T_AthenaPoolCustomCnv< DataHeader, DataHeader_p6 > DataHeaderCnvBase
TTypeAdapter RootType
Definition RootType.h:211

◆ ~DataHeaderCnv()

DataHeaderCnv::~DataHeaderCnv ( )

Definition at line 40 of file DataHeaderCnv.cxx.

41{
42 // Remove itself from the IncidentSvc - if it is still around
43 ServiceHandle<IIncidentSvc> incSvc("IncidentSvc", "DataHeaderCnv");
44 if( incSvc.retrieve().isSuccess() ) {
45 try{
46 incSvc->removeListener(this, IncidentType::EndInputFile);
47 } catch ( GaudiException & e){
48 ATH_MSG_FATAL("Gaudi exception caught in DataHeaderCnv::~DataHeaderCnv");
49 }
50 }
51}
#define ATH_MSG_FATAL(x)

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 }
Compatibility for old converter classes that don't get passed the key.

◆ classID()

const CLID & T_AthenaPoolCustCnv< DataHeader, DataHeader_p6 >::classID ( )
staticinherited
Returns
class ID.

◆ cleanUp()

virtual StatusCode T_AthenaPoolCustomCnvWithKey< DataHeader, DataHeader_p6 >::cleanUp ( const std::string & output)
overrideprotectedvirtualinherited

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

◆ clear()

void Converter::clear ( )
inlineinherited

Definition at line 53 of file Converter.h.

53{m_tracks.clear();}

◆ clearInputDHFormCache()

void DataHeaderCnv::clearInputDHFormCache ( const std::string & dbGuid)

Delete cached DHForms for a given input file GUID.

Definition at line 154 of file DataHeaderCnv.cxx.

155{
156 auto iter = m_inputDHForms.begin();
157 while( iter != m_inputDHForms.end() ) {
158 size_t dbpos = iter->first.find("[DB=");
159 if( dbpos != std::string::npos && iter->first.compare(dbpos+4, dbpos+36, dbGuid) == 0 ) {
160 iter = m_inputDHForms.erase( iter );
161 } else {
162 iter++;
163 }
164 }
165 m_inDHFormCount[ dbGuid ] = 0;
166}
std::map< std::string, unsigned > m_inDHFormCount
How many DHForms for an input file are in the cache.
std::map< std::string, std::unique_ptr< DataHeaderForm_p6 > > m_inputDHForms
DHForm cache indexed by the DHForm reference (from DataHeader) that was used to read it.

◆ compareClassGuid()

virtual bool T_AthenaPoolCustCnv< DataHeader, DataHeader_p6 >::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.

Definition at line 56 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;
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
75 }
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() );
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) override

◆ createPersistent() [1/2]

virtual DataHeader_p6 * DataHeaderCnv::createPersistent ( DataHeader * )
inlineoverridevirtual

Implements T_AthenaPoolCustomCnv< DataHeader, DataHeader_p6 >.

Definition at line 53 of file DataHeaderCnv.h.

53{ return nullptr; }

◆ createPersistent() [2/2]

DataHeader_p6 * DataHeaderCnv::createPersistent ( DataHeader * transObj,
DataHeaderForm_p6 * dh_form )

Definition at line 544 of file DataHeaderCnv.cxx.

545{
546 return m_tpOutConverter.createPersistent( transObj, *dh_form );
547}
DataHeaderCnv_p6 m_tpOutConverter

◆ createPersistentWithKey() [1/2]

virtual DataHeader_p6 * T_AthenaPoolCustomCnv< DataHeader, DataHeader_p6 >::createPersistentWithKey ( DataHeader * obj,
const std::string &  )
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)

◆ createPersistentWithKey() [2/2]

template<class TRANS, class PERS>
virtual PERS * T_AthenaPoolCustomCnvWithKey< TRANS, PERS >::createPersistentWithKey ( TRANS * obj,
const std::string & key )
protectedpure virtualinherited

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)

Implemented in ElementTableCnv, LayerMaterialMapCnv, MaterialStepCollectionCnv, T_AthenaPoolAuxContainerCnv< AUXSTORE, TPCNVS >, T_AthenaPoolCustomCnv< TRANS, PERS >, T_AthenaPoolCustomCnv< AFP_SiDigiCollection, AFP_SiDigiCollection_PERS >, T_AthenaPoolCustomCnv< AFP_SIDLocRecoEvCollection, AFP_SIDLocRecoEvCollection_PERS >, T_AthenaPoolCustomCnv< AFP_SIDSimHitCollection, AFP_SIDSimHitCollection_PERS >, T_AthenaPoolCustomCnv< AFP_TDDigiCollection, AFP_TDDigiCollection_PERS >, T_AthenaPoolCustomCnv< AFP_TDLocRecoEvCollection, AFP_TDLocRecoEvCollection_PERS >, T_AthenaPoolCustomCnv< AFP_TDSimHitCollection, AFP_TDSimHitCollection_PERS >, T_AthenaPoolCustomCnv< ALFA_CLinkEvent, ALFA_CLinkEvent_PERS >, T_AthenaPoolCustomCnv< ALFA_DigitCollection, ALFA_DigitCollection_PERS >, T_AthenaPoolCustomCnv< ALFA_GloRecEvCollection, ALFA_GloRecEvCollection_PERS >, T_AthenaPoolCustomCnv< ALFA_HitCollection, ALFA_HitCollection_PERS >, T_AthenaPoolCustomCnv< ALFA_LocRecCorrEvCollection, ALFA_LocRecCorrEvCollection_PERS >, T_AthenaPoolCustomCnv< ALFA_LocRecCorrODEvCollection, ALFA_LocRecCorrODEvCollection_PERS >, T_AthenaPoolCustomCnv< ALFA_LocRecEvCollection, ALFA_LocRecEvCollection_PERS >, T_AthenaPoolCustomCnv< ALFA_LocRecODEvCollection, ALFA_LocRecODEvCollection_PERS >, T_AthenaPoolCustomCnv< ALFA_ODDigitCollection, ALFA_ODDigitCollection_PERS >, T_AthenaPoolCustomCnv< ALFA_ODHitCollection, ALFA_ODHitCollection_PERS >, T_AthenaPoolCustomCnv< Analysis ::TauDetailsContainer, TauDetailsContainer_PERS >, T_AthenaPoolCustomCnv< Analysis ::TauJetContainer, TauJetContainer_PERS >, T_AthenaPoolCustomCnv< Analysis::MuonContainer, MuonContainer_PERS >, T_AthenaPoolCustomCnv< AthExDecay, AthExDecay_PERS >, T_AthenaPoolCustomCnv< AthExElephantino, AthExElephantino_PERS >, T_AthenaPoolCustomCnv< AthExFatObject, AthExFatObject_PERS >, T_AthenaPoolCustomCnv< BCM_RDO_Container, BCM_RDO_Container_p0 >, T_AthenaPoolCustomCnv< CaloCalibrationHitContainer, CaloCalibrationHitContainer_PERS >, T_AthenaPoolCustomCnv< CaloRingsContainer, CaloRingsContainer_PERS >, T_AthenaPoolCustomCnv< eflowObjectContainer, eflowObjectContainer_p5 >, T_AthenaPoolCustomCnv< egammaContainer, egammaContainer_PERS >, T_AthenaPoolCustomCnv< egDetailContainer, egDetailContainer_PERS >, T_AthenaPoolCustomCnv< ElectronContainer, ElectronContainer_PERS >, T_AthenaPoolCustomCnv< INav4MomAssocs, INav4MomAssocs_PERS >, T_AthenaPoolCustomCnv< INav4MomLinkContainer, INav4MomLinkContainer_PERS >, T_AthenaPoolCustomCnv< InDet::InDetLowBetaCandidate, InDetLowBetaCandidate_PERS >, T_AthenaPoolCustomCnv< IParticleLinkContainer, IParticleLinkContainer_PERS >, T_AthenaPoolCustomCnv< LArHitContainer, LArHitContainer_PERS >, T_AthenaPoolCustomCnv< LArHitFloatContainer, LArHitContainer_PERS >, T_AthenaPoolCustomCnv< LArTTL1Container, LArTTL1Container_PERS >, T_AthenaPoolCustomCnv< McEventCollection, McEventCollection_PERS >, T_AthenaPoolCustomCnv< MissingET, MissingET_PERS >, T_AthenaPoolCustomCnv< MissingEtCalo, MissingEtCalo_PERS >, T_AthenaPoolCustomCnv< MissingEtTruth, MissingEtTruth_PERS >, T_AthenaPoolCustomCnv< MuonCaloEnergyContainer, MuonCaloEnergyContainer_PERS >, T_AthenaPoolCustomCnv< PhotonContainer, PhotonContainer_PERS >, T_AthenaPoolCustomCnv< Rec::MuonSpShowerContainer, MuonSpShowerContainer_PERS >, T_AthenaPoolCustomCnv< RecoTimingObj, RecoTimingObj_PERS >, T_AthenaPoolCustomCnv< RingerRings, RingerRings_PERS >, T_AthenaPoolCustomCnv< SiHitCollection, SiHitCollection_PERS >, T_AthenaPoolCustomCnv< SimulationHitCollection, SimulationHitCollection_PERS >, T_AthenaPoolCustomCnv< T, P >, T_AthenaPoolCustomCnv< TileBeamElemContainer, TileBeamElemContainer_PERS >, T_AthenaPoolCustomCnv< TileCosmicMuonContainer, TileCosmicMuonContainer_PERS >, T_AthenaPoolCustomCnv< TileDigitsContainer, TileDigitsContainer_PERS >, T_AthenaPoolCustomCnv< TileHitContainer, TileHitContainer_PERS >, T_AthenaPoolCustomCnv< TileHitVector, TileHitVector_PERS >, T_AthenaPoolCustomCnv< TileL2Container, TileL2Container_PERS >, T_AthenaPoolCustomCnv< TileMuContainer, TileMuContainer_PERS >, T_AthenaPoolCustomCnv< TileMuonReceiverContainer, TileMuonReceiverContainer_PERS >, T_AthenaPoolCustomCnv< TileRawChannelContainer, TileRawChannelContainer_PERS >, T_AthenaPoolCustomCnv< TileTTL1Container, TileTTL1Container_PERS >, T_AthenaPoolCustomCnv< TrackRecordCollection, TrackRecordCollection_PERS >, T_AthenaPoolCustomCnv< TRANS, LEGACY >, T_AthenaPoolCustomCnv< TrigComposite, TrigComposite_PERS >, T_AthenaPoolCustomCnv< TrigEMCluster, TrigEMCluster_PERS >, T_AthenaPoolCustomCnv< TrigMonConfig, TrigMonConfig_PERS >, T_AthenaPoolCustomCnv< TrigMonConfigCollection, TrigMonConfigCollection_PERS >, T_AthenaPoolCustomCnv< TrigMonEvent, TrigMonEvent_PERS >, T_AthenaPoolCustomCnv< TrigMonEventCollection, TrigMonEventCollection_PERS >, T_AthenaPoolCustomCnv< TrigOperationalInfo, TrigOperationalInfo_PERS >, T_AthenaPoolCustomCnv< TrigOperationalInfoCollection, TrigOperationalInfoCollection_PERS >, T_AthenaPoolCustomCnv< TrigRNNOutput, TrigRNNOutput_PERS >, T_AthenaPoolCustomCnv< TrigRoiDescriptor, TrigRoiDescriptor_PERS >, T_AthenaPoolCustomCnv< TrigRoiDescriptorCollection, TrigRoiDescriptorCollection_PERS >, T_AthenaPoolCustomCnv< TrigTau, TrigTau_PERS >, T_AthenaPoolCustomCnv< TrigTauCluster, TrigTauCluster_PERS >, T_AthenaPoolCustomCnv< TrigTauClusterDetails, TrigTauClusterDetails_PERS >, T_AthenaPoolCustomCnv< TrigTauTracksInfo, TrigTauTracksInfo_PERS >, T_AthenaPoolCustomCnv< TRTUncompressedHitCollection, TRT_HitCollection_PERS >, T_AthenaPoolCustomCnv< TruthEtIsolationsContainer, TruthEtIsolationsContainer_PERS >, T_AthenaPoolCustomCnv< TruthParticleContainer, TruthParticleContainer_PERS >, T_AthenaPoolCustomCnv< ViewVector< DV >, ViewVector< DV > >, T_AthenaPoolCustomCnv< ZdcRawChannelCollection, ZdcRawChannelCollection_PERS >, T_AthenaPoolTPCnvCnv< TRANS, TPCNV_CUR, TPCNVS >, T_AthenaPoolxAODCnv< XAOD, TPCNVS >, TrackCollectionCnv, and xAODShallowAuxContainerCnv.

◆ 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.

Definition at line 61 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 {
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}
virtual StatusCode DataObjectToPers(DataObject *pObj, IOpaqueAddress *&pAddr) override

◆ createTransient()

DataHeader * DataHeaderCnv::createTransient ( )
overridevirtual

Implements T_AthenaPoolCustomCnv< DataHeader, DataHeader_p6 >.

Definition at line 564 of file DataHeaderCnv.cxx.

564 {
565 if (this->m_i_poolToken == nullptr) {
566 return(nullptr);
567 }
568 if (this->m_i_poolToken->technology() == 0x00001000) { // Artificial ByteStream DataHeader Token
569 DataHeader* dh = new DataHeader();
570 std::string bestPfn, fileType;
571 m_athenaPoolCnvSvc->getPoolSvc()->lookupBestPfn(this->m_i_poolToken->dbID().toString(), bestPfn, fileType);
572 DataHeaderElement dhe(ClassID_traits<DataHeader>::ID(), bestPfn, Token(this->m_i_poolToken));
573 dh->insert(dhe);
574 return(dh);
575 }
576 static const pool::Guid p6_guid("4DDBD295-EFCE-472A-9EC8-15CD35A9EB8D");
577 static const pool::Guid p5_guid("D82968A1-CF91-4320-B2DD-E0F739CBC7E6");
578 static const pool::Guid p4_guid("9630EB7B-CCD7-47D9-A39B-CBBF4133CDF2");
579 static const pool::Guid p3_guid("EC1318F0-8E28-45F8-9A2D-2597C1CC87A6");
580 try {
581 if( compareClassGuid( p6_guid ) ) {
582 std::unique_ptr<DataHeader_p6> header( poolReadObject_p6() );
583 auto dhForm = m_inputDHForms[ header->dhFormToken() ].get();
584 auto dh = m_tpInConverter.createTransient( header.get(), *dhForm, m_i_poolToken );
586 // To dump the DataHeader uncomment below
587 // std::ostringstream ss; dh->dump(ss); std::cout << ss.str() << std::endl;
588 return dh;
589 } else if (this->compareClassGuid( p5_guid )) {
590 std::unique_ptr<DataHeader_p5> obj_p5( poolReadObject_p5() );
591 return m_tpInConverter_p5.createTransient( *obj_p5, *m_dhInForm5 ).release();
592 } else if (this->compareClassGuid( p4_guid )) {
593 std::unique_ptr<DataHeader_p4> obj_p4(this->poolReadObject<DataHeader_p4>());
594 DataHeaderCnv_p4 tPconverter_p4;
595 return(tPconverter_p4.createTransient(obj_p4.get()));
596 } else if (this->compareClassGuid( p3_guid )) {
597 std::unique_ptr<DataHeader_p3> obj_p3(this->poolReadObject<DataHeader_p3>());
598 DataHeaderCnv_p3 tPconverter_p3;
599 return(tPconverter_p3.createTransient(obj_p3.get()));
600 }
601 } catch (std::exception &e) {
602 // upgrade all exceptions to runtime_error (who needs that? MN)
603 std::string error = e.what();
604 throw std::runtime_error(error);
605 }
606 return(nullptr);
607}
ServiceHandle< IAthenaPoolCnvSvc > m_athenaPoolCnvSvc
DataHeader * createTransient(const DataHeader_p3 *persObj)
DataHeader * createTransient(const DataHeader_p4 *persObj)
DataHeaderCnv_p6 m_tpInConverter
DataHeaderCnv_p5 m_tpInConverter_p5
for use when reading DataHeader_p5
std::unique_ptr< DataHeaderForm_p5 > m_dhInForm5
std::unique_ptr< DataHeader_p6 > poolReadObject_p6()
std::unique_ptr< DataHeader_p5 > poolReadObject_p5()
void removeBadElements(DataHeader *dh)
Remove DataHeaderElements with incomplete (dbID="") refs.
virtual bool compareClassGuid(const Guid &clid) const
P * poolReadObject()
Read object of type P.

◆ createTransientWithKey()

virtual DataHeader * T_AthenaPoolCustomCnv< DataHeader, DataHeader_p6 >::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()

virtual StatusCode T_AthenaPoolCustomCnvWithKey< DataHeader, DataHeader_p6 >::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

◆ DataObjectToPool()

StatusCode DataHeaderCnv::DataObjectToPool ( IOpaqueAddress * pAddr,
DataObject * pObj )
overridevirtual

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_AthenaPoolCustomCnvWithKey< TRANS, PERS >.

Definition at line 293 of file DataHeaderCnv.cxx.

294{
295 DataHeader* obj = nullptr;
296 if (!SG::fromStorable(pObj, obj) || obj == nullptr) {
297 ATH_MSG_ERROR( "Failed to cast DataHeader to transient type" );
298 return(StatusCode::FAILURE);
299 }
300 // DHForm placement:
301 Placement dhf_placement = setPlacementWithType("DataHeaderForm", pObj->name(), *pAddr->par());
302 std::string form_placement_str = dhf_placement.toString();
303 // Find or create Form
304 std::unique_ptr<DataHeaderForm_p6>& dhForm = m_persFormMap[form_placement_str];
305 if (dhForm == nullptr) {
306 // create new DHF for this file. Every new file/container should get its own DHForm
307 dhForm = std::make_unique<DataHeaderForm_p6>();
308 dhForm->setProcessTag( obj->getProcessTag() );
309 }
310
311 // DH placement first:
312 Placement dh_placement = setPlacementWithType("DataHeader", pObj->name(), *pAddr->par());
313 // remember the connection string, it may get changed in registerForWrite by SharedWriter
314 const std::string connection = dh_placement.fileName();
315 // Create persistent DH and update Form
316 DataHeader_p6* persObj = nullptr;
317 try {
318 persObj = createPersistent(obj, dhForm.get());
319 } catch (std::exception &e) {
320 ATH_MSG_FATAL("Failed to convert DataHeader to persistent type: " << e.what());
321 return(StatusCode::FAILURE);
322 }
323 // Queue the DH for write
324 std::unique_ptr<Token> dh_token (m_athenaPoolCnvSvc->registerForWrite(&dh_placement, persObj, m_classDesc));
325 if (dh_token == nullptr) {
326 ATH_MSG_FATAL("Failed to write DataHeader");
327 return(StatusCode::FAILURE);
328 }
329 keepPoolObj(persObj, connection);
330 // insert self reference - this updates DH and can modify the Form
331 m_tpOutConverter.insertDHRef(persObj, obj->getProcessTag(), dh_token->toString(), *dhForm);
332
333 if( !m_oneDHForm ) {
334 if( dhForm->isModified() ) {
335 // Write DHForm if in legacy mode in case it was modified (or new)
336 dhForm->setVersion( DataHeaderForm_p6::DHverFormRef );
337 static const RootType dhFormType(typeid(*dhForm));
338 Token* dhf_token = m_athenaPoolCnvSvc->registerForWrite(&dhf_placement, dhForm.get(), dhFormType);
339 if (dhf_token == nullptr) {
340 ATH_MSG_FATAL("Failed to write " << dhFormType.Name());
341 return(StatusCode::FAILURE);
342 }
343 if (dhf_token->technology() != 0) { // Only store DHF token if technology allows it to be appended to DH
344 dhForm->setToken(dhf_token->toString());
345 } else { // Otherwise keep string empty to cause DHF reading via DH token
346 ATH_MSG_DEBUG("Technology does not support setting DHF token for: " << dh_token->toString());
347 dhForm->setToken("");
348 }
349 ATH_MSG_DEBUG("wrote new DHForm with " << dhForm->sizeObj() << " SG object data");
350 dhf_token->release(); dhf_token = nullptr;
351 dhForm->clearModified();
352 }
353 // update the Ref to the DHForm
354 persObj->setDhFormToken( dhForm->getToken() );
355 }
356 else {
357 // use the DHForm placement as a Ref, as the DHForm will be written out at the end only
358 // but add DB ID to the placement str in case the filename is not unique between jobs
359 if( dhForm->getToken().empty() ) {
360 form_placement_str += std::format("[DB={}]", dh_token->dbID().toString());
361 dhForm->setToken( form_placement_str );
362 } else {
363 form_placement_str = dhForm->getToken();
364 }
365 // remove the [FILE= part as the DBID will be enough for reading back
366 auto b = form_placement_str.find("[FILE=");
367 auto e = form_placement_str.find("]", b);
368 form_placement_str.erase(b, e-b+1);
369 // store the modified DHForm placement in place of the Ref in the DH
370 persObj->setDhFormToken( form_placement_str );
371 }
372
373 const coral::AttributeList* list = obj->getAttributeList();
374 if (list != nullptr) {
375 obj->setEvtRefTokenStr(dh_token->toString());
376 Placement attr_placement = this->setPlacementWithType("AttributeList", "Token", *pAddr->par());
377 const Token* ref_token = m_athenaPoolCnvSvc->registerForWrite(&attr_placement,
378 obj->getEvtRefTokenStr().c_str(),
379 RootType("Token"));
380 delete ref_token; ref_token = nullptr;
381 for (coral::AttributeList::const_iterator iter = list->begin(), last = list->end(); iter != last; ++iter) {
382 attr_placement = this->setPlacementWithType("AttributeList", (*iter).specification().name(), *pAddr->par());
383 const Token* attr_token = m_athenaPoolCnvSvc->registerForWrite(&attr_placement,
384 (*iter).addressOfData(),
385 RootType((*iter).specification().type()) );
386 delete attr_token; attr_token = nullptr;
387 }
388 }
389 TokenAddress* tokAddr = dynamic_cast<TokenAddress*>(pAddr);
390 if (tokAddr != nullptr) {
391 tokAddr->setToken(std::move(dh_token));
392 } else {
393 return(StatusCode::FAILURE);
394 }
395 return(StatusCode::SUCCESS);
396}
#define ATH_MSG_DEBUG(x)
virtual Placement setPlacementWithType(const std::string &tname, const std::string &key, const std::string &output)
std::map< std::string, std::unique_ptr< DataHeaderForm_p6 >, placementComp > m_persFormMap
bool m_oneDHForm
if true write only one DataHeaderForm at the end (stop, finalize, or WriteDataHeaderForms incident) t...
DataHeader_p6 * createPersistent(DataHeader *transObj, DataHeaderForm_p6 *)
void setDhFormToken(const std::string &formToken)
const std::string toString() const
Retrieve the string representation of the placement.
Definition Placement.cxx:15
const std::string & fileName() const
Access file name.
Definition Placement.h:28
void keepPoolObj(DataHeader_p6 *obj, const std::string &output)
void setToken(std::unique_ptr< Token > token)
virtual const std::string toString() const
Retrieve the string representation of the token.
Definition Token.cxx:134
int technology() const
Access technology type.
Definition Token.h:77
int release()
Release token: Decrease reference count and eventually delete.
Definition Token.cxx:80
bool fromStorable(DataObject *pDObj, T *&pTrans, bool quiet=false, IRegisterTransient *irt=0, bool isConst=true)
list(name, path='/')
Definition histSizes.py:38

◆ detStore()

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

Handle to DetectorStore.

Definition at line 69 of file AthenaPoolConverter.h.

69{ return 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.

Definition at line 66 of file AthenaPoolConverter.cxx.

141 {
143 try {
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) override

◆ finalize()

StatusCode AthenaPoolConverter::finalize ( )
overridevirtualinherited

Definition at line 49 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)

◆ getDataObject()

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

Definition at line 111 of file AthenaPoolConverter.cxx.

272 {
273 return(m_dataObject);
274}

◆ handle()

void DataHeaderCnv::handle ( const Incident & incident)
overridevirtual

Incident service handle listening for EndInputFile.

Definition at line 94 of file DataHeaderCnv.cxx.

95{
96 if( incident.type() == "PreFork" ) {
97 m_persFormMap.clear();
98 }
99 if( incident.type() == IncidentType::EndInputFile ) {
100 // remove cached DHForms that came from the file that is now being closed
101 const std::string& guid = static_cast<const FileIncident&>(incident).fileGuid();
102 clearInputDHFormCache( guid );
103 }
104 if( incident.type() == "WriteDataHeaderForms" ) {
105 // Issued from OutputStream MetaData write() or directly called from AthenaPoolCnvSvc
106 const std::string& fileName = static_cast<const FileIncident*>(&incident)->fileName();
107 // Write out all the cached DHForms before closing a given output stream
108 std::vector<std::string> toWrite;
109 auto pos = fileName.find("[OutputCollection=MetaDataHdr]");
110 bool metaDataCommit = (pos != std::string::npos);
111 std::string justFileName = fileName.substr(0, pos);
112 ATH_MSG_DEBUG("Handling WriteDataHeaderForms incident for stream: " << fileName);
113 // collect DHForms related to the stream
114 for( const auto& elem : m_persFormMap ) {
115 const std::string& placementStr = elem.first;
116 Placement formPlacement;
117 formPlacement.fromString( placementStr );
118 ATH_MSG_VERBOSE("DatHeaderForm key in map=" << placementStr);
119 if( formPlacement.fileName() == justFileName or fileName == "*" ) {
120 // write only the Forms that correspond to the commit type (MetaData or others)
121 if( (placementStr.find("[CONT=MetaData") != std::string::npos) == metaDataCommit ) {
122 toWrite.push_back( placementStr );
123 }
124 }
125 }
126 // write the DHForms one by one (the only mode supported by RNTuple)
127 for( std::size_t n = 0; const std::string& placementStr : toWrite ) {
128 Placement formPlacement;
129 formPlacement.fromString( placementStr );
130 auto form_ptr = m_persFormMap[placementStr].get();
131 if( form_ptr->isModified() ) {
132 static const RootType dhFormType( typeid( *form_ptr ) );
133 ATH_MSG_DEBUG("Writing DatHeaderForm " << placementStr);
134 Token* form_token = m_athenaPoolCnvSvc->registerForWrite(&formPlacement, form_ptr, dhFormType);
135 if( !form_token ) {
136 std::string errmsg = std::format("Failed to write {} {}", dhFormType.Name(), placementStr);
138 throw GaudiException(std::move(errmsg), "DataHeaderCnv::WriteDataHeaderForms", StatusCode::FAILURE);
139 }
140 ATH_MSG_DEBUG("Wrote DatHeaderForm, placeemnt was " << placementStr << " token=" << form_token->toString());
141 form_token->release(); form_token = nullptr;
142 bool doCommit = (++n == toWrite.size());
143 const std::string connection = ( fileName!="*"? fileName : formPlacement.fileName() );
144 if( !m_athenaPoolCnvSvc->commitOutput(connection, doCommit).isSuccess() ) {
145 throw GaudiException("WriteDataHeaderForms failed", "DataHeaderCnv::WriteDataHeaderForms", StatusCode::FAILURE);
146 }
147 }
148 m_persFormMap.erase( placementStr );
149 }
150 }
151}
static thread_local std::ostringstream errmsg
Definition WaferTree.h:25
void clearInputDHFormCache(const std::string &dbGuid)
Delete cached DHForms for a given input file GUID.
Placement & fromString(const std::string &from)
Build from the string representation of a placement.
Definition Placement.cxx:28

◆ initialize()

StatusCode DataHeaderCnv::initialize ( )
overridevirtual

Gaudi Service Interface method implementations:

Reimplemented from T_AthenaPoolCustCnv< TRANS, PERS >.

Definition at line 53 of file DataHeaderCnv.cxx.

54{
55 // Read properties from the ConversionSvc
56 m_inDHFMapMaxsize = 100; // default DHForm cache size
57 bool doFilterDHAliases = true;
58 const std::string svcName = (serviceLocator()->existsService("AthenaPoolSharedIOCnvSvc") ? "AthenaPoolSharedIOCnvSvc" : "AthenaPoolCnvSvc");
59 SmartIF<IProperty> cnvSvc{service(svcName, false)};
60 if( cnvSvc ) {
61 IntegerProperty sizeProp("maxDHFormCacheSize", m_inDHFMapMaxsize);
62 if( cnvSvc->getProperty(&sizeProp).isSuccess() ) {
63 m_inDHFMapMaxsize = sizeProp.value();
64 }
65 BooleanProperty aliasFilterProp("doFilterDHAliases", doFilterDHAliases);
66 if( cnvSvc->getProperty(&aliasFilterProp).isSuccess() ) {
67 doFilterDHAliases = aliasFilterProp.value();
68 }
69 BooleanProperty oneDHForm("OneDataHeaderForm", m_oneDHForm);
70 if( cnvSvc->getProperty(&oneDHForm).isSuccess() ) {
71 m_oneDHForm = oneDHForm.value();
72 }
73 }
74 ATH_MSG_VERBOSE("Using DHForm cache size: " << m_inDHFMapMaxsize);
75 if( doFilterDHAliases ) {
76 ATH_MSG_VERBOSE("Will filter SG Aux aliases in DataHeader");
77 } else {
78 ATH_MSG_VERBOSE("Will NOT filter SG Aux aliases in DataHeader");
79 }
80 m_tpOutConverter.setSGAliasFiltering( doFilterDHAliases );
81
82 // Get IncidentSvc
83 ServiceHandle<IIncidentSvc> incSvc("IncidentSvc", "DataHeaderCnv");
84 ATH_CHECK( incSvc.retrieve() );
85 // Listen to EndInputFile incidents to clear old DataHeaderForms from the cache
86 incSvc->addListener(this, IncidentType::EndInputFile, 0);
87 incSvc->addListener(this, "PreFork", 0);
88 // Listen to WriteDataHeaderForms incidents to flush DHForms after
89 incSvc->addListener(this, "WriteDataHeaderForms", 0);
91}
#define ATH_CHECK
Evaluate an expression and check for errors.
unsigned m_inDHFMapMaxsize
Max DHForms to cache per input file.

◆ initMessaging()

void AthMessaging::initMessaging ( ) const
privateinherited

Initialize our message level and MessageSvc.

This method should only be called once.

Definition at line 121 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}
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
300 newphi = phi1;
301 else
302 newphi = phi2;
303
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
312 z0c = z0 + deltaz0;
313
314 }
315 }
constexpr int pow(int base, int exp) noexcept

◆ keepPoolObj() [1/2]

void T_AthenaPoolCustomCnvWithKey< DataHeader, DataHeader_p6 >::keepPoolObj ( DataHeader_p6 * obj,
const std::string & output )
protectedinherited

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

Parameters
obj[IN] persistent object

◆ keepPoolObj() [2/2]

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 92 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
void setLevel(MSG::Level lvl)
Change the current logging level.

◆ 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 99 of file AthMessaging.h.

179{ return msg() << lvl; }

◆ 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 86 of file AthMessaging.h.

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

◆ objectToPool()

StatusCode T_AthenaPoolCustCnv< DataHeader, DataHeader_p6 >::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()

virtual StatusCode T_AthenaPoolCustomCnvWithKey< DataHeader, DataHeader_p6 >::persToTrans ( DataHeader *& ,
DataHeader_p6 *  )
inlineoverrideprotectedvirtualinherited

obsolete

Definition at line 96 of file T_AthenaPoolCustomCnv.h.

96{ return(StatusCode::FAILURE); }

◆ 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 }

◆ poolReadObject() [1/2]

P * T_AthenaPoolCustomCnvWithKey< DataHeader, DataHeader_p6 >::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)

◆ poolReadObject() [2/2]

void T_AthenaPoolCustomCnvWithKey< DataHeader, DataHeader_p6 >::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

◆ poolReadObject_p5()

std::unique_ptr< DataHeader_p5 > DataHeaderCnv::poolReadObject_p5 ( )

Definition at line 399 of file DataHeaderCnv.cxx.

400{
401 void* voidPtr1 = nullptr;
402 m_athenaPoolCnvSvc->setObjPtr(voidPtr1, m_i_poolToken);
403 if (voidPtr1 == nullptr) {
404 throw std::runtime_error("Could not get object for token = " + m_i_poolToken->toString());
405 }
406 std::unique_ptr<DataHeader_p5> header( reinterpret_cast<DataHeader_p5*>(voidPtr1) );
407
408 void* voidPtr2 = nullptr;
409 Token mapToken;
410 mapToken.fromString( header->dhFormToken() );
411 mapToken.setAuxString( m_i_poolToken->auxString() ); // set PersSvc context
412 if (mapToken.classID() != Guid::null()) {
413 if( header->dhFormMdx() != m_dhFormMdx ) {
414 m_athenaPoolCnvSvc->setObjPtr(voidPtr2, &mapToken);
415 if (voidPtr2 == nullptr) {
416 throw std::runtime_error("Could not get object for token = " + mapToken.toString());
417 }
418 m_dhInForm5.reset( reinterpret_cast<DataHeaderForm_p5*>(voidPtr2) );
419 m_dhFormMdx = header->dhFormMdx();
420 }
421 }
422 return header;
423}
std::string m_dhFormMdx
static const Guid & null() noexcept
NULL-Guid: static class method.
Definition Guid.cxx:14
Token & setAuxString(const std::string &auxString)
Set auxiliary string.
Definition Token.h:93
const Guid & classID() const
Access database identifier.
Definition Token.h:73
Token & fromString(const std::string_view from)
Build from the string representation of a token.
Definition Token.cxx:147

◆ poolReadObject_p6()

std::unique_ptr< DataHeader_p6 > DataHeaderCnv::poolReadObject_p6 ( )

Definition at line 428 of file DataHeaderCnv.cxx.

429{
430 void* voidPtr1 = nullptr;
431 std::string error_message;
432 try {
433 m_athenaPoolCnvSvc->setObjPtr(voidPtr1, m_i_poolToken);
434 } catch(const std::exception& err) {
435 voidPtr1 = nullptr;
436 error_message = err.what();
437 }
438 if (voidPtr1 == nullptr) {
439 throw std::runtime_error("Could not get object for token = " + m_i_poolToken->toString() + ", " + error_message);
440 }
441 std::unique_ptr<DataHeader_p6> header( reinterpret_cast<DataHeader_p6*>(voidPtr1) );
442
443 std::string dhFormToken = header->dhFormToken();
444 Token formToken;
445 if( !dhFormToken.empty() and dhFormToken.find("[OID=") == std::string::npos) {
446 // OneForm format of Form Ref (without OID)
447 // we need to reconstruct the real Ref before checking in the Ref cache
448 Placement dhf_placement;
449 dhf_placement.fromString( dhFormToken );
450 formToken.setDb( m_i_poolToken->dbID() );
451 formToken.setCont( dhf_placement.containerName() );
452 formToken.setTechnology( dhf_placement.technology() );
453 formToken.setAuxString( dhf_placement.auxString() );
454 formToken.setClassID( DHForm_p6_Guid );
455 std::int64_t oid2 = m_i_poolToken->oid().second;
456 oid2 >>= 32; oid2 <<= 32;
457 std::string swn = getSWNFromStr( dhFormToken );
458 // add the row number from the SHForm Ref
459 if( !swn.empty() ) oid2 += std::stoul( swn ) - 1;
460 formToken.setOid( {0,oid2} );
461 ATH_MSG_DEBUG("Constructed DHForm Ref=" << formToken.toString() << " from " << dhFormToken );
462 dhFormToken = formToken.toString();
463 header->setDhFormToken( dhFormToken );
464 }
465 // see if the DataHeaderForm is already cached
466 if( dhFormToken.empty() || m_inputDHForms.find(dhFormToken) == m_inputDHForms.end() ) {
467 // no cached DHForm
468 size_t dbpos = dhFormToken.find("[DB=");
469 if( dbpos != std::string::npos ) {
470 const std::string dbGuid = dhFormToken.substr(dbpos+4, dbpos+36);
471 if( ++m_inDHFormCount[dbGuid] > m_inDHFMapMaxsize ) {
472 // prevent the input DHFMap from growing too large
473 clearInputDHFormCache( dbGuid );
474 m_inDHFormCount[dbGuid] = 1;
475 }
476 }
477 // we need to read a new DHF
478 void* voidPtr2 = nullptr;
479 if( dhFormToken.empty() ) {
480 // Some technologies can't set DHF token, use DH token with new CLID.
481 m_i_poolToken->setData(&formToken);
482 formToken.setClassID( DHForm_p6_Guid );
483 } else {
484 formToken.fromString( dhFormToken );
485 formToken.setAuxString( m_i_poolToken->auxString() ); // set PersSvc context
486 }
487 if (formToken.classID() != Guid::null()) {
488 try {
489 m_athenaPoolCnvSvc->setObjPtr(voidPtr2, &formToken);
490 } catch(const std::exception& err) {
491 voidPtr2 = nullptr;
492 error_message = err.what();
493 }
494 if (voidPtr2 == nullptr) {
495 // if there is no good lastGoodDHFRef then try reading DataHeaderForm Token from the first DataHeader
496 if( m_lastGoodDHFRef.find(m_i_poolToken->contID()) == m_lastGoodDHFRef.end() ) {
497 Token firstToken;
498 m_i_poolToken->setData(&firstToken);
499 firstToken.setOid(Token::OID_t(firstToken.oid().first, 0));
500 void* firstPtr1 = nullptr;
501 try {
502 m_athenaPoolCnvSvc->setObjPtr(firstPtr1, &firstToken);
503 } catch(const std::exception& err) {
504 firstPtr1 = nullptr;
505 error_message = err.what();
506 }
507 if (firstPtr1 == nullptr) throw std::runtime_error("Could not get first DataHeader for token = " + firstToken.toString() + ", " + error_message);
508
509 // Get DataHeaderForm Token from the first DataHeader
510 std::unique_ptr<DataHeader_p6> firstHeader( reinterpret_cast<DataHeader_p6*>(firstPtr1) );
511 dhFormToken = firstHeader->dhFormToken();
512
513 // Read DataHeaderForm and insert it to the cache
514 formToken.fromString( dhFormToken );
515 formToken.setAuxString( m_i_poolToken->auxString() ); // set PersSvc context
516 try {
517 m_athenaPoolCnvSvc->setObjPtr(voidPtr2, &formToken);
518 } catch(const std::exception& err) {
519 voidPtr2 = nullptr;
520 error_message = err.what();
521 }
522 if (voidPtr2 == nullptr) throw std::runtime_error("Could not get DataHeaderForm for token = " + formToken.toString() + ", " + error_message);
523 m_lastGoodDHFRef[m_i_poolToken->contID()] = dhFormToken;
524 m_inputDHForms[dhFormToken].reset( reinterpret_cast<DataHeaderForm_p6*>(voidPtr2) );
525 ATH_MSG_WARNING("DataHeaderForm read exception: " << error_message << " - reusing the last good DHForm");
526 } else {
527 // try to reuse the last good DHForm Ref (object is already cached)
528 ATH_MSG_WARNING("DataHeaderForm read exception: " << error_message << " - reusing the last good DHForm");
529 }
530 header->setDhFormToken(m_lastGoodDHFRef[m_i_poolToken->contID()]);
531 return header;
532 }
533 if (voidPtr2 == nullptr) {
534 throw std::runtime_error("Could not get object for token = " + formToken.toString());
535 }
536 m_lastGoodDHFRef[m_i_poolToken->contID()] = dhFormToken;
537 }
538 m_inputDHForms[dhFormToken].reset( reinterpret_cast<DataHeaderForm_p6*>(voidPtr2) );
539 }
540 return header;
541}
static const pool::Guid DHForm_p6_Guid("7BE56CEF-C866-4BEE-9348-A5F34B5F1DAD")
std::string getSWNFromStr(const std::string &str)
std::map< std::string, std::string > m_lastGoodDHFRef
const std::string & auxString() const
Access auxiliary string.
Definition Placement.h:40
const std::string & containerName() const
Access container name.
Definition Placement.h:32
int technology() const
Access technology type.
Definition Placement.h:36
Token & setCont(const std::string &cnt)
Set container name.
Definition Token.h:71
Token & setDb(const Guid &db)
Set database name.
Definition Token.h:66
Token & setClassID(const Guid &cl_id)
Access database identifier.
Definition Token.h:75
Token & setOid(const OID_t &oid)
Set object identifier.
Definition Token.h:85
Token & setTechnology(int t)
Set technology type.
Definition Token.h:79
const OID_t & oid() const
Access object identifier.
Definition Token.h:81

◆ PoolToDataObject()

virtual StatusCode T_AthenaPoolCustomCnvWithKey< DataHeader, DataHeader_p6 >::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.

◆ poolToObject()

StatusCode T_AthenaPoolCustCnv< DataHeader, DataHeader_p6 >::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.

◆ removeBadElements()

void DataHeaderCnv::removeBadElements ( DataHeader * dh)

Remove DataHeaderElements with incomplete (dbID="") refs.

Definition at line 550 of file DataHeaderCnv.cxx.

551{
552 auto iter = dh->m_inputDataHeader.begin();
553 while( iter != dh->m_inputDataHeader.end() ) {
554 if( iter->getToken()->dbID() == Guid::null() ) {
555 ATH_MSG_WARNING("Removed incomplete Input Element");
556 iter = dh->m_inputDataHeader.erase(iter);
557 } else {
558 ++iter;
559 }
560 }
561}

◆ repSvcType()

long AthenaPoolConverter::repSvcType ( ) const
overridevirtualinherited

Definition at line 51 of file AthenaPoolConverter.cxx.

58 {
59 return pool::POOL_StorageType.type();
60}

◆ 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
183
184 while(muonitr!=muonend) {
185
186 bool hasInDet = (*muonitr)->hasInDetTrackParticle();
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();
218
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,
239 -1) ;
240
241 addTrack(t);
242 }
243
244 }
void ipCorr(double d0, double z0, double &d0c, double &z0c, double phi0, double eta, double pt)
Definition Converter.h:257

◆ selectTracks() [2/3]

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

Definition at line 111 of file Converter.h.

111 {
112
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();
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,
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
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
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,
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 108 of file AthMessaging.cxx.

29{
30 m_lvl = lvl;
31}

◆ setPlacement()

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

Set POOL placement.

◆ setPlacementForP()

Placement T_AthenaPoolCustCnv< DataHeader, DataHeader_p6 >::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 106 of file AthenaPoolConverter.cxx.

176 {
178 // Override streaming parameters from StreamTool if requested.
181 int tech = 0;
182 m_athenaPoolCnvSvc->decodeOutputSpec(outputConnectionSpec, tech).ignore();
183 // Set DB and Container names
184 placement.setFileName(outputConnectionSpec);
185
187 if( containerPrefix == "Default" ) {
189 }
192
193 // Get Technology from containerPrefix
197 }
198
199 // Override streaming parameters from StreamTool if requested.
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") {
210 } else if (thisKey == "PoolContainerPrefix") {
212 } else if (thisKey == "TopLevelContainerName") {
214 } else if (thisKey == "SubLevelBranchName") {
216 } else if (thisKey == "PoolContainerFriendPostfix") {
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
239 } else {
240 // no indexing needed (nothing points to Tags)
241 // safe to set tech here - it will not be overwritten by decodeOutput
244 }
245 }
246 // all other object types
247 else {
248 const std::string typeTok = "<type>", keyTok = "<key>";
250 if (!branchNameHint.empty()) {
251 containerName += "(" + branchNameHint + ")";
252 }
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}

◆ setToken()

virtual void T_AthenaPoolCustCnv< DataHeader, DataHeader_p6 >::setToken ( const std::string & token)
protectedvirtualinherited

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

◆ storageType()

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

Definition at line 72 of file AthenaPoolConverter.cxx.

155 {
156 return pool::POOL_StorageType.type();
157}

◆ tracks()

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

Definition at line 50 of file Converter.h.

50{return m_tracks;}

◆ transToPers()

virtual StatusCode T_AthenaPoolCustomCnvWithKey< DataHeader, DataHeader_p6 >::transToPers ( DataHeader * ,
DataHeader_p6 *&  )
inlineoverrideprotectedvirtualinherited

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

Definition at line 94 of file T_AthenaPoolCustomCnv.h.

94{ return(StatusCode::FAILURE); }

◆ updateRep()

StatusCode DataHeaderCnv::updateRep ( IOpaqueAddress * pAddress,
DataObject * pObject )
overridevirtual

Extend base-class conversion methods.

Definition at line 214 of file DataHeaderCnv.cxx.

215{
216 auto dataHeader = reinterpret_cast<DataHeader_p6*>( pObject );
217 const std::string dhRef = pAddress->par()[0];
218 const std::string dhPlacementStr = pAddress->par()[1];
219 const std::string dhFile = getFILEFromStr( dhPlacementStr );
220 Placement dhFormPlacement;
221 dhFormPlacement.fromString( dataHeader->dhFormToken() );
222 dhFormPlacement.setFileName( dhFile );
223 const std::string clientN = getSWNFromStr( dhPlacementStr );
224 if( !clientN.empty() ) {
225 // Client num in the DHForm ref means it's OneDataHeaderForm mode
226 std::string dhFormNewRef = dhFormPlacement.toString() + storeSWNInStr( clientN );
227 ATH_MSG_DEBUG("Setting DH formRef to: " << dhFormNewRef);
228 dataHeader->setDhFormToken( dhFormNewRef );
229 } else {
230 /* DH is received by the SharedWriter first and needs the DHForm object both for
231 reference (Token) and to add DHElem with the ref to itself.
232 These updates will be handled by updateRepRefs() - cache the DH info so it can
233 by used later by updateRepRefs
234 */
236 ATH_MSG_ERROR( "updateRep called but the previous DataHeader was not yet processed."
237 << " cached DH Key=" << m_sharedWriterCachedDHKey
238 << " cached DH Ref=" << m_sharedWriterCachedDHToken );
239 return StatusCode::FAILURE;
240 }
241 // remember this DH and finish processing in updateRepRefs()
242 m_sharedWriterCachedDH = dataHeader;
243 m_sharedWriterCachedDHToken = std::move(dhRef);
244 std::size_t tagBeg = dhPlacementStr.find("[KEY=") + 5;
245 std::size_t tagSize = dhPlacementStr.find(']', tagBeg) - tagBeg;
246 m_sharedWriterCachedDHKey = dhPlacementStr.substr( tagBeg, tagSize );
247 }
248 return StatusCode::SUCCESS;
249}
std::string getFILEFromStr(const std::string &str)
std::string storeSWNInStr(const std::string &str)
std::string m_sharedWriterCachedDHKey
DataHeader_p6 * m_sharedWriterCachedDH
cached values for use with SharedWriter server
std::string m_sharedWriterCachedDHToken
Placement & setFileName(const std::string &fileName)
Set file name.
Definition Placement.h:30

◆ updateRepRefs()

StatusCode DataHeaderCnv::updateRepRefs ( IOpaqueAddress * pAddress,
DataObject * pObject )
overridevirtual

Definition at line 252 of file DataHeaderCnv.cxx.

253{
255 /* Attach a DHForm to the previous DataHeader (in SharedWriter server mode)
256 Finish writing of the DataHeader by attaching the DHForm to it and by adding
257 the self reference. DHForm is passed as pObject and is cached until a new one
258 arrives. This method is called for each event after the DH is received.
259 pObject is null if there is no new DHForm for this event - in this case the old
260 one is used
261 */
262 std::string dhid = pAddress->par()[1];
263 if( pObject ) {
264 this->setToken( pAddress->par()[0] );
266 ATH_MSG_ERROR( "updateRepRefs called without DataHeaderForm" );
267 return StatusCode::FAILURE;
268 }
269 // replace the old DHForm
270 // will keep this DHForm until a new one arrives
271 m_sharedWriterCachedDHForm[dhid].reset( reinterpret_cast<DataHeaderForm_p6*>( pObject ) );
272 m_sharedWriterCachedDHForm[dhid]->setToken( pAddress->par()[0] );
273 }
275 ATH_MSG_ERROR( "updateRepRefs: missing DataHeaderForm for DH ID=" << dhid );
276 return StatusCode::FAILURE;
277 }
278 // update the cached DataHeader (can be done until a commit is called)
279 m_sharedWriterCachedDH->setDhFormToken( m_sharedWriterCachedDHForm[dhid]->getToken() );
282 // this DataHeader object is now fully processed, so forget it
283 m_sharedWriterCachedDH = nullptr;
284 }
285 else {
286 // In OneDataHeaderForm mode - keep the DHForms from all clients and write them out at the end
287 m_persFormMap[ pAddress->par()[1] ].reset( reinterpret_cast<DataHeaderForm_p6*>( pObject ) );
288 }
289 return(StatusCode::SUCCESS);
290}
std::map< std::string, std::unique_ptr< DataHeaderForm_p6 > > m_sharedWriterCachedDHForm
map of cached DHForms for DataHeader ID
virtual void setToken(const std::string &token)

◆ CnvFactory< DataHeaderCnv >

friend class CnvFactory< DataHeaderCnv >
friend

Definition at line 30 of file DataHeaderCnv.h.

Member Data Documentation

◆ ATLAS_THREAD_SAFE

std::atomic_flag m_initialized AthMessaging::ATLAS_THREAD_SAFE
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

Guid T_AthenaPoolCustCnv< DataHeader, DataHeader_p6 >::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_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_dhFormMdx

std::string DataHeaderCnv::m_dhFormMdx
protected

Definition at line 89 of file DataHeaderCnv.h.

◆ m_dhFormType

RootType DataHeaderCnv::m_dhFormType
protected

cached shape of the DataHeaderForm_pN

Definition at line 69 of file DataHeaderCnv.h.

◆ m_dhInForm5

std::unique_ptr<DataHeaderForm_p5> DataHeaderCnv::m_dhInForm5
protected

Definition at line 88 of file DataHeaderCnv.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
mutableprivateinherited

MessageSvc pointer.

Definition at line 135 of file AthMessaging.h.

135{ nullptr };

◆ m_inDHFMapMaxsize

unsigned DataHeaderCnv::m_inDHFMapMaxsize {}
protected

Max DHForms to cache per input file.

Definition at line 82 of file DataHeaderCnv.h.

82{};

◆ m_inDHFormCount

std::map<std::string, unsigned> DataHeaderCnv::m_inDHFormCount
protected

How many DHForms for an input file are in the cache.

Definition at line 80 of file DataHeaderCnv.h.

◆ m_inputDHForms

std::map<std::string, std::unique_ptr<DataHeaderForm_p6> > DataHeaderCnv::m_inputDHForms
protected

DHForm cache indexed by the DHForm reference (from DataHeader) that was used to read it.

Definition at line 77 of file DataHeaderCnv.h.

◆ m_lastGoodDHFRef

std::map< std::string, std::string> DataHeaderCnv::m_lastGoodDHFRef
protected

Definition at line 84 of file DataHeaderCnv.h.

◆ m_lvl

std::atomic<MSG::Level> AthMessaging::m_lvl
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_oneDHForm

bool DataHeaderCnv::m_oneDHForm = true
protected

if true write only one DataHeaderForm at the end (stop, finalize, or WriteDataHeaderForms incident) the value is read from AthenaPoolCnvSvc OneDataHeaderForm property

Definition at line 72 of file DataHeaderCnv.h.

◆ m_persFormMap

std::map<std::string, std::unique_ptr<DataHeaderForm_p6>, placementComp > DataHeaderCnv::m_persFormMap
protected

Definition at line 75 of file DataHeaderCnv.h.

◆ m_persObjLists

std::map<std::string, std::vector< std::unique_ptr<DataHeader_p6> > > T_AthenaPoolCustomCnvWithKey< DataHeader, DataHeader_p6 >::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

std::mutex T_AthenaPoolCustomCnvWithKey< DataHeader, DataHeader_p6 >::m_pListMutex
protectedinherited

protection mutex for m_persObjLists

Definition at line 123 of file T_AthenaPoolCustomCnv.h.

◆ m_sharedWriterCachedDH

DataHeader_p6* DataHeaderCnv::m_sharedWriterCachedDH = nullptr
protected

cached values for use with SharedWriter server

Definition at line 92 of file DataHeaderCnv.h.

◆ m_sharedWriterCachedDHForm

std::map< std::string, std::unique_ptr<DataHeaderForm_p6> > DataHeaderCnv::m_sharedWriterCachedDHForm
protected

map of cached DHForms for DataHeader ID

Definition at line 94 of file DataHeaderCnv.h.

◆ m_sharedWriterCachedDHKey

std::string DataHeaderCnv::m_sharedWriterCachedDHKey
protected

Definition at line 95 of file DataHeaderCnv.h.

◆ m_sharedWriterCachedDHToken

std::string DataHeaderCnv::m_sharedWriterCachedDHToken
protected

Definition at line 96 of file DataHeaderCnv.h.

◆ m_tpInConverter

DataHeaderCnv_p6 DataHeaderCnv::m_tpInConverter
protected

Definition at line 66 of file DataHeaderCnv.h.

◆ m_tpInConverter_p5

DataHeaderCnv_p5 DataHeaderCnv::m_tpInConverter_p5
protected

for use when reading DataHeader_p5

Definition at line 87 of file DataHeaderCnv.h.

◆ m_tpOutConverter

DataHeaderCnv_p6 DataHeaderCnv::m_tpOutConverter
protected

Definition at line 65 of file DataHeaderCnv.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: