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

Manages the content of the metadata stores. More...

#include <MetaDataSvc.h>

Inheritance diagram for MetaDataSvc:

Classes

class  ToolLockGuard

Public Member Functions

 MetaDataSvc (const std::string &name, ISvcLocator *pSvcLocator)
 Standard Service Constructor.
virtual ~MetaDataSvc ()
 Destructor.
virtual StatusCode prepareOutput ()
 Makes the metadata store ready for output.
virtual void handle (const Incident &incident) override
 react to file incidents.
StatusCode transitionMetaDataFile (const std::string &outputConn, bool disconnect)
 Transition output metadata file - fire MeteDataStop incident to transition OutputStream and disconnect now if requested.
virtual StatusCode io_reinit () override
 Implements IIoComponent interface sets m_outputPrepared to false and prints some information.
StatusCode rootOpenAction (FILEMGR_CALLBACK_ARGS)
virtual StoreGateSvcoutputDataStore () const override final
virtual const std::string currentRangeID () const override final
CLID remapMetaContCLID (const CLID &item_id) const
void lockTools () const
void unlockTools () const
void recordHook (const std::type_info &) override
void removeHook (const std::type_info &) override
std::string removeStreamFromKey (std::string &key)
 check if the metadata object key contains Stream name (added by SharedWriter in MetaDataSvc) remove stream part from the key (i.e.
virtual std::set< std::string > getPerStreamKeysFor (const std::string &key) const override final
 Get all per-stream Key variants created for in-file metadata object with original key If no stream-specific keys are found, it returns the original key.
virtual StatusCode initialize () override
 initialize the metadata service at the beginning of the job
virtual StatusCode stop () override
 stop the metadata service
virtual StatusCode finalize () override
 finalize the metadata service at the end of the job
virtual StatusCode newMetadataSource (const Incident &)
 Fills the input metadata store with the content of the new input file.
virtual StatusCode retireMetadataSource (const Incident &)
 Allows metadata tools to act before an input file is closed.
virtual StatusCode prepareOutput (const std::string &outputName)
 Makes the metadata store ready for output with SharedWriter Calls the metaDataStop method of all MetaDataTool interfaces in m_metaDataTool.
virtual StatusCode shmProxy (const std::string &filename) override
 Loads file metadata from memory shared between streams in SharedWriter This function clears the input and output metadata stores.
StatusCode preLoadAddresses (StoreID::type, IAddressProvider::tadList &) override
 does nothing.
StatusCode loadAddresses (StoreID::type storeID, IAddressProvider::tadList &tads) override
 loads addresses of versioned metadata object.
StatusCode updateAddress (StoreID::type, SG::TransientAddress *, const EventContext &) override
 always fails

Private Member Functions

StatusCode addProxyToInputMetaDataStore (const std::string &tokenStr)
StatusCode initInputMetaDataStore (const std::string &fileName)
 Initialize input metadata store - can be called directly or via BeginInputFile incident.

Private Attributes

ServiceHandle< StoreGateSvcm_inputDataStore
ServiceHandle< StoreGateSvcm_outputDataStore
ServiceHandle< IAddressCreator > m_addrCrtr { this, "ConversionService", "AthenaPoolCnvSvc" }
ServiceHandle< IFileMgr > m_fileMgr
ServiceHandle< IIncidentSvc > m_incSvc
ServiceHandle< OutputStreamSequencerSvcm_outSeqSvc
ServiceHandle< IClassIDSvc > m_classIDSvc {"ClassIDSvc", name()}
long m_storageType {0L}
bool m_clearedInputDataStore {true}
bool m_clearedOutputDataStore {false}
bool m_allowMetaDataStop {false}
bool m_outputPrepared {false}
std::map< std::string_view, CLIDm_persToClid {}
std::set< CLIDm_handledClasses {}
std::map< std::string, std::set< std::string > > m_streamKeys {}
Gaudi::Property< std::string > m_metaDataCont {this, "MetaDataContainer", ""}
 MetaDataContainer, POOL container name for MetaData.
PublicToolHandleArray< IMetaDataToolm_metaDataTools {this, "MetaDataTools", {}}
 MetaDataTools, vector with the MetaData tools.

Static Private Attributes

static constexpr std::string_view m_streamInKeyMark {"__STREAM["}
 marker string for embedding stream name in MetaData object keys for SharedWriter server

Detailed Description

Manages the content of the metadata stores.

This service orchestrates the reading of metadata from input files and its propagation to the output with the help of the IMetaDataTool interfaces in m_metaDataTools. The MetaDataSvc reacts to BeginInputFile and EndInputFile incidents. It relies on the AthenaPoolCnvSvc (or whatever persistency service) to call the the appropriate prepareOutput method when committing the MetaDataStore content to the output file.

On BeginInputFile it clears the InputMetaDataStore and populates it with content from the new input file. The beginInputFile methods of all tools are called to allow required actions on the metadata objects.

On EndInputFile the MetaDataSvc calls the endInputFile methods of all the interfaces in m_metaDataTools .

In jobs with multiple parallel output streams (SharedWriter) the metadata content from multiple streams is put into the output MetaDataStore. To do this the The MetaDataSvc accesses the memory shared with the output streams, and adds the content of their MetaDataStore to the shared InputMetaDataStore. This is done by the client calling shmProxy for each object to be added to the MetaDataStore. Afterwards the client must also fire BeginInputFile and EndInputFile incidents to allow the MetaDataTools to move their objects from the InputMetaDataStore to the MetaDataStore taking care of possible merges.

Example configuration:

ca = ComponentAccumulator()
ca.addService(CompFactory.StoreGateSvc("MetaDataStore"))
ca.addService(CompFactory.StoreGateSvc("InputMetaDataStore"))
metaDataSvc = CompFactory.MetaDataSvc("MetaDataSvc")
ca.addService(
CompFactory.ProxyProviderSvc(ProviderNames=["MetaDataSvc"]))
metaDataSvc.MetaDataTools += [someMetaDataTool]
See also
IMetaDataTool
AthenaPoolCnvSvc

Definition at line 84 of file MetaDataSvc.h.

Constructor & Destructor Documentation

◆ MetaDataSvc()

MetaDataSvc::MetaDataSvc ( const std::string & name,
ISvcLocator * pSvcLocator )

Standard Service Constructor.

Definition at line 54 of file MetaDataSvc.cxx.

55 : base_class( name, pSvcLocator )
56 , m_inputDataStore( "StoreGateSvc/InputMetaDataStore", name )
57 , m_outputDataStore( "StoreGateSvc/MetaDataStore", name )
58 , m_fileMgr( "FileMgr", name )
59 , m_incSvc( "IncidentSvc", name )
60 , m_outSeqSvc( "OutputStreamSequencerSvc", name )
61 , m_persToClid{ { "DataHeader_p5", 222376821 },
62 { "EventStreamInfo_p3", 167728019 },
63 { "ByteStreamMetadataContainer_p1", 1076128893 },
64 { "IOVMetaDataContainer_p1", 1316383046 },
65 { "xAOD::EventFormat_v1", 243004407 },
66 { "xAOD::CutBookkeeperContainer_v1", 1234982351 },
67 { "xAOD::CutBookkeeperAuxContainer_v1", 1147935274 },
68 { "xAOD::TriggerMenuContainer_v1", 1107011239 },
69 { "DataVector<xAOD::TriggerMenu_v1>", 1107011239 },
70 { "xAOD::TriggerMenuAuxContainer_v1", 1212409402 },
71 { "xAOD::TriggerMenuJsonContainer_v1", 1221262614 },
72 { "DataVector<xAOD::TriggerMenuJson_v1>", 1221262614 },
73 { "xAOD::TriggerMenuJsonAuxContainer_v1", 373045213 },
74 { "xAOD::LumiBlockRangeContainer_v1", 1115934851 },
75 { "DataVector<xAOD::LumiBlockRange_v1>", 1115934851 },
76 { "xAOD::LumiBlockRangeAuxContainer_v1", 1251061086 },
77 { "xAOD::FileMetaData_v1", 178309087 },
78 { "xAOD::FileMetaDataAuxInfo_v1", 73252552 },
79 { "xAOD::RingSetConfContainer_v1", 1157997427 },
80 { "DataVector<xAOD::RingSetConf_v1>", 1157997427 },
81 { "xAOD::RingSetConfAuxContainer_v1", 1307745126 },
82 { "xAOD::TruthMetaDataContainer_v1", 1188015687 },
83 { "DataVector<xAOD::TruthMetaData_v1>", 1188015687 },
84 { "xAOD::TruthMetaDataAuxContainer_v1", 1094306618 } } {}
ServiceHandle< OutputStreamSequencerSvc > m_outSeqSvc
ServiceHandle< StoreGateSvc > m_outputDataStore
ServiceHandle< StoreGateSvc > m_inputDataStore
std::map< std::string_view, CLID > m_persToClid
ServiceHandle< IIncidentSvc > m_incSvc
ServiceHandle< IFileMgr > m_fileMgr

◆ ~MetaDataSvc()

MetaDataSvc::~MetaDataSvc ( )
virtualdefault

Destructor.

Member Function Documentation

◆ addProxyToInputMetaDataStore()

StatusCode MetaDataSvc::addProxyToInputMetaDataStore ( const std::string & tokenStr)
private

Definition at line 416 of file MetaDataSvc.cxx.

416 {
417 std::string fileName = tokenStr.substr(tokenStr.find("[FILE=") + 6);
418 leftString(fileName, ']');
419 std::string className = tokenStr.substr(tokenStr.find("[PNAME=") + 7);
420 leftString(className, ']');
421 std::string contName = tokenStr.substr(tokenStr.find("[CONT=") + 6);
422 leftString(contName,']');
423 std::size_t pos1 = contName.find('(');
424 std::string keyName = contName.substr(pos1 + 1, contName.size() - pos1 - 2);
425 std::size_t pos2 = keyName.find('/');
426 if (pos2 != std::string::npos) keyName = keyName.substr(pos2 + 1);
427 std::string numName = tokenStr.substr(tokenStr.find("[NUM=") + 5);
428 leftString(numName,']');
429 unsigned long num = 0;
430 std::istringstream iss(numName);
431 iss >> num;
432 CLID clid = m_persToClid[className];
433
434 // make stream-unique keys for infile metadata objects
435 // AthenaOutputStream will use this to distribute objects to the right stream (and restore the original key)
436 if( clid == 178309087 ) { // FileMetaData
437 std::string newName = std::format("{}{}{}{}", keyName, m_streamInKeyMark, fileName, "]");
438 ATH_MSG_DEBUG("Recording " << keyName << " as " << newName);
439 m_streamKeys[keyName].insert(newName);
440 keyName = std::move(newName);
441 }
442 if( clid == 73252552 ) { // FileMetaDataAuxInfo
443 std::string newName = std::format("{}{}{}]{}",
446 fileName,
448 ATH_MSG_DEBUG("Recording " << keyName << " as " << newName);
449 m_streamKeys[keyName].insert(newName);
450 keyName = std::move(newName);
451 }
452 const std::string par[3] = { "SHM" , keyName , std::move(className) };
453 const unsigned long ipar[2] = { num , 0 };
454 IOpaqueAddress* opqAddr = nullptr;
455 SG::DataProxy* dp = m_inputDataStore->proxy(clid, keyName);
456 if (dp != nullptr) {
457 ATH_MSG_DEBUG("Resetting duplicate proxy for: " << clid << "#" << keyName << " from file: " << fileName);
458 dp->reset();
459 }
460 if (!m_addrCrtr->createAddress(m_storageType, clid, par, ipar, opqAddr).isSuccess()) {
461 ATH_MSG_FATAL("addProxyToInputMetaDataStore: Cannot create address for " << tokenStr);
462 return(StatusCode::FAILURE);
463 }
464 if (m_inputDataStore->recordAddress(keyName, opqAddr).isFailure()) {
465 ATH_MSG_FATAL("addProxyToInputMetaDataStore: Cannot create proxy for " << tokenStr);
466 return(StatusCode::FAILURE);
467 }
468 if (m_inputDataStore->accessData(clid, keyName) == nullptr) {
469 ATH_MSG_FATAL("addProxyToInputMetaDataStore: Cannot access data for " << tokenStr);
470 return(StatusCode::FAILURE);
471 }
472 if (keyName.find(RootAuxDynIO::AUX_POSTFIX) != std::string::npos
473 && m_inputDataStore->symLink(clid, keyName, 187169987).isFailure()) {
474 ATH_MSG_WARNING("addProxyToInputMetaDataStore: Cannot symlink to AuxStore for " << tokenStr);
475 }
476 return(StatusCode::SUCCESS);
477}
#define ATH_MSG_FATAL(x)
#define ATH_MSG_WARNING(x)
#define ATH_MSG_DEBUG(x)
uint32_t CLID
The Class ID type.
long m_storageType
std::map< std::string, std::set< std::string > > m_streamKeys
static constexpr std::string_view m_streamInKeyMark
marker string for embedding stream name in MetaData object keys for SharedWriter server
ServiceHandle< IAddressCreator > m_addrCrtr
constexpr char AUX_POSTFIX[]
Common post-fix for the names of auxiliary containers in StoreGate.

◆ currentRangeID()

const std::string MetaDataSvc::currentRangeID ( ) const
finaloverridevirtual

Definition at line 548 of file MetaDataSvc.cxx.

549{
550 return m_outSeqSvc.isValid()? m_outSeqSvc->currentRangeID() : "";
551}

◆ finalize()

StatusCode MetaDataSvc::finalize ( )
overridevirtual

finalize the metadata service at the end of the job

Definition at line 144 of file MetaDataSvc.cxx.

144 {
145 // Release IncidentService
146 if (!m_incSvc.release().isSuccess()) {
147 ATH_MSG_WARNING("Cannot release IncidentService.");
148 }
149 // Release FileMgr
150 if (!m_fileMgr.release().isSuccess()) {
151 ATH_MSG_WARNING("Cannot release FileMgr.");
152 }
153 // Release AddressCreator
154 if (!m_addrCrtr.release().isSuccess()) {
155 ATH_MSG_WARNING("Cannot release AddressCreator.");
156 }
157 // Release OutputMetaDataStore
158 if (!m_outputDataStore.release().isSuccess()) {
159 ATH_MSG_WARNING("Cannot release OutputMetaDataStore.");
160 }
161 // Release InputMetaDataStore
162 if (!m_inputDataStore.release().isSuccess()) {
163 ATH_MSG_WARNING("Cannot release InputMetaDataStore.");
164 }
165 return(StatusCode::SUCCESS);
166}

◆ getPerStreamKeysFor()

std::set< std::string > MetaDataSvc::getPerStreamKeysFor ( const std::string & key) const
nodiscardfinaloverridevirtual

Get all per-stream Key variants created for in-file metadata object with original key If no stream-specific keys are found, it returns the original key.

Definition at line 408 of file MetaDataSvc.cxx.

408 {
409 if (!m_streamKeys.contains(key)) {
410 return {key};
411 }
412 return m_streamKeys.at(key);
413}

◆ handle()

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

react to file incidents.

calls newMetadataSource on BeginInputFile and retireMetadataSource on EndInputFile. Does

Parameters
incidentis expected to be BeginInputFile or EndInputFile

Definition at line 320 of file MetaDataSvc.cxx.

320 {
321 const FileIncident* fileInc = dynamic_cast<const FileIncident*>(&inc);
322 if (fileInc == nullptr) {
323 ATH_MSG_ERROR("Unable to get FileName from EndInputFile incident");
324 return;
325 }
326 const std::string fileName = fileInc->fileName();
327 ATH_MSG_DEBUG("handle() " << inc.type() << " for " << fileName);
328
329 if (inc.type() == "FirstInputFile") {
330 // Register open/close callback actions
331 using namespace boost::placeholders;
332 Io::bfcn_action_t boa = boost::bind(&MetaDataSvc::rootOpenAction, this, _1,_2);
333 if (m_fileMgr->regAction(std::move(boa), Io::OPEN).isFailure()) {
334 ATH_MSG_FATAL("Cannot register ROOT file open action with FileMgr.");
335 }
336 if (!initInputMetaDataStore(fileName).isSuccess()) {
337 ATH_MSG_WARNING("Unable to initialize InputMetaDataStore");
338 }
339 } else if (inc.type() == "BeginInputFile" || inc.type() == "BeginInputMemFile") {
340 if(newMetadataSource(inc).isFailure()) {
341 ATH_MSG_ERROR("Could not process new metadata source " << fileName);
342 }
343 } else if (inc.type() == "EndInputFile" || inc.type() == "EndInputMemFile") {
344 if(retireMetadataSource(inc).isFailure()) {
345 ATH_MSG_ERROR("Could not retire metadata source " << fileName);
346 }
347 }
348}
#define ATH_MSG_ERROR(x)
virtual StatusCode newMetadataSource(const Incident &)
Fills the input metadata store with the content of the new input file.
StatusCode rootOpenAction(FILEMGR_CALLBACK_ARGS)
virtual StatusCode retireMetadataSource(const Incident &)
Allows metadata tools to act before an input file is closed.
StatusCode initInputMetaDataStore(const std::string &fileName)
Initialize input metadata store - can be called directly or via BeginInputFile incident.

◆ initialize()

StatusCode MetaDataSvc::initialize ( )
overridevirtual

initialize the metadata service at the beginning of the job

Definition at line 90 of file MetaDataSvc.cxx.

90 {
91 ATH_MSG_INFO("Initializing " << name());
92
93 // Retrieve InputMetaDataStore
94 ATH_CHECK( m_inputDataStore.retrieve() );
95 // Retrieve OutputMetaDataStore
96 ATH_CHECK( m_outputDataStore.retrieve() );
97 // Retrieve AddressCreator
98 ATH_CHECK( m_addrCrtr.retrieve() );
99
100 AthCnvSvc* cnvSvc = dynamic_cast<AthCnvSvc*>(m_addrCrtr.operator->());
101 if (cnvSvc) {
102 m_storageType = cnvSvc->repSvcType();
103 } else {
104 ATH_MSG_WARNING("Cannot get ConversionSvc Interface.");
105 }
106 // Get FileMgr
107 ATH_CHECK( m_fileMgr.retrieve() );
108
109 // Set to be listener for end of event
110 ATH_CHECK( m_incSvc.retrieve() );
111
112 ATH_CHECK( m_metaDataTools.retrieve() );
113 ATH_MSG_INFO("Found " << m_metaDataTools);
114
115 m_incSvc->addListener(this, "FirstInputFile", 80, true);
116 m_incSvc->addListener(this, "BeginInputFile", 80, true);
117 m_incSvc->addListener(this, "EndInputFile", 10, true);
118 m_incSvc->addListener(this, "BeginInputMemFile", 80, true);
119 m_incSvc->addListener(this, "EndInputMemFile", 10, true);
120
121 // Register this service for 'I/O' events
122 ServiceHandle<IIoComponentMgr> iomgr("IoComponentMgr", this->name());
123 ATH_CHECK( iomgr.retrieve() );
124 ATH_CHECK( iomgr->io_register(this) );
125
126 ServiceHandle<Gaudi::Interfaces::IOptionsSvc> joSvc("JobOptionsSvc", name());
127 if (!joSvc.retrieve().isSuccess()) {
128 ATH_MSG_WARNING("Cannot get JobOptionsSvc.");
129 } else {
130 if (joSvc->has("EventSelector.InputCollections")) {
131 // Get EventSelector to force in-time initialization and FirstInputFile incident
132 ServiceHandle<IEvtSelector> evtsel("EventSelector", this->name());
133 if (!evtsel.retrieve().isSuccess()) {
134 ATH_MSG_WARNING("Cannot get EventSelector.");
135 }
136 }
137 }
138 // retrieve the output sequences service (EventService) if available
139 m_outSeqSvc.retrieve().ignore();
140
141 return(StatusCode::SUCCESS);
142}
#define ATH_CHECK
Evaluate an expression and check for errors.
#define ATH_MSG_INFO(x)
virtual long repSvcType() const override
Retrieve the class type of the data store the converter uses.
PublicToolHandleArray< IMetaDataTool > m_metaDataTools
MetaDataTools, vector with the MetaData tools.

◆ initInputMetaDataStore()

StatusCode MetaDataSvc::initInputMetaDataStore ( const std::string & fileName)
private

Initialize input metadata store - can be called directly or via BeginInputFile incident.

Definition at line 479 of file MetaDataSvc.cxx.

479 {
480 ATH_MSG_DEBUG("initInputMetaDataStore: file name " << fileName);
482 // Load proxies for InputMetaDataStore
483 if (m_metaDataCont.value().empty()) {
484 ATH_MSG_DEBUG("MetaDataSvc called without MetaDataContainer set.");
485 return(StatusCode::SUCCESS);
486 }
487 if (fileName.starts_with( "BSF:")) {
488 ATH_MSG_DEBUG("MetaDataSvc called for non ROOT file.");
489 } else if (fileName.compare(0, 3, "SHM")==0) {
490 ATH_MSG_DEBUG("MetaDataSvc called for shared memory.");
491 } else {
492 const std::string par[2] = {
493 fileName,
494 std::format("{}(DataHeader)", m_metaDataCont.value())
495 };
496 const std::string parOld[2] = {
497 fileName,
498 std::format("{}{}", m_metaDataCont.value(), "DataHeader")
499 };
500 for (int verNumber = 0; verNumber < 100; verNumber++) {
501 SG::VersionedKey myVersKey(name(), verNumber);
502 if (m_inputDataStore->contains<DataHeader>(myVersKey)) {
503 ATH_MSG_DEBUG("initInputMetaDataStore: MetaData Store already contains DataHeader, key = " << myVersKey);
504 } else {
505 const unsigned long ipar[2] = { (unsigned long)verNumber , 0 };
506 IOpaqueAddress* opqAddr = nullptr;
507 if (!m_addrCrtr->createAddress(m_storageType, ClassID_traits<DataHeader>::ID(), par, ipar, opqAddr).isSuccess()) {
508 if (!m_addrCrtr->createAddress(m_storageType, ClassID_traits<DataHeader>::ID(), parOld, ipar, opqAddr).isSuccess()) {
509 break;
510 }
511 }
512 if (m_inputDataStore->recordAddress(myVersKey, opqAddr).isFailure()) {
513 ATH_MSG_WARNING("initInputMetaDataStore: Cannot create proxy for DataHeader, key = " << myVersKey);
514 }
515 }
516 }
517 std::list<SG::TransientAddress*> tList;
519 for (SG::TransientAddress* tad : tList) {
520 CLID clid = tad->clID();
521 ATH_MSG_VERBOSE("initInputMetaDataStore: add proxy for clid = " << clid << ", key = " << tad->name());
522 if (m_inputDataStore->contains(tad->clID(), tad->name())) {
523 ATH_MSG_DEBUG("initInputMetaDataStore: MetaData Store already contains clid = " << clid << ", key = " << tad->name());
524 } else {
525 if (!m_inputDataStore->recordAddress(tad->name(), tad->address())) {
526 ATH_MSG_ERROR("initInputMetaDataStore: Cannot create proxy for clid = " << clid << ", key = " << tad->name());
527 return StatusCode::FAILURE;
528 }
529 }
530
531 for (CLID tclid : tad->transientID()) {
532 if (tclid != clid) {
533 if (m_inputDataStore->symLink (clid, tad->name(), tclid).isFailure()) {
534 ATH_MSG_WARNING("Cannot make autosymlink from " <<
535 clid << "/" << tad->name() << " to " << tclid);
536 }
537 }
538 }
539 delete tad;
540 }
541 tList.clear();
542 }
543 ATH_MSG_DEBUG("Loaded input meta data store proxies");
544 return(StatusCode::SUCCESS);
545}
#define ATH_MSG_VERBOSE(x)
StatusCode loadAddresses(StoreID::type storeID, IAddressProvider::tadList &tads) override
loads addresses of versioned metadata object.
Gaudi::Property< std::string > m_metaDataCont
MetaDataContainer, POOL container name for MetaData.
bool m_clearedInputDataStore
@ METADATA_STORE
Definition StoreID.h:29

◆ io_reinit()

StatusCode MetaDataSvc::io_reinit ( )
overridevirtual

Implements IIoComponent interface sets m_outputPrepared to false and prints some information.

Returns
SUCCESS
See also
IIoComponent

Definition at line 379 of file MetaDataSvc.cxx.

379 {
380 ATH_MSG_INFO("I/O reinitialization...");
381 ATH_MSG_DEBUG("Dumping InputMetaDataStore: " << m_inputDataStore->dump());
382 ATH_MSG_DEBUG("Dumping OutputMetaDataStore: " << m_outputDataStore->dump());
383 for (const auto& tool : m_metaDataTools) {
384 ATH_MSG_INFO("Attached MetaDataTool: " << tool->name());
385 }
386 m_outputPrepared = false;
387 return(StatusCode::SUCCESS);
388}
bool m_outputPrepared

◆ loadAddresses()

StatusCode MetaDataSvc::loadAddresses ( StoreID::type storeID,
IAddressProvider::tadList & tads )
override

loads addresses of versioned metadata object.

loops over all versions of the DataHeader and adds addresses of objects from DataHeaderElements to the tads with a version corresponding to version number of the DataHeader that contained them.

See also
ObjectWithVersion
DataHeader
Parameters
storeID[IN] the identity of the store
tads[OUT] list of addresses to objects from versions keys
Returns
FAILURE the DataHeader could not be retrieved, else SUCCESS

Definition at line 178 of file MetaDataSvc.cxx.

178 {
179 if (storeID != StoreID::METADATA_STORE) { // should this (also) run in the INPUT_METADATA_STORE?
180 return(StatusCode::SUCCESS);
181 }
182 // Put Additional MetaData objects into Input MetaData Store using VersionedKey
183 std::list<SG::ObjectWithVersion<DataHeader> > allVersions;
184 StatusCode sc = m_inputDataStore->retrieveAllVersions(allVersions, name());
185 if (!sc.isSuccess()) {
186 ATH_MSG_WARNING("Could not retrieve all versions for DataHeader, will not read Metadata");
187 } else {
188 int verNumber = -1;
189 for (SG::ObjectWithVersion<DataHeader>& obj : allVersions) {
190 ++verNumber;
191 const DataHeader* dataHeader = obj.dataObject.cptr();
192 if (dataHeader == nullptr) {
193 ATH_MSG_ERROR("Could not get DataHeader, will not read Metadata");
194 return(StatusCode::FAILURE);
195 }
196 for (const DataHeaderElement& dhe : *dataHeader) {
197 const CLID clid = dhe.getPrimaryClassID();
198 if (clid != ClassID_traits<DataHeader>::ID()) {
199 SG::VersionedKey myVersObjKey(dhe.getKey(), verNumber);
200 std::string key = dhe.getKey();
201 if (verNumber != 0) {
202 key = myVersObjKey;
203 }
204 tads.push_back(dhe.getAddress(m_storageType, key));
205 }
206 }
207 }
208 }
209 return(StatusCode::SUCCESS);
210}
static Double_t sc
::StatusCode StatusCode
StatusCode definition for legacy code.

◆ lockTools()

void MetaDataSvc::lockTools ( ) const

Definition at line 599 of file MetaDataSvc.cxx.

599 {
600 ATH_MSG_DEBUG("Locking metadata tools");
601 for(auto& tool : m_metaDataTools ) {
602 const ILockableTool *lockable = dynamic_cast<const ILockableTool*>( tool.get() );
603 if( lockable ) lockable->lock_shared();
604 }
605}
virtual void lock_shared() const =0
Lock the tool.

◆ newMetadataSource()

StatusCode MetaDataSvc::newMetadataSource ( const Incident & inc)
virtual

Fills the input metadata store with the content of the new input file.

Once the GUID and name of the input file are determined from the incident this function blocks stopping the MetaDataSvc by setting m_allowMetaDataStop to false. Then attempts first to clear the input metadata store and prepare it for the metadata tools by calling initInputMetaDataStore. The loops over all MetaDataTool interfaces in m_metaDataTools and calls their beginInputFile implementations.

See also
initInputMetaDataStore()
m_metaDataTools
Parameters
incThe BeginInputFile incident fired on opening a new file
Returns
FAILURE when inc is not a file incident, the input metadata store cannot be set up, or a MetaDataTool fails. Otherwise SUCCESS.

Definition at line 212 of file MetaDataSvc.cxx.

213{
214 const FileIncident* fileInc = dynamic_cast<const FileIncident*>(&inc);
215 if (fileInc == nullptr) {
216 ATH_MSG_ERROR("Unable to get FileName from EndInputFile incident");
217 return StatusCode::FAILURE;
218 }
219 const std::string guid = fileInc->fileGuid();
220 const std::string fileName = fileInc->fileName();
221 m_allowMetaDataStop = false;
222 if (!fileName.starts_with( "BSF:")) {
223 // the input file is _not_ bytestream
225 if (!m_inputDataStore->clearStore().isSuccess()) {
226 ATH_MSG_WARNING("Unable to clear input MetaData Proxies");
227 }
229 }
231 }
232 StatusCode rc{StatusCode::SUCCESS};
233 for (auto& tool : m_metaDataTools) {
234 ATH_MSG_DEBUG(" calling beginInputFile on " << tool->name() << " for GUID \"" << guid << "\"");
235 if (tool->beginInputFile(guid).isFailure()) {
236 ATH_MSG_ERROR("Unable to call beginInputFile for " << tool->name());
237 rc = StatusCode::FAILURE;
238 }
239 }
240 return rc;
241}
static Double_t rc
bool m_allowMetaDataStop

◆ outputDataStore()

virtual StoreGateSvc * MetaDataSvc::outputDataStore ( ) const
inlinefinaloverridevirtual

Definition at line 235 of file MetaDataSvc.h.

235 {
236 return &*m_outputDataStore;
237 }

◆ preLoadAddresses()

StatusCode MetaDataSvc::preLoadAddresses ( StoreID::type ,
IAddressProvider::tadList &  )
inlineoverride

does nothing.

Parameters
storeID[IN] store ID, this function only preloads detector store addresses.
tads[OUT] list of the transient addresses which were preloaded.
Returns
SUCCESS

Definition at line 184 of file MetaDataSvc.h.

185 {
186 return StatusCode::SUCCESS;
187 }

◆ prepareOutput()

StatusCode MetaDataSvc::prepareOutput ( )
virtual

Makes the metadata store ready for output.

Calls the metaDataStop method of all MetaDataTool interfaces in m_metaDataTool. Then release the metadata tools. This implementation assumes SharedWriter is not being used.

Returns
SUCCESS unless a MetaDataTool fails, then FAILURE

Definition at line 260 of file MetaDataSvc.cxx.

261{
262 if (m_outputPrepared) {
263 return StatusCode::SUCCESS;
264 }
265
266 StatusCode rc{StatusCode::SUCCESS};
267 for (auto& tool : m_metaDataTools) {
268 ATH_MSG_DEBUG(" calling metaDataStop for " << tool->name());
269 if (tool->metaDataStop().isFailure()) {
270 ATH_MSG_ERROR("Unable to call metaDataStop for " << tool->name());
271 rc = StatusCode::FAILURE;
272 }
273 }
274 if (!m_metaDataTools.release().isSuccess()) {
275 ATH_MSG_WARNING("Cannot release " << m_metaDataTools);
276 }
277
278 m_outputPrepared = true;
279 return rc;
280}

◆ recordHook()

void MetaDataSvc::recordHook ( const std::type_info & typeInfo)
override

Definition at line 574 of file MetaDataSvc.cxx.

574 {
575 const std::string& typeName = System::typeinfoName(typeInfo);
576 ATH_MSG_VERBOSE("Handling record event of type " << typeName);
577
578 CLID itemID = 0;
579 if (m_classIDSvc->getIDOfTypeInfoName(typeName, itemID).isSuccess()) {
580 auto result = m_handledClasses.insert(itemID);
581 if (result.second)
582 ATH_MSG_DEBUG("MetaDataSvc will handle " << typeName
583 << " ClassID: " << itemID);
584 }
585}
std::set< CLID > m_handledClasses
ServiceHandle< IClassIDSvc > m_classIDSvc

◆ remapMetaContCLID()

CLID MetaDataSvc::remapMetaContCLID ( const CLID & item_id) const

Definition at line 554 of file MetaDataSvc.cxx.

555{
556 if (!m_handledClasses.contains(itemID)) {
557 ATH_MSG_DEBUG("Not translating metadata item ID #" << itemID);
558 return itemID;
559 }
560
561 std::string itemName;
562 CLID contID = 0;
563 if (m_classIDSvc->getTypeNameOfID(itemID, itemName).isSuccess()) {
564 const std::string contName = std::format("MetaCont<{}>", itemName);
565 ATH_MSG_DEBUG("Transforming " << contName << " to " << itemName
566 << " for output");
567 if (m_classIDSvc->getIDOfTypeName(contName, contID).isSuccess())
568 return contID;
569 }
570
571 return itemID;
572}

◆ removeHook()

void MetaDataSvc::removeHook ( const std::type_info & typeInfo)
override

Definition at line 587 of file MetaDataSvc.cxx.

587 {
588 const std::string& typeName = System::typeinfoName(typeInfo);
589 ATH_MSG_VERBOSE("Handling removal event of type " << typeName);
590
591 CLID itemID = 0;
592 if (m_classIDSvc->getIDOfTypeInfoName(typeName, itemID).isSuccess()) {
593 if (0 < m_handledClasses.erase(itemID))
594 ATH_MSG_DEBUG("MetaDataSvc will no longer handle " << typeName
595 << " ClassID: " << itemID);
596 }
597}

◆ removeStreamFromKey()

std::string MetaDataSvc::removeStreamFromKey ( std::string & key)

check if the metadata object key contains Stream name (added by SharedWriter in MetaDataSvc) remove stream part from the key (i.e.

modify the parameter) and return it

Definition at line 396 of file MetaDataSvc.cxx.

396 {
397 size_t pos = key.find(m_streamInKeyMark);
398 if( pos==std::string::npos ) return "";
399 size_t epos = key.find(']', pos);
400 size_t spos = pos + m_streamInKeyMark.size();
401 std::string stream = key.substr( spos, epos - spos );
402 //cppcheck-suppress uselessCallsSubstr
403 key = key.substr(0, pos) + key.substr(epos+1);
404 return stream;
405}

◆ retireMetadataSource()

StatusCode MetaDataSvc::retireMetadataSource ( const Incident & inc)
virtual

Allows metadata tools to act before an input file is closed.

Grabs the file GUID then calls the the endInputFile method of all metadata tools in m_metaDataTools providing the GUID as argument.

Parameters
incis a file incident fired before closing an input file
Returns
SUCCESS unless a MetaDataTool fails, then FAILURE

Definition at line 243 of file MetaDataSvc.cxx.

244{
245 const FileIncident* fileInc = dynamic_cast<const FileIncident*>(&inc);
246 if (fileInc == nullptr) {
247 ATH_MSG_ERROR("Unable to get FileName from EndInputFile incident");
248 return StatusCode::FAILURE;
249 }
250 const std::string guid = fileInc->fileGuid();
251 ATH_MSG_DEBUG("retireMetadataSource: " << fileInc->fileName());
252 for (auto& tool : m_metaDataTools) {
253 ATH_MSG_DEBUG(" calling endInputFile on " << tool->name() << " for GUID \"" << guid << "\"");
254 ATH_CHECK(tool->endInputFile(guid));
255 }
256 m_allowMetaDataStop = true;
257 return StatusCode::SUCCESS;
258}

◆ rootOpenAction()

StatusCode MetaDataSvc::rootOpenAction ( FILEMGR_CALLBACK_ARGS )

Definition at line 390 of file MetaDataSvc.cxx.

390 {
391 return(StatusCode::SUCCESS);
392}

◆ stop()

StatusCode MetaDataSvc::stop ( )
overridevirtual

stop the metadata service

Definition at line 169 of file MetaDataSvc.cxx.

169 {
170 ATH_MSG_DEBUG("MetaDataSvc::stop()");
171 // Fire metaDataStopIncident
172 Incident metaDataStopIncident(name(), "MetaDataStop");
173 m_incSvc->fireIncident(metaDataStopIncident);
174 return(StatusCode::SUCCESS);
175}

◆ transitionMetaDataFile()

StatusCode MetaDataSvc::transitionMetaDataFile ( const std::string & outputConn,
bool disconnect )

Transition output metadata file - fire MeteDataStop incident to transition OutputStream and disconnect now if requested.

Definition at line 352 of file MetaDataSvc.cxx.

353{
354 ATH_MSG_DEBUG("transitionMetaDataFile: " << outputConn );
355
356 // this is normally called through EndInputFile inc, simulate it for EvSvc
357 FileIncident inc("transitionMetaDataFile", "EndInputFile", "dummyMetaInputFileName", "");
359
360 // Reset flag to allow calling prepareOutput again at next transition
361 m_outputPrepared = false;
362
363 Incident metaDataStopIncident(name(), "MetaDataStop");
364 m_incSvc->fireIncident(metaDataStopIncident);
365
366 if( disconnect ) {
367 AthCnvSvc* cnvSvc = dynamic_cast<AthCnvSvc*>(m_addrCrtr.operator->());
368 if (cnvSvc) {
369 if (!cnvSvc->disconnectOutput(outputConn).isSuccess()) {
370 ATH_MSG_WARNING("Cannot get disconnect Output Files");
371 }
372 }
373 }
374
375 return(StatusCode::SUCCESS);
376}
virtual StatusCode disconnectOutput(const std::string &output)
Disconnect output files from the service.

◆ unlockTools()

void MetaDataSvc::unlockTools ( ) const

Definition at line 607 of file MetaDataSvc.cxx.

607 {
608 ATH_MSG_DEBUG("Unlocking metadata tools");
609 for(auto& tool : m_metaDataTools ) {
610 const ILockableTool *lockable = dynamic_cast<const ILockableTool*>( tool.get() );
611 if( lockable ) lockable->unlock_shared();
612 }
613}
virtual void unlock_shared() const =0
Unlock the tool.

◆ updateAddress()

StatusCode MetaDataSvc::updateAddress ( StoreID::type ,
SG::TransientAddress * ,
const EventContext &  )
inlineoverride

always fails

Parameters
storeID[IN] the identity of the store
tad[IN] transient address to be updated
ctx[IN] current event's context information
Returns
FAILURE

Definition at line 208 of file MetaDataSvc.h.

210 {
211 return StatusCode::FAILURE;
212 }

Member Data Documentation

◆ m_addrCrtr

ServiceHandle<IAddressCreator> MetaDataSvc::m_addrCrtr { this, "ConversionService", "AthenaPoolCnvSvc" }
private

Definition at line 300 of file MetaDataSvc.h.

300{ this, "ConversionService", "AthenaPoolCnvSvc" };

◆ m_allowMetaDataStop

bool MetaDataSvc::m_allowMetaDataStop {false}
private

Definition at line 309 of file MetaDataSvc.h.

309{false};

◆ m_classIDSvc

ServiceHandle<IClassIDSvc> MetaDataSvc::m_classIDSvc {"ClassIDSvc", name()}
private

Definition at line 304 of file MetaDataSvc.h.

304{"ClassIDSvc", name()};

◆ m_clearedInputDataStore

bool MetaDataSvc::m_clearedInputDataStore {true}
private

Definition at line 307 of file MetaDataSvc.h.

307{true};

◆ m_clearedOutputDataStore

bool MetaDataSvc::m_clearedOutputDataStore {false}
private

Definition at line 308 of file MetaDataSvc.h.

308{false};

◆ m_fileMgr

ServiceHandle<IFileMgr> MetaDataSvc::m_fileMgr
private

Definition at line 301 of file MetaDataSvc.h.

◆ m_handledClasses

std::set<CLID> MetaDataSvc::m_handledClasses {}
private

Definition at line 313 of file MetaDataSvc.h.

313{};

◆ m_incSvc

ServiceHandle<IIncidentSvc> MetaDataSvc::m_incSvc
private

Definition at line 302 of file MetaDataSvc.h.

◆ m_inputDataStore

ServiceHandle<StoreGateSvc> MetaDataSvc::m_inputDataStore
private

Definition at line 298 of file MetaDataSvc.h.

◆ m_metaDataCont

Gaudi::Property<std::string> MetaDataSvc::m_metaDataCont {this, "MetaDataContainer", ""}
private

MetaDataContainer, POOL container name for MetaData.

Definition at line 321 of file MetaDataSvc.h.

321{this, "MetaDataContainer", ""};

◆ m_metaDataTools

PublicToolHandleArray<IMetaDataTool> MetaDataSvc::m_metaDataTools {this, "MetaDataTools", {}}
private

MetaDataTools, vector with the MetaData tools.

Definition at line 323 of file MetaDataSvc.h.

323{this, "MetaDataTools", {}};

◆ m_outputDataStore

ServiceHandle<StoreGateSvc> MetaDataSvc::m_outputDataStore
private

Definition at line 299 of file MetaDataSvc.h.

◆ m_outputPrepared

bool MetaDataSvc::m_outputPrepared {false}
private

Definition at line 310 of file MetaDataSvc.h.

310{false};

◆ m_outSeqSvc

ServiceHandle<OutputStreamSequencerSvc> MetaDataSvc::m_outSeqSvc
private

Definition at line 303 of file MetaDataSvc.h.

◆ m_persToClid

std::map<std::string_view, CLID> MetaDataSvc::m_persToClid {}
private

Definition at line 311 of file MetaDataSvc.h.

311{};

◆ m_storageType

long MetaDataSvc::m_storageType {0L}
private

Definition at line 306 of file MetaDataSvc.h.

306{0L};

◆ m_streamInKeyMark

std::string_view MetaDataSvc::m_streamInKeyMark {"__STREAM["}
staticconstexprprivate

marker string for embedding stream name in MetaData object keys for SharedWriter server

Definition at line 315 of file MetaDataSvc.h.

315{"__STREAM["};

◆ m_streamKeys

std::map< std::string, std::set<std::string> > MetaDataSvc::m_streamKeys {}
private

Definition at line 317 of file MetaDataSvc.h.

317{};

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