ATLAS Offline Software
Classes | Public Types | Public Member Functions | Static Public Member Functions | Protected Types | Protected Member Functions | Protected Attributes | Private Member Functions | Private Attributes | Friends | List of all members
DataHeaderCnv Class Referenceabstract

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

#include <DataHeaderCnv.h>

Inheritance diagram for DataHeaderCnv:
Collaboration diagram for DataHeaderCnv:

Classes

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

Public Types

typedef T_AthenaPoolCustCnv< TRANS, PERSBaseType
 

Public Member Functions

 DataHeaderCnv (ISvcLocator *svcloc)
 
 ~DataHeaderCnv ()
 
virtual StatusCode initialize () override
 Gaudi Service Interface method implementations: More...
 
virtual StatusCode updateRep (IOpaqueAddress *pAddress, DataObject *pObject) override
 Extend base-class conversion methods. More...
 
virtual StatusCode updateRepRefs (IOpaqueAddress *pAddress, DataObject *pObject) override
 
virtual StatusCode DataObjectToPool (IOpaqueAddress *pAddr, DataObject *pObj) override
 Write an object into POOL. More...
 
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. More...
 
void clearInputDHFormCache (const std::string &dbGuid)
 Delete cached DHForms for a given input file GUID. More...
 
void removeBadElements (DataHeader *dh)
 Remove DataHeaderElements with incomplete (dbID="") refs. More...
 
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. More...
 
virtual StatusCode createRep (DataObject *pObj, IOpaqueAddress *&pAddr) override
 Create a POOL persistent representation for a transient object. More...
 
virtual StatusCode fillRepRefs (IOpaqueAddress *pAddr, DataObject *pObj) override
 Create a POOL persistent representation for a transient object. More...
 
const ServiceHandle< StoreGateSvc > & detStore () const
 Handle to DetectorStore. More...
 
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. More...
 
MsgStream & msg () const
 The standard message stream. More...
 
MsgStream & msg (const MSG::Level lvl) const
 The standard message stream. More...
 
void setLevel (MSG::Level lvl)
 Change the current logging level. More...
 

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 PERScreatePersistent (TRANS *obj)=0
 
virtual PERScreatePersistentWithKey (TRANS *obj, const std::string &) override
 method to be implemented by the developer. More...
 
virtual TRANS * createTransientWithKey (const std::string &) override
 method to be implemented by the developer. More...
 
template<class P >
P * poolReadObject ()
 Read object of type P. More...
 
template<class P >
void poolReadObject (TopLevelTPCnvBase &tlp_converter)
 Read object of type P (plus all extending objects) using the indicated top-level TP converter. More...
 
void keepPoolObj (PERS *obj, const std::string &output)
 Remember the POOL object to be written out (will be deleted after commit) More...
 
virtual StatusCode transToPers (TRANS *, PERS *&) override
 Obsolete methods replaced by createPersistent() and createTransient() obsolete. More...
 
virtual StatusCode persToTrans (TRANS *&, PERS *) override
 obsolete More...
 
virtual StatusCode DataObjectToPers (DataObject *pObj, IOpaqueAddress *&pAddr) override
 Convert an object into Persistent. More...
 
virtual StatusCode PoolToDataObject (DataObject *&pObj, const Token *token, const std::string &key) override
 Read an object from POOL. More...
 
virtual StatusCode cleanUp (const std::string &output) override
 Callback from the CleanupSvc to delete persistent object in the local list. More...
 
template<class P >
Placement setPlacementForP (P &p, const std::string &key, const std::string &output)
 Set POOL placement for type P. More...
 
template<class P >
StatusCode objectToPool (P *pObj, Token *&token, const std::string &key, const std::string &output)
 Write an object into POOL returning its token. More...
 
template<class P >
StatusCode poolToObject (const Token *&token, P *&pObj)
 Read an object from POOL. More...
 
virtual bool compareClassGuid (const Guid &clid) const
 Compare POOL class GUID with the one of the object being read. More...
 
virtual void setToken (const std::string &token)
 Set the token (in std::string representation) and classID for the object that will be read next. More...
 
virtual Placement setPlacement (const std::string &key, const std::string &output)
 Set POOL placement. More...
 
virtual Placement setPlacementWithType (const std::string &tname, const std::string &key, const std::string &output)
 Set POOL placement hint for a given type. More...
 
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 More...
 
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 More...
 
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. More...
 
std::map< std::string, unsigned > m_inDHFormCount
 How many DHForms for an input file are in the cache. More...
 
unsigned m_inDHFMapMaxsize
 Max DHForms to cache per input file. More...
 
std::map< std::string, std::string > m_lastGoodDHFRef
 
DataHeaderCnv_p5 m_tpInConverter_p5
 for use when reading DataHeader_p5 More...
 
std::unique_ptr< DataHeaderForm_p5m_dhInForm5
 
std::string m_dhFormMdx
 
DataHeader_p6m_sharedWriterCachedDH = nullptr
 cached values for use with SharedWriter server More...
 
std::map< std::string, std::unique_ptr< DataHeaderForm_p6 > > m_sharedWriterCachedDHForm
 map of cached DHForms for DataHeader ID More...
 
std::string m_sharedWriterCachedDHKey
 
std::string m_sharedWriterCachedDHToken
 
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. More...
 
std::mutex m_pListMutex
 protection mutex for m_persObjLists More...
 
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. More...
 

Private Attributes

std::map< DataObject *, PERS * > m_persMap
 
std::string m_nm
 Message source name. More...
 
boost::thread_specific_ptr< MsgStream > m_msg_tls
 MsgStream instance (a std::cout like with print-out levels) More...
 
std::atomic< IMessageSvc * > m_imsg { nullptr }
 MessageSvc pointer. More...
 
std::atomic< MSG::Level > m_lvl { MSG::NIL }
 Current logging level. More...
 
std::atomic_flag m_initialized ATLAS_THREAD_SAFE = ATOMIC_FLAG_INIT
 Messaging initialized (initMessaging) More...
 

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

template<class TRANS , class PERS >
typedef T_AthenaPoolCustCnv<TRANS, PERS> T_AthenaPoolCustomCnvWithKey< TRANS, PERS >::BaseType
inherited

Definition at line 41 of file T_AthenaPoolCustomCnv.h.

◆ 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 30 of file DataHeaderCnv.cxx.

30  :
31  DataHeaderCnvBase(svcloc, "DataHeaderCnv")
32 {
33  m_classDesc = RootType( "DataHeader_p6" );
34 }

◆ ~DataHeaderCnv()

DataHeaderCnv::~DataHeaderCnv ( )

Definition at line 37 of file DataHeaderCnv.cxx.

38 {
39  // Remove itself from the IncidentSvc - if it is still around
40  ServiceHandle<IIncidentSvc> incSvc("IncidentSvc", "DataHeaderCnv");
41  if( incSvc.retrieve().isSuccess() ) {
42  incSvc->removeListener(this, IncidentType::EndInputFile);
43  }
44 }

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  }

◆ classID()

template<class TRANS , class PERS >
static 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();}

◆ clearInputDHFormCache()

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

Delete cached DHForms for a given input file GUID.

Definition at line 146 of file DataHeaderCnv.cxx.

147 {
148  auto iter = m_inputDHForms.begin();
149  while( iter != m_inputDHForms.end() ) {
150  size_t dbpos = iter->first.find("[DB=");
151  if( dbpos != std::string::npos && iter->first.compare(dbpos+4, dbpos+36, dbGuid) == 0 ) {
152  iter = m_inputDHForms.erase( iter );
153  } else {
154  iter++;
155  }
156  }
157  m_inDHFormCount[ dbGuid ] = 0;
158 }

◆ 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< LArHVScaleCorrComplete, LArConditionsSubset< LArSingleFloatP >, LArSingleFloatSubset_p1 >, and T_AthenaPoolCoolMultChanCnv< TransientClass, LArConditionsSubset< LArSingleFloatP >, LArSingleFloatSubset_p1 >.

Definition at line 61 of file AthenaPoolConverter.cxx.

61  {
62  TokenAddress* tokAddr = dynamic_cast<TokenAddress*>(pAddr);
63 
64  bool ownTokAddr = false;
65  if (tokAddr == nullptr || tokAddr->getToken() == nullptr) {
66  ownTokAddr = true;
67  Token* token = new Token;
68  token->fromString(*(pAddr->par()));
69  GenericAddress* genAddr = dynamic_cast<GenericAddress*>(pAddr);
70  if (not genAddr){
71  ATH_MSG_ERROR("Dynamic cast failed in AthenaPoolConverter::createObj");
72  //clean up
73  delete token;
74  return StatusCode::FAILURE;
75  }
76  tokAddr = new TokenAddress(*genAddr, token);
77  }
78  if( tokAddr->ipar()[0] > 0 and tokAddr->getToken()->auxString().empty() ) {
79  char text[32];
80  ::sprintf(text, "[CTXT=%08X]", static_cast<int>(*(pAddr->ipar())));
81  tokAddr->getToken()->setAuxString(text);
82  }
83  ATH_MSG_VERBOSE("createObj: " << tokAddr->getToken()->toString() << ", CTX=" << tokAddr->ipar()[0]
84  << ", auxStr=" << tokAddr->getToken()->auxString() );
85  std::lock_guard<CallMutex> lock(m_conv_mut);
86  m_i_poolToken = tokAddr->getToken();
87  try {
88  std::string key = pAddr->par()[1];
89  if (!PoolToDataObject(pObj, tokAddr->getToken(), key).isSuccess()) {
90  ATH_MSG_ERROR("createObj PoolToDataObject() failed, Token = " << (tokAddr->getToken() ? tokAddr->getToken()->toString() : "NULL"));
91  pObj = nullptr;
92  }
93  } catch (std::exception& e) {
94  ATH_MSG_ERROR("createObj - caught exception: " << e.what());
95  pObj = nullptr;
96  }
97  if (pObj == nullptr) {
98  ATH_MSG_ERROR("createObj failed to get DataObject, Token = " << (tokAddr->getToken() ? tokAddr->getToken()->toString() : "NULL"));
99  }
100  if (ownTokAddr) {
101  delete tokAddr; tokAddr = nullptr;
102  }
103  m_i_poolToken = nullptr;
104  if (pObj == nullptr) {
105  return(StatusCode::FAILURE);
106  }
107  return(StatusCode::SUCCESS);
108 }

◆ createPersistent() [1/3]

virtual DataHeader_p6* DataHeaderCnv::createPersistent ( DataHeader )
inlineoverridevirtual

Definition at line 53 of file DataHeaderCnv.h.

53 { return nullptr; }

◆ createPersistent() [2/3]

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

Definition at line 535 of file DataHeaderCnv.cxx.

536 {
537  return m_tpOutConverter.createPersistent( transObj, *dh_form );
538 }

◆ createPersistent() [3/3]

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

Implemented in ZdcRawChannelCollectionCnv, TruthParticleContainerCnv, TruthEtIsolationsContainerCnv, TRTUncompressedHitCollectionCnv, TrigTauTracksInfoCnv, TrigTauClusterDetailsCnv, TrigTauClusterCnv, TrigTauCnv, TrigRoiDescriptorCollectionCnv, TrigRoiDescriptorCnv, TrigRNNOutputCnv, TrigOperationalInfoCollectionCnv, TrigOperationalInfoCnv, TrigMonEventCollectionCnv, TrigMonEventCnv, TrigMonConfigCollectionCnv, TrigMonConfigCnv, TrigEMClusterCnv, TrigCompositeCnv, T_AthenaPoolViewVectorCnv< DV >, T_AthenaPoolLegacyCnv< TRANS, PERS, LEGACY >::LegacyCnv, T_AthenaPoolLegacyCnv< TRANS, PERS, LEGACY >, TrackRecordCollectionCnv, TileTTL1ContainerCnv, TileRawChannelContainerCnv, TileMuonReceiverContainerCnv, TileMuContainerCnv, TileL2ContainerCnv, TileHitVectorCnv, TileHitContainerCnv, TileDigitsContainerCnv, TileCosmicMuonContainerCnv, TileBeamElemContainerCnv, LArRawEventContainerCnv< T, P, C >, MuonRdoContainerTPCnv< T, P, CONV >, SimulationHitCollectionCnv, SiHitCollectionCnv, RingerRingsCnv, RecoTimingObjCnv, MuonSpShowerContainerCnv, PhotonContainerCnv, MuonCaloEnergyContainerCnv, MissingEtTruthCnv, MissingEtCaloCnv, MissingETCnv, McEventCollectionCnv, LArTTL1ContainerCnv, LArHitFloatContainerCnv, LArHitContainerCnv, IParticleLinkContainerCnv, InDetLowBetaCandidateCnv, INav4MomLinkContainerCnv, INav4MomAssocsCnv, ElectronContainerCnv, egDetailContainerCnv, egammaContainerCnv, eflowObjectContainerCnv, CaloRingsContainerCnv, CaloCalibrationHitContainerCnv, BCM_RDO_ContainerCnv, AthExFatObjectCnv, AthExElephantinoCnv, AthExDecayCnv, MuonContainerCnv, TauJetContainerCnv, TauDetailsContainerCnv, ALFA_ODHitCollectionCnv, ALFA_ODDigitCollectionCnv, ALFA_LocRecODEvCollectionCnv, ALFA_LocRecEvCollectionCnv, ALFA_LocRecCorrODEvCollectionCnv, ALFA_LocRecCorrEvCollectionCnv, ALFA_HitCollectionCnv, ALFA_GloRecEvCollectionCnv, ALFA_DigitCollectionCnv, ALFA_CLinkEventCnv, AFP_TDSimHitCollectionCnv, AFP_TDLocRecoEvCollectionCnv, AFP_TDDigiCollectionCnv, AFP_SIDSimHitCollectionCnv, AFP_SIDLocRecoEvCollectionCnv, and AFP_SiDigiCollectionCnv.

◆ 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< LArHVScaleCorrComplete, LArConditionsSubset< LArSingleFloatP >, LArSingleFloatSubset_p1 >, and T_AthenaPoolCoolMultChanCnv< TransientClass, LArConditionsSubset< LArSingleFloatP >, LArSingleFloatSubset_p1 >.

Definition at line 110 of file AthenaPoolConverter.cxx.

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

◆ createTransient()

DataHeader * DataHeaderCnv::createTransient ( )
overridevirtual

Implements T_AthenaPoolCustomCnv< TRANS, PERS >.

Definition at line 555 of file DataHeaderCnv.cxx.

555  {
556  if (this->m_i_poolToken == nullptr) {
557  return(nullptr);
558  }
559  if (this->m_i_poolToken->technology() == 0x00001000) { // Artificial ByteStream DataHeader Token
560  DataHeader* dh = new DataHeader();
561  std::string bestPfn, fileType;
562  m_athenaPoolCnvSvc->getPoolSvc()->lookupBestPfn(this->m_i_poolToken->dbID().toString(), bestPfn, fileType);
563  const Token* copy = new Token(this->m_i_poolToken);
565  dh->insert(dhe);
566  return(dh);
567  }
568  static const pool::Guid p6_guid("4DDBD295-EFCE-472A-9EC8-15CD35A9EB8D");
569  static const pool::Guid p5_guid("D82968A1-CF91-4320-B2DD-E0F739CBC7E6");
570  static const pool::Guid p4_guid("9630EB7B-CCD7-47D9-A39B-CBBF4133CDF2");
571  static const pool::Guid p3_guid("EC1318F0-8E28-45F8-9A2D-2597C1CC87A6");
572  try {
573  if( compareClassGuid( p6_guid ) ) {
574  std::unique_ptr<DataHeader_p6> header( poolReadObject_p6() );
575  auto dhForm = m_inputDHForms[ header->dhFormToken() ].get();
576  auto dh = m_tpInConverter.createTransient( header.get(), *dhForm, m_i_poolToken );
578  // To dump the DataHeader uncomment below
579  // std::ostringstream ss; dh->dump(ss); std::cout << ss.str() << std::endl;
580  return dh;
581  } else if (this->compareClassGuid( p5_guid )) {
582  std::unique_ptr<DataHeader_p5> obj_p5( poolReadObject_p5() );
583  return m_tpInConverter_p5.createTransient( *obj_p5, *m_dhInForm5 ).release();
584  } else if (this->compareClassGuid( p4_guid )) {
585  std::unique_ptr<DataHeader_p4> obj_p4(this->poolReadObject<DataHeader_p4>());
586  DataHeaderCnv_p4 tPconverter_p4;
587  return(tPconverter_p4.createTransient(obj_p4.get()));
588  } else if (this->compareClassGuid( p3_guid )) {
589  std::unique_ptr<DataHeader_p3> obj_p3(this->poolReadObject<DataHeader_p3>());
590  DataHeaderCnv_p3 tPconverter_p3;
591  return(tPconverter_p3.createTransient(obj_p3.get()));
592  }
593  } catch (std::exception &e) {
594  // upgrade all exceptions to runtime_error (who needs that? MN)
595  std::string error = e.what();
596  throw std::runtime_error(error);
597  }
598  return(nullptr);
599 }

◆ 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()

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 286 of file DataHeaderCnv.cxx.

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

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

Reimplemented in T_AthenaPoolCoolMultChanCnv< COLL_T, ELEM_T, ELEM_P >, T_AthenaPoolCoolMultChanCnv< LArHVScaleCorrComplete, LArConditionsSubset< LArSingleFloatP >, LArSingleFloatSubset_p1 >, and T_AthenaPoolCoolMultChanCnv< TransientClass, LArConditionsSubset< LArSingleFloatP >, LArSingleFloatSubset_p1 >.

Definition at line 139 of file AthenaPoolConverter.cxx.

139  {
140  std::lock_guard<CallMutex> lock(m_conv_mut);
141  try {
142  if (!DataObjectToPool(pAddr, pObj).isSuccess()) {
143  ATH_MSG_ERROR("FillRepRefs failed, key = " << pObj->name());
144  return(StatusCode::FAILURE);
145  }
146  } catch (std::exception& e) {
147  ATH_MSG_ERROR("fillRepRefs - caught exception: " << e.what());
148  return(StatusCode::FAILURE);
149  }
150  return(StatusCode::SUCCESS);
151 }

◆ finalize()

StatusCode AthenaPoolConverter::finalize ( )
overridevirtualinherited

Definition at line 49 of file AthenaPoolConverter.cxx.

49  {
50  // Release AthenaPoolCnvSvc
51  if (!m_athenaPoolCnvSvc.release().isSuccess()) {
52  ATH_MSG_WARNING("Cannot release AthenaPoolCnvSvc.");
53  }
54  return(::Converter::finalize());
55 }

◆ getDataObject()

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

Definition at line 267 of file AthenaPoolConverter.cxx.

267  {
268  return(m_dataObject);
269 }

◆ handle()

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

Incident service handle listening for EndInputFile.

Definition at line 86 of file DataHeaderCnv.cxx.

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

◆ initialize()

StatusCode DataHeaderCnv::initialize ( )
overridevirtual

Gaudi Service Interface method implementations:

Reimplemented from T_AthenaPoolCustCnv< TRANS, PERS >.

Definition at line 46 of file DataHeaderCnv.cxx.

47 {
48  // Read properties from the ConversionSvc
49  m_inDHFMapMaxsize = 100; // default DHForm cache size
50  bool doFilterDHAliases = true;
51  SmartIF<IProperty> cnvSvc{service("AthenaPoolCnvSvc")};
52  if( cnvSvc ) {
53  IntegerProperty sizeProp("maxDHFormCacheSize", m_inDHFMapMaxsize);
54  if( cnvSvc->getProperty(&sizeProp).isSuccess() ) {
55  m_inDHFMapMaxsize = sizeProp.value();
56  }
57  BooleanProperty aliasFilterProp("doFilterDHAliases", doFilterDHAliases);
58  if( cnvSvc->getProperty(&aliasFilterProp).isSuccess() ) {
59  doFilterDHAliases = aliasFilterProp.value();
60  }
61  BooleanProperty oneDHForm("OneDataHeaderForm", m_oneDHForm);
62  if( cnvSvc->getProperty(&oneDHForm).isSuccess() ) {
63  m_oneDHForm = oneDHForm.value();
64  }
65  }
66  ATH_MSG_VERBOSE("Using DHForm cache size: " << m_inDHFMapMaxsize);
67  if( doFilterDHAliases ) {
68  ATH_MSG_VERBOSE("Will filter SG Aux aliases in DataHeader");
69  } else {
70  ATH_MSG_VERBOSE("Will NOT filter SG Aux aliases in DataHeader");
71  }
72  m_tpOutConverter.setSGAliasFiltering( doFilterDHAliases );
73 
74  // Get IncidentSvc
75  ServiceHandle<IIncidentSvc> incSvc("IncidentSvc", "DataHeaderCnv");
76  ATH_CHECK( incSvc.retrieve() );
77  // Listen to EndInputFile incidents to clear old DataHeaderForms from the cache
78  incSvc->addListener(this, IncidentType::EndInputFile, 0);
79  incSvc->addListener(this, "PreFork", 0);
80  // Listen to WriteDataHeaderForms incidents to flush DHForms after
81  incSvc->addListener(this, "WriteDataHeaderForms", 0);
83 }

◆ 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  m_lvl = m_imsg ?
43  static_cast<MSG::Level>( m_imsg.load()->outputLevel(m_nm) ) :
44  MSG::INFO;
45 }

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

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

165 {
166  MsgStream* ms = m_msg_tls.get();
167  if (!ms) {
168  if (!m_initialized.test_and_set()) initMessaging();
169  ms = new MsgStream(m_imsg,m_nm);
170  m_msg_tls.reset( ms );
171  }
172 
173  ms->setLevel (m_lvl);
174  return *ms;
175 }

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

180 { 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 151 of file AthMessaging.h.

152 {
153  if (!m_initialized.test_and_set()) initMessaging();
154  if (m_lvl <= lvl) {
155  msg() << lvl;
156  return true;
157  } else {
158  return false;
159  }
160 }

◆ objectToPool()

template<class TRANS , class PERS >
template<class P >
StatusCode T_AthenaPoolCustCnv< TRANS, PERS >::objectToPool ( P *  pObj,
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); }

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

template<class TRANS , class PERS >
template<class P >
P* T_AthenaPoolCustomCnvWithKey< TRANS, PERS >::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]

template<class TRANS , class PERS >
template<class P >
void T_AthenaPoolCustomCnvWithKey< TRANS, PERS >::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 393 of file DataHeaderCnv.cxx.

394 {
395  void* voidPtr1 = nullptr;
396  m_athenaPoolCnvSvc->setObjPtr(voidPtr1, m_i_poolToken);
397  if (voidPtr1 == nullptr) {
398  throw std::runtime_error("Could not get object for token = " + m_i_poolToken->toString());
399  }
400  std::unique_ptr<DataHeader_p5> header( reinterpret_cast<DataHeader_p5*>(voidPtr1) );
401 
402  void* voidPtr2 = nullptr;
403  Token mapToken;
404  mapToken.fromString( header->dhFormToken() );
405  mapToken.setAuxString( m_i_poolToken->auxString() ); // set PersSvc context
406  if (mapToken.classID() != Guid::null()) {
407  if( header->dhFormMdx() != m_dhFormMdx ) {
408  m_athenaPoolCnvSvc->setObjPtr(voidPtr2, &mapToken);
409  if (voidPtr2 == nullptr) {
410  throw std::runtime_error("Could not get object for token = " + mapToken.toString());
411  }
412  m_dhInForm5.reset( reinterpret_cast<DataHeaderForm_p5*>(voidPtr2) );
413  m_dhFormMdx = header->dhFormMdx();
414  }
415  }
416  return header;
417 }

◆ poolReadObject_p6()

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

Definition at line 422 of file DataHeaderCnv.cxx.

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

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

◆ removeBadElements()

void DataHeaderCnv::removeBadElements ( DataHeader dh)

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

Definition at line 541 of file DataHeaderCnv.cxx.

542 {
543  auto iter = dh->m_inputDataHeader.begin();
544  while( iter != dh->m_inputDataHeader.end() ) {
545  if( iter->getToken()->dbID() == Guid::null() ) {
546  ATH_MSG_WARNING("Removed incomplete Input Element");
547  iter = dh->m_inputDataHeader.erase(iter);
548  } else {
549  ++iter;
550  }
551  }
552 }

◆ repSvcType()

long AthenaPoolConverter::repSvcType ( ) const
overridevirtualinherited

Definition at line 57 of file AthenaPoolConverter.cxx.

57  {
58  return(POOL_StorageType);
59 }

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

◆ 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 174 of file AthenaPoolConverter.cxx.

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

◆ setToken()

template<class TRANS , class PERS >
virtual void T_AthenaPoolCustCnv< TRANS, PERS >::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

Reimplemented in T_AthenaPoolCoolMultChanCnv< COLL_T, ELEM_T, ELEM_P >, T_AthenaPoolCoolMultChanCnv< LArHVScaleCorrComplete, LArConditionsSubset< LArSingleFloatP >, LArSingleFloatSubset_p1 >, and T_AthenaPoolCoolMultChanCnv< TransientClass, LArConditionsSubset< LArSingleFloatP >, LArSingleFloatSubset_p1 >.

◆ storageType()

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

Definition at line 153 of file AthenaPoolConverter.cxx.

153  {
154  return(POOL_StorageType);
155 }

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

◆ updateRep()

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

Extend base-class conversion methods.

Definition at line 206 of file DataHeaderCnv.cxx.

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

◆ updateRepRefs()

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

Definition at line 244 of file DataHeaderCnv.cxx.

245 {
246  if( m_sharedWriterCachedDH ) {
247  /* Attach a DHForm to the previous DataHeader (in SharedWriter server mode)
248  Finish writing of the DataHeader by attaching the DHForm to it and by adding
249  the self reference. DHForm is passed as pObject and is cached until a new one
250  arrives. This method is called for each event after the DH is received.
251  pObject is null if there is no new DHForm for this event - in this case the old
252  one is used
253  */
254  static const pool::Guid dhf_p6_guid("7BE56CEF-C866-4BEE-9348-A5F34B5F1DAD");
255  std::string dhid = pAddress->par()[1];
256  if( pObject ) {
257  this->setToken( pAddress->par()[0] );
258  if( !compareClassGuid( dhf_p6_guid ) ) {
259  ATH_MSG_ERROR( "updateRepRefs called without DataHeaderForm" );
260  return StatusCode::FAILURE;
261  }
262  // replace the old DHForm
263  // will keep this DHForm until a new one arrives
264  m_sharedWriterCachedDHForm[dhid].reset( reinterpret_cast<DataHeaderForm_p6*>( pObject ) );
265  m_sharedWriterCachedDHForm[dhid]->setToken( pAddress->par()[0] );
266  }
267  if( m_sharedWriterCachedDHForm.find(dhid) == m_sharedWriterCachedDHForm.end() ) {
268  ATH_MSG_ERROR( "updateRepRefs: missing DataHeaderForm for DH ID=" << dhid );
269  return StatusCode::FAILURE;
270  }
271  // update the cached DataHeader (can be done until a commit is called)
275  // this DataHeader object is now fully processed, so forget it
276  m_sharedWriterCachedDH = nullptr;
277  }
278  else {
279  // In OneDataHeaderForm mode - keep the DHForms from all clients and write them out at the end
280  m_persFormMap[ pAddress->par()[1] ].reset( reinterpret_cast<DataHeaderForm_p6*>( pObject ) );
281  }
282  return(StatusCode::SUCCESS);
283 }

Friends And Related Function Documentation

◆ 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 = 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_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 { nullptr }
mutableprivateinherited

MessageSvc pointer.

Definition at line 135 of file AthMessaging.h.

◆ m_inDHFMapMaxsize

unsigned DataHeaderCnv::m_inDHFMapMaxsize
protected

Max DHForms to cache per input file.

Definition at line 82 of file DataHeaderCnv.h.

◆ 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 { MSG::NIL }
mutableprivateinherited

Current logging level.

Definition at line 138 of file AthMessaging.h.

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

template<class TRANS , class PERS >
std::map<DataObject*, PERS*> T_AthenaPoolCustCnv< TRANS, PERS >::m_persMap
privateinherited

Definition at line 103 of file T_AthenaPoolCustCnv.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_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:
AthMessaging::m_lvl
std::atomic< MSG::Level > m_lvl
Current logging level.
Definition: AthMessaging.h:138
getFILEFromStr
std::string getFILEFromStr(const std::string &str)
Definition: DataHeaderCnv.cxx:174
Trk::numberOfPixelHits
@ numberOfPixelHits
number of pixel layers on track with absence of hits
Definition: Tracking/TrkEvent/TrkTrackSummary/TrkTrackSummary/TrackSummary.h:57
DataHeaderForm_p6
This class provides storage for the constant fields of the persistent DataHeader class.
Definition: DataHeader_p6.h:27
AthenaPoolConverter::setPlacementWithType
virtual Placement setPlacementWithType(const std::string &tname, const std::string &key, const std::string &output)
Set POOL placement hint for a given type.
Definition: AthenaPoolConverter.cxx:174
DataHeaderCnv::m_persFormMap
std::map< std::string, std::unique_ptr< DataHeaderForm_p6 >, placementComp > m_persFormMap
Definition: DataHeaderCnv.h:75
AllowedVariables::e
e
Definition: AsgElectronSelectorTool.cxx:37
DataHeaderCnv_p6::createTransient
DataHeader * createTransient(const DataHeader_p6 *persObj, const DataHeaderForm_p6 &form, const Token *dhToken)
Definition: DataHeaderCnv_p6.cxx:61
AthenaPoolConverter::m_dataObject
const DataObject * m_dataObject
Definition: AthenaPoolConverter.h:129
CalculateHighPtTerm.pT
pT
Definition: ICHEP2016/CalculateHighPtTerm.py:57
Converter::ipCorr
void ipCorr(double d0, double z0, double &d0c, double &z0c, double phi0, double eta, double pt)
Definition: Converter.h:257
DataHeaderCnv_p6::setSGAliasFiltering
void setSGAliasFiltering(bool doFiltering)
Definition: DataHeaderCnv_p6.h:41
Guid::null
static const Guid & null()
NULL-Guid: static class method.
Definition: Guid.cxx:18
python.tests.PyTestsLib.finalize
def finalize(self)
_info( "content of StoreGate..." ) self.sg.dump()
Definition: PyTestsLib.py:50
ATH_MSG_FATAL
#define ATH_MSG_FATAL(x)
Definition: AthMsgStreamMacros.h:34
DataModel_detail::const_iterator
Const iterator class for DataVector/DataList.
Definition: DVLIterator.h:82
Placement
This class holds all the necessary information to guide the writing of an object in a physical place.
Definition: Placement.h:19
DataHeaderForm_p6::isModified
bool isModified() const
Definition: DataHeader_p6.cxx:135
storeSWNInStr
std::string storeSWNInStr(const std::string &str)
Definition: DataHeaderCnv.cxx:183
Trk::numberOfTRTHighThresholdHits
@ numberOfTRTHighThresholdHits
total number of TRT hits which pass the high threshold
Definition: Tracking/TrkEvent/TrkTrackSummary/TrkTrackSummary/TrackSummary.h:87
AthenaPoolConverter::DataObjectToPool
virtual StatusCode DataObjectToPool(IOpaqueAddress *pAddr, DataObject *pObj)=0
Write an object into POOL.
Converter::m_beamY
double m_beamY
Definition: Converter.h:320
header
Definition: hcg.cxx:526
StateLessPT_NewConfig.proxy
proxy
Definition: StateLessPT_NewConfig.py:392
DataHeaderCnv::m_sharedWriterCachedDHToken
std::string m_sharedWriterCachedDHToken
Definition: DataHeaderCnv.h:96
Placement::containerName
const std::string & containerName() const
Access container name.
Definition: Placement.h:32
phi
Scalar phi() const
phi method
Definition: AmgMatrixBasePlugin.h:67
vtune_athena.format
format
Definition: vtune_athena.py:14
DataHeaderForm_p6::setVersion
void setVersion(const DHVersions ver)
change version if writing backward compatible format
Definition: DataHeader_p6.h:88
Token::contID
const std::string & contID() const
Access container identifier.
Definition: Token.h:67
SG::fromStorable
bool fromStorable(DataObject *pDObj, T *&pTrans, bool quiet=false, IRegisterTransient *irt=0, bool isConst=true)
Definition: StorableConversions.h:180
APRDefaults::RNTupleNames::DataHeader
static constexpr const char * DataHeader
Definition: APRDefaults.h:20
AthenaPoolConverter::m_athenaPoolCnvSvc
ServiceHandle< IAthenaPoolCnvSvc > m_athenaPoolCnvSvc
Definition: AthenaPoolConverter.h:117
eta
Scalar eta() const
pseudorapidity method
Definition: AmgMatrixBasePlugin.h:83
DataHeaderCnv::m_dhFormMdx
std::string m_dhFormMdx
Definition: DataHeaderCnv.h:89
Trk::ParametersT
Dummy class used to allow special convertors to be called for surfaces owned by a detector element.
Definition: EMErrorDetail.h:25
DataHeaderCnv::m_sharedWriterCachedDHKey
std::string m_sharedWriterCachedDHKey
Definition: DataHeaderCnv.h:95
InDetAccessor::phi0
@ phi0
Definition: InDetAccessor.h:33
theta
Scalar theta() const
theta method
Definition: AmgMatrixBasePlugin.h:75
conifer::pow
constexpr int pow(int x)
Definition: conifer.h:20
xAOD::JetInput::Track
@ Track
Definition: JetContainerInfo.h:61
Token::auxString
const std::string & auxString() const
Access auxiliary string.
Definition: Token.h:89
DataHeaderCnv::m_tpOutConverter
DataHeaderCnv_p6 m_tpOutConverter
Definition: DataHeaderCnv.h:65
Trk::TrackParticleBase::trackSummary
const TrackSummary * trackSummary() const
accessor function for TrackSummary.
Definition: TrackParticleBase.h:247
AthenaPoolConverter::storageType
static long storageType()
Definition: AthenaPoolConverter.cxx:153
Token::dbID
const Guid & dbID() const
Access database identifier.
Definition: Token.h:62
test_pyathena.pt
pt
Definition: test_pyathena.py:11
M_PI
#define M_PI
Definition: ActiveFraction.h:11
T_AthenaPoolCustomCnvWithKey::keepPoolObj
void keepPoolObj(PERS *obj, const std::string &output)
Remember the POOL object to be written out (will be deleted after commit)
DataHeaderCnv_p6::createPersistent
DataHeader_p6 * createPersistent(const DataHeader *transObj, DataHeaderForm_p6 &form)
Definition: DataHeaderCnv_p6.cxx:136
AthenaPoolConverter::m_detStore
ServiceHandle< StoreGateSvc > m_detStore
Definition: AthenaPoolConverter.h:116
APRDefaults::TTreeNames::EventTag
static constexpr const char * EventTag
Definition: APRDefaults.h:13
Trk::z0
@ z0
Definition: ParamDefs.h:64
DataHeaderForm_p5
This class provides storage for the constant fields of the persistent DataHeader class.
Definition: DataHeader_p5.h:42
Placement::technology
int technology() const
Access technology type.
Definition: Placement.h:36
athena.value
value
Definition: athena.py:124
Guid::toString
const std::string toString() const
Automatic conversion to string representation.
Definition: Guid.cxx:58
python.SystemOfUnits.TeV
int TeV
Definition: SystemOfUnits.py:158
DataHeaderCnv::m_tpInConverter_p5
DataHeaderCnv_p5 m_tpInConverter_p5
for use when reading DataHeader_p5
Definition: DataHeaderCnv.h:87
PyPoolBrowser.dh
dh
Definition: PyPoolBrowser.py:102
read_hist_ntuple.t
t
Definition: read_hist_ntuple.py:5
drawFromPickle.cos
cos
Definition: drawFromPickle.py:36
python.PyKernel.AttributeList
AttributeList
Definition: PyKernel.py:36
Token::classID
const Guid & classID() const
Access database identifier.
Definition: Token.h:71
ATH_MSG_VERBOSE
#define ATH_MSG_VERBOSE(x)
Definition: AthMsgStreamMacros.h:28
DataHeaderForm_p6::setProcessTag
void setProcessTag(const std::string &tag)
Definition: DataHeader_p6.h:85
DataHeaderCnv::m_inputDHForms
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.
Definition: DataHeaderCnv.h:77
DataHeader_p6::setDhFormToken
void setDhFormToken(const std::string &formToken)
Definition: DataHeader_p6.cxx:167
DataHeaderCnv::m_sharedWriterCachedDHForm
std::map< std::string, std::unique_ptr< DataHeaderForm_p6 > > m_sharedWriterCachedDHForm
map of cached DHForms for DataHeader ID
Definition: DataHeaderCnv.h:94
MCP::ScaleSmearParam::r2
@ r2
drawFromPickle.exp
exp
Definition: drawFromPickle.py:36
Placement::setContainerName
Placement & setContainerName(const std::string &containerName)
Set container name.
Definition: Placement.h:34
AthMessaging::m_imsg
std::atomic< IMessageSvc * > m_imsg
MessageSvc pointer.
Definition: AthMessaging.h:135
DataHeaderCnv_p6::insertDHRef
void insertDHRef(DataHeader_p6 *pers_dh, const std::string &key, const std::string &dh_tokstr, DataHeaderForm_p6 &dh_form)
insert DH self reference as one of the DHElements. Contains the stream Key
Definition: DataHeaderCnv_p6.cxx:154
getSWNFromStr
std::string getSWNFromStr(const std::string &str)
Definition: DataHeaderCnv.cxx:172
python.SystemOfUnits.ms
int ms
Definition: SystemOfUnits.py:132
IDTPM::nPixelHits
float nPixelHits(const U &p)
Definition: TrackParametersHelper.h:326
Athena::getMessageSvc
IMessageSvc * getMessageSvc(bool quiet=false)
Definition: getMessageSvc.cxx:20
RootType
TTypeAdapter RootType
Definition: RootType.h:211
pool::DbType::type
int type() const
Access to full type.
Definition: DbType.h:66
Trk::numberOfBLayerHits
@ numberOfBLayerHits
these are the hits in the 0th pixel layer?
Definition: Tracking/TrkEvent/TrkTrackSummary/TrkTrackSummary/TrackSummary.h:51
AthenaPoolConverter::m_conv_mut
CallMutex m_conv_mut
Definition: AthenaPoolConverter.h:133
T_AthenaPoolCustCnv::setToken
virtual void setToken(const std::string &token)
Set the token (in std::string representation) and classID for the object that will be read next.
Token
This class provides a token that identifies in a unique way objects on the persistent storage.
Definition: Token.h:21
Converter::phiCorr
double phiCorr(double phi)
Definition: Converter.h:248
DataHeaderCnvBase
T_AthenaPoolCustomCnv< DataHeader, DataHeader_p6 > DataHeaderCnvBase
Definition: DataHeaderCnv.h:30
TrigJetMonitorAlgorithm.errmsg
errmsg
Definition: TrigJetMonitorAlgorithm.py:90
TokenAddress
This class provides a Generic Transient Address for POOL tokens.
Definition: TokenAddress.h:21
DataHeaderCnv::m_inDHFMapMaxsize
unsigned m_inDHFMapMaxsize
Max DHForms to cache per input file.
Definition: DataHeaderCnv.h:82
DataHeaderForm_p6::DHverFormRef
@ DHverFormRef
Definition: DataHeader_p6.h:50
Token::OID_t
Definition: Token.h:24
pool::Guid
::Guid Guid
Definition: T_AthenaPoolCustCnv.h:19
Token::fromString
Token & fromString(const std::string &from)
Build from the string representation of a token.
Definition: Token.cxx:133
Token::setClassID
Token & setClassID(const Guid &cl_id)
Access database identifier.
Definition: Token.h:73
TokenAddress::setToken
void setToken(Token *token)
Definition: TokenAddress.h:50
DataHeaderElement
This class provides a persistent form for the TransientAddress.
Definition: DataHeader.h:36
Token::technology
int technology() const
Access technology type.
Definition: Token.h:75
FortranAlgorithmOptions.fileName
fileName
Definition: FortranAlgorithmOptions.py:13
TrigConf::MSGTC::Level
Level
Definition: Trigger/TrigConfiguration/TrigConfBase/TrigConfBase/MsgStream.h:21
AthenaPoolConverter::m_i_poolToken
const Token * m_i_poolToken
Definition: AthenaPoolConverter.h:130
ATH_MSG_ERROR
#define ATH_MSG_ERROR(x)
Definition: AthMsgStreamMacros.h:33
DataHeaderForm_p6::getToken
const std::string & getToken() const
Definition: DataHeader_p6.cxx:148
DataHeaderCnv::m_sharedWriterCachedDH
DataHeader_p6 * m_sharedWriterCachedDH
cached values for use with SharedWriter server
Definition: DataHeaderCnv.h:92
dqt_zlumi_pandas.err
err
Definition: dqt_zlumi_pandas.py:182
DataHeader
This class provides the layout for summary information stored for data written to POOL.
Definition: DataHeader.h:124
Converter::m_beamX
double m_beamX
Definition: Converter.h:320
beamspotman.n
n
Definition: beamspotman.py:731
Trk::numberOfSCTHits
@ numberOfSCTHits
number of SCT holes
Definition: Tracking/TrkEvent/TrkTrackSummary/TrkTrackSummary/TrackSummary.h:71
ATH_MSG_DEBUG
#define ATH_MSG_DEBUG(x)
Definition: AthMsgStreamMacros.h:29
ClassID_traits
Default, invalid implementation of ClassID_traits.
Definition: Control/AthenaKernel/AthenaKernel/ClassID_traits.h:40
AthenaPoolConverter::m_containerPrefix
std::string m_containerPrefix
Definition: AthenaPoolConverter.h:125
DataHeaderCnv::m_tpInConverter
DataHeaderCnv_p6 m_tpInConverter
Definition: DataHeaderCnv.h:66
calibdata.exception
exception
Definition: calibdata.py:496
Trk::TrackParticleBase::fitQuality
const FitQuality * fitQuality() const
accessor function for FitQuality.
Definition: TrackParticleBase.h:259
chi2
double chi2(TH1 *h0, TH1 *h1)
Definition: comparitor.cxx:522
AthenaPoolConverter::m_containerNameHint
std::string m_containerNameHint
Definition: AthenaPoolConverter.h:126
TRT::Track::d0
@ d0
Definition: InnerDetector/InDetCalibEvent/TRT_CalibData/TRT_CalibData/TrackInfo.h:62
DataHeaderCnv::clearInputDHFormCache
void clearInputDHFormCache(const std::string &dbGuid)
Delete cached DHForms for a given input file GUID.
Definition: DataHeaderCnv.cxx:146
ATH_CHECK
#define ATH_CHECK
Definition: AthCheckMacros.h:40
Token::setDb
Token & setDb(const Guid &db)
Set database name.
Definition: Token.h:64
Placement::fileName
const std::string & fileName() const
Access file name.
Definition: Placement.h:28
histSizes.list
def list(name, path='/')
Definition: histSizes.py:38
Token::release
int release()
Release token: Decrease reference count and eventually delete.
Definition: Token.cxx:60
Placement::setFileName
Placement & setFileName(const std::string &fileName)
Set file name.
Definition: Placement.h:30
drawFromPickle.tan
tan
Definition: drawFromPickle.py:36
Trk::FitQuality
Class to represent and store fit qualities from track reconstruction in terms of and number of degre...
Definition: FitQuality.h:97
TRT::Track::z0
@ z0
Definition: InnerDetector/InDetCalibEvent/TRT_CalibData/TRT_CalibData/TrackInfo.h:63
Token::setTechnology
Token & setTechnology(int t)
Set technology type.
Definition: Token.h:77
CLID
uint32_t CLID
The Class ID type.
Definition: Event/xAOD/xAODCore/xAODCore/ClassID_traits.h:47
DataHeader_p6
This class provides a persistent representation for the DataHeader class.
Definition: DataHeader_p6.h:116
APRDefaults::RNTupleNames::EventTag
static constexpr const char * EventTag
Definition: APRDefaults.h:19
Placement::auxString
const std::string & auxString() const
Access auxiliary string.
Definition: Placement.h:40
AthMessaging::msg
MsgStream & msg() const
The standard message stream.
Definition: AthMessaging.h:164
DataHeaderCnv_p4::createTransient
DataHeader * createTransient(const DataHeader_p4 *persObj)
Definition: DataHeaderCnv_p4.h:51
Converter::addTrack
void addTrack(TIDA::Track *t)
Definition: Converter.h:45
DataHeaderCnv::createPersistent
DataHeader_p6 * createPersistent(DataHeader *transObj, DataHeaderForm_p6 *)
Definition: DataHeaderCnv.cxx:535
DataHeaderCnv::m_dhInForm5
std::unique_ptr< DataHeaderForm_p5 > m_dhInForm5
Definition: DataHeaderCnv.h:88
DataHeaderCnv::poolReadObject_p5
std::unique_ptr< DataHeader_p5 > poolReadObject_p5()
Definition: DataHeaderCnv.cxx:393
pool_uuid.guid
guid
Definition: pool_uuid.py:112
merge.output
output
Definition: merge.py:17
DataHeaderCnv::m_lastGoodDHFRef
std::map< std::string, std::string > m_lastGoodDHFRef
Definition: DataHeaderCnv.h:84
APRDefaults::TTreeNames::DataHeader
static constexpr const char * DataHeader
Definition: APRDefaults.h:14
DataHeaderForm_p6::clearModified
void clearModified()
Definition: DataHeader_p6.cxx:139
Trk::numberOfTRTHits
@ numberOfTRTHits
number of TRT outliers
Definition: Tracking/TrkEvent/TrkTrackSummary/TrkTrackSummary/TrackSummary.h:79
DataHeaderCnv::m_oneDHForm
bool m_oneDHForm
if true write only one DataHeaderForm at the end (stop, finalize, or WriteDataHeaderForms incident) t...
Definition: DataHeaderCnv.h:72
Trk::TrackSummary
A summary of the information contained by a track.
Definition: Tracking/TrkEvent/TrkTrackSummary/TrkTrackSummary/TrackSummary.h:287
Trk::d0
@ d0
Definition: ParamDefs.h:63
AthenaPoolConverter::PoolToDataObject
virtual StatusCode PoolToDataObject(DataObject *&pObj, const Token *token, const std::string &key)=0
Read an object from POOL.
plotBeamSpotMon.b
b
Definition: plotBeamSpotMon.py:77
DataHeaderForm_p6::setToken
void setToken(const std::string &tok)
Definition: DataHeader_p6.cxx:143
DataHeaderCnv_p4
This class provides the converter to customize the saving of DataHeader_p4.
Definition: DataHeaderCnv_p4.h:35
Token::toString
virtual const std::string toString() const
Retrieve the string representation of the token.
Definition: Token.cxx:114
DataHeaderForm_p6::sizeObj
std::size_t sizeObj() const
Definition: DataHeader_p6.cxx:102
DataHeaderCnv::m_inDHFormCount
std::map< std::string, unsigned > m_inDHFormCount
How many DHForms for an input file are in the cache.
Definition: DataHeaderCnv.h:80
Token::setOid
Token & setOid(const OID_t &oid)
Set object identifier.
Definition: Token.h:83
python.LumiBlobConversion.pos
pos
Definition: LumiBlobConversion.py:18
Rec::TrackParticle
Definition: Reconstruction/Particle/Particle/TrackParticle.h:47
Placement::toString
const std::string toString() const
Retrieve the string representation of the placement.
Definition: Placement.cxx:15
Rec::TrackParticle::measuredPerigee
const Trk::Perigee * measuredPerigee() const
Accessor method for Perigee.
Definition: Reconstruction/Particle/Particle/TrackParticle.h:180
DataHeaderCnv_p3::createTransient
DataHeader * createTransient(const DataHeader_p3 *persObj)
Definition: DataHeaderCnv_p3.h:51
DataVector::end
const_iterator end() const noexcept
Return a const_iterator pointing past the end of the collection.
AthenaPoolConverter::DataObjectToPers
virtual StatusCode DataObjectToPers(DataObject *pObj, IOpaqueAddress *&pAddr)=0
Convert an object into Persistent.
DataHeaderCnv::removeBadElements
void removeBadElements(DataHeader *dh)
Remove DataHeaderElements with incomplete (dbID="") refs.
Definition: DataHeaderCnv.cxx:541
Trk::DetectorType
DetectorType
enumerates the various detector types currently accessible from the isHit() method.
Definition: Tracking/TrkEvent/TrkTrackSummary/TrkTrackSummary/TrackSummary.h:231
DataHeaderCnv_p5::createTransient
std::unique_ptr< DataHeader > createTransient(const DataHeader_p5 &persObj, const DataHeaderForm_p5 &dhForm) const
Definition: DataHeaderCnv_p5.h:70
pool::DbType::exactMatch
bool exactMatch(const DbType &typ) const
Definition: DbType.h:73
ATH_MSG_WARNING
#define ATH_MSG_WARNING(x)
Definition: AthMsgStreamMacros.h:32
AthenaPoolConverter::m_branchNameHint
std::string m_branchNameHint
Definition: AthenaPoolConverter.h:127
TokenAddress::getToken
Token * getToken()
Definition: TokenAddress.h:48
DataHeader_p5
This class provides a persistent representation for the DataHeader class.
Definition: DataHeader_p5.h:67
Token::oid
const OID_t & oid() const
Access object identifier.
Definition: Token.h:79
Token::setAuxString
Token & setAuxString(const std::string &auxString)
Set auxiliary string.
Definition: Token.h:91
AthMessaging::m_nm
std::string m_nm
Message source name.
Definition: AthMessaging.h:129
Placement::setTechnology
Placement & setTechnology(int technology)
Set technology type.
Definition: Placement.h:38
TIDA::Track
Definition: Trigger/TrigAnalysis/TrigInDetAnalysis/TrigInDetAnalysis/Track.h:26
Token::setCont
Token & setCont(const std::string &cnt)
Set container name.
Definition: Token.h:69
makeTransCanvas.text
text
Definition: makeTransCanvas.py:11
Trk::FitQuality::chiSquared
double chiSquared() const
returns the of the overall track fit
Definition: FitQuality.h:56
Trk::FitQuality::numberDoF
int numberDoF() const
returns the number of degrees of freedom of the overall track or vertex fit as integer
Definition: FitQuality.h:60
calibdata.copy
bool copy
Definition: calibdata.py:27
T_AthenaPoolCustCnv::compareClassGuid
virtual bool compareClassGuid(const Guid &clid) const
Compare POOL class GUID with the one of the object being read.
AthMessaging::initMessaging
void initMessaging() const
Initialize our message level and MessageSvc.
Definition: AthMessaging.cxx:39
drawFromPickle.sin
sin
Definition: drawFromPickle.py:36
DataHeaderCnv_p3
This class provides the converter to customize the saving of DataHeader_p3.
Definition: DataHeaderCnv_p3.h:35
AthenaPoolConverter::m_classDesc
RootType m_classDesc
Definition: AthenaPoolConverter.h:118
Token::setData
const Token & setData(Token *pToken) const
Set all the data part of the token.
Definition: Token.cxx:194
makeTOC.header
header
Definition: makeTOC.py:28
MCP::ScaleSmearParam::r1
@ r1
T_AthenaPoolCustCnv::initialize
virtual StatusCode initialize()
Gaudi Service Interface method implementations:
AthMessaging::m_msg_tls
boost::thread_specific_ptr< MsgStream > m_msg_tls
MsgStream instance (a std::cout like with print-out levels)
Definition: AthMessaging.h:132
python.PyAthena.obj
obj
Definition: PyAthena.py:132
SG::DataProxy
Definition: DataProxy.h:44
error
Definition: IImpactPoint3dEstimator.h:70
Converter::m_tracks
std::vector< TIDA::Track * > m_tracks
Definition: Converter.h:321
Placement::fromString
Placement & fromString(const std::string &from)
Build from the string representation of a placement.
Definition: Placement.cxx:28
Trk::phi0
@ phi0
Definition: ParamDefs.h:65
DataHeaderCnv::poolReadObject_p6
std::unique_ptr< DataHeader_p6 > poolReadObject_p6()
Definition: DataHeaderCnv.cxx:422
IDTPM::nSiHits
float nSiHits(const U &p)
Definition: TrackParametersHelper.h:399
python.trfValidateRootFile.rc
rc
Definition: trfValidateRootFile.py:349
DataVector::begin
const_iterator begin() const noexcept
Return a const_iterator pointing at the beginning of the collection.
ServiceHandle< IIncidentSvc >
mapkey::key
key
Definition: TElectronEfficiencyCorrectionTool.cxx:37
TScopeAdapter
Definition: RootType.h:119
SCT_Monitoring::summary
@ summary
Definition: SCT_MonitoringNumbers.h:65