27#include "Gaudi/Property.h"
30#include "GaudiKernel/FileIncident.h"
31#include "GaudiKernel/IIoComponentMgr.h"
32#include "GaudiKernel/ISvcLocator.h"
33#include "GaudiKernel/ITHistSvc.h"
34#include "GaudiKernel/MsgStream.h"
35#include "GaudiKernel/StatusCode.h"
36#include "GaudiKernel/System.h"
37#include "GaudiKernel/IClassIDSvc.h"
53#include "EventInfo/EventInfo.h"
66#include "GaudiKernel/ServiceHandle.h"
93 const std::vector<std::string>&
files()
const {
return m_evtsel->m_inputCollectionsName.value(); }
111 ISvcLocator* svcLoc ) :
112 base_class ( name, svcLoc ),
114 m_imetaStore(
"StoreGateSvc/InputMetaDataStore", name ),
120 m_ppSvc (
"ProxyProviderSvc" , name ),
133 declareProperty(
"SkipEvents",
m_skipEvts = 0,
"Number of events to skip at the beginning" );
134 declareProperty(
"AccessMode",
m_accessMode = -1,
"-1 = use TEvent Default; 0 = BranchAccess; 1 = ClassAccess; 2 = AthenaAccess" );
136 declareProperty(
"FillEventInfo",
m_fillEventInfo=
false,
"If True, will fill old EDM EventInfo with xAOD::EventInfo content, necessary for database reading (IOVDbSvc)");
138 declareProperty(
"PrintPerfStats",
m_printPerfStats=
false,
"If True, at end of job will print the xAOD perf stats");
141 declareProperty(
"EvtStore",
m_dataStore,
"Store where to publish data");
142 declareProperty(
"ProxyProviderSvc" ,
m_ppSvc ,
"The ProxyProviderSvc that we should register ourself in and connect the EvtStore to");
143 declareProperty(
"InputMetaStore",
m_imetaStore,
"Store where to publish (input) metadata");
144 declareProperty(
"MetaStore",
m_ometaStore,
"Store where to publish (output) metadata");
145 declareProperty(
"TreeName",
m_tupleName =
"CollectionTree",
"Name of the TTree to load/read from input file(s)" );
146 declareProperty(
"MetaDataTreeName",
m_metadataName =
"MetaData",
"Name of the TTree to load/read metadata from input file(s)" );
148 declareProperty(
"ReadMetaDataWithPool",
m_readMetadataWithPool=
false,
"If true, using POOL to read metadata, will ensure input file is registered with catalog");
152 declareProperty(
"CollectionType",
m_collectionType=
"",
"Compability flag for RecExCommon");
170 ATH_MSG_ERROR(
"You have to give a TTree name to read from the ROOT files !");
171 return StatusCode::FAILURE;
175 if ( nbrInputFiles < 1 ) {
177 <<
"(Got [" << nbrInputFiles <<
"] file instead !)");
178 return StatusCode::FAILURE;
180 ATH_MSG_INFO(
"Selector configured to read [" << nbrInputFiles <<
"] file(s)...");
184 int old_level = gErrorIgnoreLevel;
185 gErrorIgnoreLevel = kWarning;
187 gErrorIgnoreLevel = old_level;
189 if(serviceLocator()->existsService(
"AthROOTErrorHandlerSvc")) {
191 CHECK( ehSvc.retrieve() );
192 CHECK( ehSvc->initialize() );
193 CHECK( ehSvc.release() );
196 case -1:
ATH_MSG_INFO(
"Using DEFAULT xAOD access mode (usually same as CLASS mode)");
break;
197 case 0:
ATH_MSG_INFO(
"Using BRANCH xAOD access mode");
break;
198 case 1:
ATH_MSG_INFO(
"Using CLASS xAOD access mode");
break;
199 case 2:
ATH_MSG_INFO(
"Using ATHENA xAOD access mode");
break;
213 return StatusCode::FAILURE;
215 if(!f->Get(
"##Shapes")) {
216 ATH_MSG_INFO(
"First file is not POOL file (e.g. is CxAOD), so reading metadata with xAOD::TEvent instead");
226 if (!iomgr.retrieve().isSuccess()) {
228 return StatusCode::FAILURE;
230 if (!iomgr->io_register(
this).isSuccess()) {
231 ATH_MSG_FATAL(
"Could not register myself with the IoComponentMgr !");
232 return StatusCode::FAILURE;
237 for (std::size_t icol = 0,
imax = incol.size(); icol <
imax; icol++) {
238 if (!iomgr->io_register(
this,
239 IIoComponentMgr::IoMode::READ,
240 incol[icol]).isSuccess()) {
241 ATH_MSG_FATAL(
"could not register [" << incol[icol] <<
"] for output !");
244 ATH_MSG_VERBOSE(
"io_register[" << this->name() <<
"](" << incol[icol] <<
") [ok]");
248 return StatusCode::FAILURE;
253 return StatusCode::FAILURE;
285 std::vector<std::string> propVal;
287 bool foundSvc(
false);
bool foundPoolSvc(
false);
288 for(
const std::string& s : propVal) {
289 if(s==
"Athena::xAODCnvSvc") { foundSvc=
true; }
290 if(s==
"AthenaPoolCnvSvc") { foundPoolSvc=
true; }
292 if(!foundSvc) propVal.push_back(
"Athena::xAODCnvSvc");
296 CHECK( epSvc->setProperty(
"CnvServices", Gaudi::Utils::toString( propVal ) ));
305 std::vector<std::string> propVal;
306 IProperty* prop =
dynamic_cast<IProperty*
>(&*
m_ppSvc);
308 return StatusCode::FAILURE;
311 bool foundSvc(
false);
312 for(
const std::string& s : propVal) {
313 if(s==
"MetaDataSvc") { foundSvc=
true;
break; }
316 propVal.push_back(
"MetaDataSvc");
317 IProperty* prop =
dynamic_cast<IProperty*
>(&*
m_ppSvc);
319 return StatusCode::FAILURE;
321 CHECK( prop->setProperty(
"ProviderNames", Gaudi::Utils::toString( propVal ) ));
349 return StatusCode::SUCCESS;
357 return StatusCode::SUCCESS;
373 return StatusCode::SUCCESS;
391 throw GaudiException(
"xAODEventSelector::next() - Unable to get xAODEventContext",
"xAODEventSelector",StatusCode::FAILURE);
404 auto& fnames = rctx->
files();
406 if( rctx->setFile(
"").isFailure() ) {
407 throw GaudiException(
"xAODEventSelector::next() - Fatal error when trying to setFile('')",
"xAODEventSelector",StatusCode::FAILURE);
413 if( rctx->setFile( fname ).isFailure() ) {
414 throw GaudiException(
"xAODEventSelector::next() - Fatal error when trying to setFile('" + fname +
"')",
"xAODEventSelector",StatusCode::FAILURE);
419 rctx->
file()->GetName(), {},
420 rctx->
file()->GetName());
423 return StatusCode::FAILURE;
437 int64_t global_entry = rctx->
entry();
438 int64_t
entry = global_entry;
452 if(
m_tevent->getEntry( entry ) < 0 ) {
453 ATH_MSG_ERROR(
"Failed to load entry " <<
static_cast< int >( entry ) );
454 throw GaudiException(
"xAODEventSelector::next() - xAOD::TEvent::getEntry returned less than 0 bytes",
"xAODEventSelector",StatusCode::FAILURE);
466 if(
m_tevent->retrieve( xaodEventInfo ,
"EventInfo").isFailure()) {
468 throw GaudiException(
"xAODEventSelector::next() - Could not find xAOD::EventInfo",
"xAODEventSelector",StatusCode::FAILURE);
471 EventType* evtType =
new EventType;
475 if ( !
m_dataStore->record( evtInfo,
"EventInfo" ).isSuccess() ) {
477 delete evtInfo; evtInfo = 0;
478 throw GaudiException(
"xAODEventSelector::next() - Could not record EventInfo",
"xAODEventSelector",StatusCode::FAILURE);
481 return StatusCode::SUCCESS;
510 iaddr.second =
false;
511 SG::TransientAddress* taddr = iaddr.first;
514 const bool forceRemove =
false;
519 CHECK( rctx->setFile(
"") );
534 return StatusCode::FAILURE;
542 return next( ctx, -1 );
548 return next( ctx, -jump );
554 ATH_MSG_ERROR (
"............. Last Event Not Implemented .............");
555 return StatusCode::FAILURE;
570 return StatusCode::SUCCESS;
575 IOpaqueAddress*& )
const
578 return StatusCode::SUCCESS;
584 if(refCtxt==0)
return StatusCode::SUCCESS;
588 return StatusCode::SUCCESS;
591 return StatusCode::FAILURE;
597 ATH_MSG_ERROR (
"............. resetCriteria Not Implemented .............");
598 return StatusCode::FAILURE;
622 if (coll_idx == -1 && evtnum <
m_curEvt) {
626 if (coll_idx == -1) {
628 return StatusCode::RECOVERABLE;
635 return StatusCode::FAILURE;
643 return StatusCode::SUCCESS;
664 if (!iomgr.retrieve().isSuccess()) {
666 return StatusCode::FAILURE;
668 if (!iomgr->io_hasitem(
this)) {
669 ATH_MSG_FATAL(
"IoComponentMgr does not know about myself !");
670 return StatusCode::FAILURE;
679 std::string &fname = inputCollections[i];
681 if (!iomgr->io_contains(
this, fname)) {
682 ATH_MSG_ERROR(
"IoComponentMgr does not know about [" << fname <<
"] !");
683 return StatusCode::FAILURE;
685 if (!iomgr->io_retrieve(
this, fname).isSuccess()) {
686 ATH_MSG_FATAL(
"Could not retrieve new value for [" << fname <<
"] !");
687 return StatusCode::FAILURE;
707 return StatusCode::FAILURE;
711 return StatusCode::SUCCESS;
725 return StatusCode::SUCCESS;
737 return StatusCode::SUCCESS;
743 const EventContext& )
749 return StatusCode::SUCCESS;
752 << tad->
name() <<
") NOT known to us.");
753 return StatusCode::FAILURE;
757 return StatusCode::SUCCESS;
774 return(StatusCode::SUCCESS);
779 return StatusCode::FAILURE;
793 std::set<std::string> missingAux;
795 for(
auto itr =
m_tevent->inputEventFormat()->begin(); itr!=
m_tevent->inputEventFormat()->end();++itr) {
796 if(inputTree->GetBranch(itr->second.branchName().c_str())==0)
continue;
797 ATH_MSG_VERBOSE(
"EFE:" << itr->first <<
" branchName = " << itr->second.branchName() <<
" className=" << itr->second.className());
799 if(
m_clidsvc->getIDOfTypeInfoName(itr->second.className(),
id).isFailure() &&
800 m_clidsvc->getIDOfTypeName(itr->second.className(),
id).isFailure()) {
802 if(itr->second.branchName().compare(itr->second.branchName().length()-4,4,
"Aux.")==0) {
803 missingAux.insert( itr->second.className() );
continue;
806 TString className = itr->second.className();
810 TClass *cls = TClass::GetClass(className);
812 const std::type_info *ti = cls->GetTypeInfo();
813 if(ti) className = System::typeinfoName(*ti);
816 if(
m_clidsvc->getIDOfTypeInfoName(className.Data(),
id).isFailure() &&
817 m_clidsvc->getIDOfTypeName(className.Data(),
id).isFailure()) {
818 ATH_MSG_WARNING(
"No CLID for class " << itr->second.className() <<
" , cannot read " << itr->second.branchName());
824 const std::string br_name = itr->second.branchName();
830 (
unsigned long)(value_ptr),
843 if (old->clID() ==
id &&
844 old->name() == br_name) {
847 old->setAddress(addr);
849 iaddr->second =
true;
859 tads.push_back(taddr);
869 if(missingAux.size()) {
870 std::string allAux;
for(
auto& s : missingAux) allAux += s +
", ";
871 ATH_MSG_WARNING(
"The following AuxStore types are not directly accessible (missing CLID, possibly from schema evolution): " << allAux);
880 ATH_MSG_DEBUG(
"In xAODEventSelector::createRootBranchAddresses end ...");
882 return StatusCode::SUCCESS;
889 ATH_MSG_DEBUG(
"In xAODEventSelector::createMetaDataRootBranchAddresses start ...");
893 throw "xAODEventSelector: Unable to get m_tfile";
901 if (!
tree) std::abort();
902 TObjArray *leaves =
tree->GetListOfLeaves();
905 return StatusCode::SUCCESS;
909 for (Int_t i = 0; i < leaves->GetEntries(); ++i) {
910 TLeaf *leaf = (TLeaf *)leaves->At(i);
911 TBranch *branch = leaf->GetBranch();
916 const std::string type_name = leaf->GetTypeName();
917 const std::string br_name = branch->GetName();
919 const std::string toCheck =
"xAOD::";
920 if (type_name.find(toCheck) == std::string::npos) {
921 ATH_MSG_DEBUG(
"** Skip type-name = " << type_name <<
", br_name = " << br_name );
924 const std::string sg_key = br_name;
925 TClass *cls = TClass::GetClass(type_name.c_str());
926 const std::type_info *ti = 0;
930 if( br_name ==
"EventFormat" )
continue;
933 ti = cls->GetTypeInfo();
949 << type_name <<
"]");
955 ATH_MSG_DEBUG(
"id = " <<
id <<
", m_metadataName.value() = " <<
m_metadataName.value() <<
", br_name = " << br_name <<
", value_ptr = " << value_ptr);
961 (
unsigned long)(value_ptr),
962 (
unsigned long)(1)));
963 if (!
m_imetaStore->recordAddress(br_name, std::move(addr),
true).isSuccess()) {
964 ATH_MSG_ERROR(
"could not record address at [" << br_name <<
"] in store ["
976 ATH_MSG_DEBUG(
"In xAODEventSelector::createMetaDataRootBranchAddresses end ...");
978 return StatusCode::SUCCESS;
986 if(fname.empty())
return file;
989 file = (TFile*)gROOT->GetListOfFiles()->FindObject(fname.c_str());
992 file = TFile::Open(fname.c_str(),
"READ");
993 if (
file)
file->SetName(fname.c_str());
997 ATH_MSG_ERROR(
"could not open next file in input collection ["
1011 if(!newFile && !fname.empty()) {
1012 ATH_MSG_FATAL(
"xAODEventSelector: Unable to fetch Ntuple: " << fname);
1013 return StatusCode::FAILURE;
1017 const std::string currFile =
m_tfile->GetName();
1019 m_poolSvc->disconnectDb(
"PFN:"+currFile).ignore();
1027 if(!
m_tfile)
return StatusCode::SUCCESS;
1030 ATH_MSG_FATAL(
"xAODEventSelector: TEvent cannot read " << fname);
1031 return StatusCode::FAILURE;
1039 return StatusCode::FAILURE;
1046 m_poolSvc->createCollection(
"PFN:"+fname , fname );
1057 return StatusCode::SUCCESS;
1070 zero.min_entries = -1;
1071 zero.max_entries = -1;
1091 return StatusCode::SUCCESS;
1119 throw "xAODEventSelector: Unable to fetch ntuple";
#define ATH_CHECK
Evaluate an expression and check for errors.
#define ATH_MSG_VERBOSE(x)
#define ATH_MSG_WARNING(x)
a static registry of CLID->typeName entries.
macros to associate a CLID to a type
#define CHECK(...)
Evaluate an expression and check for errors.
This class provides a unique identification for each event, in terms of run/event number and/or a tim...
This class provides general information about an event.
uint32_t CLID
The Class ID type.
Include TBranchElement.h, suppressing clang warnings.
Define macros for attributes used to control the static checker.
#define ATLAS_THREAD_SAFE
state of a few global resources from ROOT and restores their initial value upon d-tor call.
A simple class to do the retrieve from TEvent.
event selector context ... just holds reference back to the selector
int64_t entry() const
access to the current event entry number
StatusCode setFile ATLAS_NOT_THREAD_SAFE(const std::string &fname)
call to setFile on evtSel
std::size_t fileIndex() const
access to the file iterator
virtual void * identifier() const override
identifier method required by IEvtSelector::Context
const std::vector< std::string > & files() const
access to the container of files
xAODEventContext(const xAODEventSelector *sel)
standard c-tor with initialization
const xAODEventSelector * m_evtsel
reference to the hosting event selector instance
const TFile * file() const
access to the current file
virtual ~xAODEventContext()
standard d-tor
Class implementing the GAUDI IEvtSelector interface using ROOT TTree as a backend.
ServiceHandle< StoreGateSvc > m_ometaStore
Pointer to the StoreGateSvc output metadata store.
std::optional< InputFileIncidentGuard > m_inputFileGuard
RAII guard: guarantees a matching EndInputFile for every BeginInputFile.
virtual StatusCode updateAddress(StoreID::type storeID, SG::TransientAddress *tad, const EventContext &ctx) override
update a transient Address
virtual int size(Context &refCtxt) const override
ICollectionSize interface
StringProperty m_tupleName
Name of TTree to load from collection of input files.
virtual StatusCode next(Context &refCtxt) const override
xAODEventSelector(const std::string &name, ISvcLocator *svcLoc)
Constructor with parameters:
long m_nbrEvts
Number of Events read so far.
ServiceHandle< IDictLoaderSvc > m_dictsvc
Pointer to the IDictLoaderSvc.
TFile * m_tfile
current TFile being read
virtual StatusCode resetCriteria(const std::string &cr, Context &ctx) const override
StringArrayProperty m_inputCollectionsName
List of input files containing TTree.
StatusCode createRootBranchAddresses(StoreID::type storeID, tadList &tads)
helper method to create proxies
int find_coll_idx(int evtidx) const
helper method to get the collection index (into m_inputCollectionsName) for a given event index evtid...
StatusCode createMetaDataRootBranchAddresses() const
helper method to create proxies for the metadata store
bool m_readMetadataWithPool
StringProperty m_collectionType
virtual StatusCode releaseContext(Context *&refCtxt) const override
friend class Athena::xAODEventContext
StringProperty m_metadataName
Name of TTree to load from metadata of input files.
xAOD::xAODTEvent * m_tevent
current TEvent being read
xAODEventSelector * self() const
non-const access to self (b/c next() is const)
std::vector< CollMetaData > m_collEvts
cache of the number of entries for each collection
StatusCode do_init_io()
helper method to init the i/o components
virtual StatusCode initialize() override
virtual StatusCode io_reinit() override
Callback method to reinitialize the internal state of the component for I/O purposes (e....
ServiceHandle< IProxyProviderSvc > m_ppSvc
Handle to the proxy provider svc.
virtual StatusCode loadAddresses(StoreID::type storeID, tadList &list) override
get all new addresses from Provider for this Event.
ServiceHandle< StoreGateSvc > m_dataStore
Pointer to the StoreGateSvc event store.
bool m_printEventProxyWarnings
StatusCode setFile(const std::string &fname)
switch to given file, loading metadata and triggering a beginInputFile incident
virtual StatusCode previous(Context &refCtxt) const override
std::unordered_map< SG::TransientAddress *, bool > m_rootAddresses
virtual int curEvent(const Context &refCtxt) const override
return the current event number.
ServiceHandle< IIncidentSvc > m_incsvc
Handle to the incident service.
virtual StatusCode createAddress(const Context &refCtxt, IOpaqueAddress *&) const override
virtual StatusCode finalize() override
ServiceHandle< IClassIDSvc > m_clidsvc
Pointer to the IClassIDSvc.
virtual StatusCode last(Context &refContext) const override
virtual StatusCode seek(Context &refCtxt, int evtnum) const override
Seek to a given event number.
TFile * fetchNtupleFile(const std::string &fname) const
helper method to retrieve the correct tuple
long m_curEvt
current event index
ServiceHandle< IPoolSvc > m_poolSvc
Handle to the PoolSvc (used in Hybrid mode when user is reading metadata with pool).
virtual StatusCode createContext(Context *&refpCtxt) const override
virtual ~xAODEventSelector()
Destructor:
long m_skipEvts
Number of events to skip at the beginning.
virtual StatusCode rewind(Context &refCtxt) const override
long m_collIdx
current collection index (into m_inputCollectionsName)
virtual void handle(const Incident &incident) override
virtual StatusCode stop() override
virtual StatusCode preLoadAddresses(StoreID::type storeID, tadList &list) override
ServiceHandle< StoreGateSvc > m_imetaStore
Pointer to the StoreGateSvc input metadata store.
static CLID typeinfoToCLID(const std::type_info &ti)
Return the CLID corresponding to a type_info.
Simple smart pointer for Gaudi-style refcounted objects.
CLID clID() const
Retrieve string key:
void clearAddress(const bool &flag)
Return the clearAddress flag.
const std::string & name() const
Get the primary (hashed) SG key.
void setAddress(CxxUtils::RefCountedPtr< IOpaqueAddress > pAddress)
Retrieve primary clid.
void setProvider(IAddressProvider *provider, StoreID::type storeID)
uint32_t lumiBlock() const
The current event's luminosity block number.
uint32_t bcid() const
The bunch crossing ID of the event.
uint32_t timeStamp() const
POSIX time in seconds from 1970. January 1st.
uint32_t runNumber() const
The current event's run number.
uint32_t timeStampNSOffset() const
Nanosecond time offset wrt. the time stamp.
uint64_t eventNumber() const
The current event's event number.
ReadStats & stats()
Access the object belonging to the current thread.
static IOStats & instance()
Singleton object accessor.
void stop()
Stop the statistics collection.
void start(bool clear=true)
Start the statistics collection.
static PerfStats & instance()
Function accessing the singleton instance.
void Print(::Option_t *option="") const
Print information about the collected statistics.
EAuxMode
Auxiliary store "mode".
void zero(TH2 *h)
zero the contents of a 2d histogram
Some weak symbol referencing magic... These are declared in AthenaKernel/getMessageSvc....
StatusCode parse(std::tuple< Tup... > &tup, const Gaudi::Parsers::InputData &input)
static const DbType ROOT_StorageType
StatusCode Init(const char *appname)
Function initialising ROOT/PyROOT for using the ATLAS EDM.
EventInfo_v1 EventInfo
Definition of the latest event info version.