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"
52#include "EventInfo/EventInfo.h"
65#include "GaudiKernel/ServiceHandle.h"
92 const std::vector<std::string>&
files()
const {
return m_evtsel->m_inputCollectionsName.value(); }
110 ISvcLocator* svcLoc ) :
111 base_class ( name, svcLoc ),
113 m_imetaStore(
"StoreGateSvc/InputMetaDataStore", name ),
119 m_ppSvc (
"ProxyProviderSvc" , name ),
132 declareProperty(
"SkipEvents",
m_skipEvts = 0,
"Number of events to skip at the beginning" );
133 declareProperty(
"AccessMode",
m_accessMode = -1,
"-1 = use TEvent Default; 0 = BranchAccess; 1 = ClassAccess; 2 = AthenaAccess" );
135 declareProperty(
"FillEventInfo",
m_fillEventInfo=
false,
"If True, will fill old EDM EventInfo with xAOD::EventInfo content, necessary for database reading (IOVDbSvc)");
137 declareProperty(
"PrintPerfStats",
m_printPerfStats=
false,
"If True, at end of job will print the xAOD perf stats");
140 declareProperty(
"EvtStore",
m_dataStore,
"Store where to publish data");
141 declareProperty(
"ProxyProviderSvc" ,
m_ppSvc ,
"The ProxyProviderSvc that we should register ourself in and connect the EvtStore to");
142 declareProperty(
"InputMetaStore",
m_imetaStore,
"Store where to publish (input) metadata");
143 declareProperty(
"MetaStore",
m_ometaStore,
"Store where to publish (output) metadata");
144 declareProperty(
"TreeName",
m_tupleName =
"CollectionTree",
"Name of the TTree to load/read from input file(s)" );
145 declareProperty(
"MetaDataTreeName",
m_metadataName =
"MetaData",
"Name of the TTree to load/read metadata from input file(s)" );
147 declareProperty(
"ReadMetaDataWithPool",
m_readMetadataWithPool=
false,
"If true, using POOL to read metadata, will ensure input file is registered with catalog");
151 declareProperty(
"CollectionType",
m_collectionType=
"",
"Compability flag for RecExCommon");
169 ATH_MSG_ERROR(
"You have to give a TTree name to read from the ROOT files !");
170 return StatusCode::FAILURE;
174 if ( nbrInputFiles < 1 ) {
176 <<
"(Got [" << nbrInputFiles <<
"] file instead !)");
177 return StatusCode::FAILURE;
179 ATH_MSG_INFO(
"Selector configured to read [" << nbrInputFiles <<
"] file(s)...");
183 int old_level = gErrorIgnoreLevel;
184 gErrorIgnoreLevel = kWarning;
186 gErrorIgnoreLevel = old_level;
188 if(serviceLocator()->existsService(
"AthROOTErrorHandlerSvc")) {
190 CHECK( ehSvc.retrieve() );
191 CHECK( ehSvc->initialize() );
192 CHECK( ehSvc.release() );
195 case -1:
ATH_MSG_INFO(
"Using DEFAULT xAOD access mode (usually same as CLASS mode)");
break;
196 case 0:
ATH_MSG_INFO(
"Using BRANCH xAOD access mode");
break;
197 case 1:
ATH_MSG_INFO(
"Using CLASS xAOD access mode");
break;
198 case 2:
ATH_MSG_INFO(
"Using ATHENA xAOD access mode");
break;
212 return StatusCode::FAILURE;
214 if(!f->Get(
"##Shapes")) {
215 ATH_MSG_INFO(
"First file is not POOL file (e.g. is CxAOD), so reading metadata with xAOD::TEvent instead");
225 if (!iomgr.retrieve().isSuccess()) {
227 return StatusCode::FAILURE;
229 if (!iomgr->io_register(
this).isSuccess()) {
230 ATH_MSG_FATAL(
"Could not register myself with the IoComponentMgr !");
231 return StatusCode::FAILURE;
236 for (std::size_t icol = 0,
imax = incol.size(); icol <
imax; icol++) {
237 if (!iomgr->io_register(
this,
238 IIoComponentMgr::IoMode::READ,
239 incol[icol]).isSuccess()) {
240 ATH_MSG_FATAL(
"could not register [" << incol[icol] <<
"] for output !");
243 ATH_MSG_VERBOSE(
"io_register[" << this->name() <<
"](" << incol[icol] <<
") [ok]");
247 return StatusCode::FAILURE;
252 return StatusCode::FAILURE;
284 std::vector<std::string> propVal;
286 bool foundSvc(
false);
bool foundPoolSvc(
false);
287 for(
const std::string& s : propVal) {
288 if(s==
"Athena::xAODCnvSvc") { foundSvc=
true; }
289 if(s==
"AthenaPoolCnvSvc") { foundPoolSvc=
true; }
291 if(!foundSvc) propVal.push_back(
"Athena::xAODCnvSvc");
295 CHECK( epSvc->setProperty(
"CnvServices", Gaudi::Utils::toString( propVal ) ));
304 std::vector<std::string> propVal;
305 IProperty* prop =
dynamic_cast<IProperty*
>(&*
m_ppSvc);
307 return StatusCode::FAILURE;
310 bool foundSvc(
false);
311 for(
const std::string& s : propVal) {
312 if(s==
"MetaDataSvc") { foundSvc=
true;
break; }
315 propVal.push_back(
"MetaDataSvc");
316 IProperty* prop =
dynamic_cast<IProperty*
>(&*
m_ppSvc);
318 return StatusCode::FAILURE;
320 CHECK( prop->setProperty(
"ProviderNames", Gaudi::Utils::toString( propVal ) ));
348 return StatusCode::SUCCESS;
356 return StatusCode::SUCCESS;
372 return StatusCode::SUCCESS;
390 throw GaudiException(
"xAODEventSelector::next() - Unable to get xAODEventContext",
"xAODEventSelector",StatusCode::FAILURE);
403 auto& fnames = rctx->
files();
405 if( rctx->setFile(
"").isFailure() ) {
406 throw GaudiException(
"xAODEventSelector::next() - Fatal error when trying to setFile('')",
"xAODEventSelector",StatusCode::FAILURE);
412 if( rctx->setFile( fname ).isFailure() ) {
413 throw GaudiException(
"xAODEventSelector::next() - Fatal error when trying to setFile('" + fname +
"')",
"xAODEventSelector",StatusCode::FAILURE);
418 rctx->
file()->GetName(), {},
419 rctx->
file()->GetName());
422 return StatusCode::FAILURE;
436 int64_t global_entry = rctx->
entry();
437 int64_t
entry = global_entry;
451 if(
m_tevent->getEntry( entry ) < 0 ) {
452 ATH_MSG_ERROR(
"Failed to load entry " <<
static_cast< int >( entry ) );
453 throw GaudiException(
"xAODEventSelector::next() - xAOD::TEvent::getEntry returned less than 0 bytes",
"xAODEventSelector",StatusCode::FAILURE);
465 if(
m_tevent->retrieve( xaodEventInfo ,
"EventInfo").isFailure()) {
467 throw GaudiException(
"xAODEventSelector::next() - Could not find xAOD::EventInfo",
"xAODEventSelector",StatusCode::FAILURE);
470 EventType* evtType =
new EventType;
474 if ( !
m_dataStore->record( evtInfo,
"EventInfo" ).isSuccess() ) {
476 delete evtInfo; evtInfo = 0;
477 throw GaudiException(
"xAODEventSelector::next() - Could not record EventInfo",
"xAODEventSelector",StatusCode::FAILURE);
480 return StatusCode::SUCCESS;
509 iaddr.second =
false;
510 SG::TransientAddress* taddr = iaddr.first;
513 const bool forceRemove =
false;
518 CHECK( rctx->setFile(
"") );
533 return StatusCode::FAILURE;
541 return next( ctx, -1 );
547 return next( ctx, -jump );
553 ATH_MSG_ERROR (
"............. Last Event Not Implemented .............");
554 return StatusCode::FAILURE;
569 return StatusCode::SUCCESS;
574 IOpaqueAddress*& )
const
577 return StatusCode::SUCCESS;
583 if(refCtxt==0)
return StatusCode::SUCCESS;
587 return StatusCode::SUCCESS;
590 return StatusCode::FAILURE;
596 ATH_MSG_ERROR (
"............. resetCriteria Not Implemented .............");
597 return StatusCode::FAILURE;
621 if (coll_idx == -1 && evtnum <
m_curEvt) {
625 if (coll_idx == -1) {
627 return StatusCode::RECOVERABLE;
634 return StatusCode::FAILURE;
642 return StatusCode::SUCCESS;
663 if (!iomgr.retrieve().isSuccess()) {
665 return StatusCode::FAILURE;
667 if (!iomgr->io_hasitem(
this)) {
668 ATH_MSG_FATAL(
"IoComponentMgr does not know about myself !");
669 return StatusCode::FAILURE;
678 std::string &fname = inputCollections[i];
680 if (!iomgr->io_contains(
this, fname)) {
681 ATH_MSG_ERROR(
"IoComponentMgr does not know about [" << fname <<
"] !");
682 return StatusCode::FAILURE;
684 if (!iomgr->io_retrieve(
this, fname).isSuccess()) {
685 ATH_MSG_FATAL(
"Could not retrieve new value for [" << fname <<
"] !");
686 return StatusCode::FAILURE;
706 return StatusCode::FAILURE;
710 return StatusCode::SUCCESS;
724 return StatusCode::SUCCESS;
736 return StatusCode::SUCCESS;
742 const EventContext& )
748 return StatusCode::SUCCESS;
751 << tad->
name() <<
") NOT known to us.");
752 return StatusCode::FAILURE;
756 return StatusCode::SUCCESS;
773 return(StatusCode::SUCCESS);
778 return StatusCode::FAILURE;
792 std::set<std::string> missingAux;
794 for(
auto itr =
m_tevent->inputEventFormat()->begin(); itr!=
m_tevent->inputEventFormat()->end();++itr) {
795 if(inputTree->GetBranch(itr->second.branchName().c_str())==0)
continue;
796 ATH_MSG_VERBOSE(
"EFE:" << itr->first <<
" branchName = " << itr->second.branchName() <<
" className=" << itr->second.className());
798 if(
m_clidsvc->getIDOfTypeInfoName(itr->second.className(),
id).isFailure() &&
799 m_clidsvc->getIDOfTypeName(itr->second.className(),
id).isFailure()) {
801 if(itr->second.branchName().compare(itr->second.branchName().length()-4,4,
"Aux.")==0) {
802 missingAux.insert( itr->second.className() );
continue;
805 TString className = itr->second.className();
809 TClass *cls = TClass::GetClass(className);
811 const std::type_info *ti = cls->GetTypeInfo();
812 if(ti) className = System::typeinfoName(*ti);
815 if(
m_clidsvc->getIDOfTypeInfoName(className.Data(),
id).isFailure() &&
816 m_clidsvc->getIDOfTypeName(className.Data(),
id).isFailure()) {
817 ATH_MSG_WARNING(
"No CLID for class " << itr->second.className() <<
" , cannot read " << itr->second.branchName());
823 const std::string br_name = itr->second.branchName();
826 (POOL_ROOTTREE_StorageType,
id,
829 (
unsigned long)(value_ptr),
842 if (old->clID() ==
id &&
843 old->name() == br_name) {
846 old->setAddress(addr);
848 iaddr->second =
true;
858 tads.push_back(taddr);
868 if(missingAux.size()) {
869 std::string allAux;
for(
auto& s : missingAux) allAux += s +
", ";
870 ATH_MSG_WARNING(
"The following AuxStore types are not directly accessible (missing CLID, possibly from schema evolution): " << allAux);
879 ATH_MSG_DEBUG(
"In xAODEventSelector::createRootBranchAddresses end ...");
881 return StatusCode::SUCCESS;
888 ATH_MSG_DEBUG(
"In xAODEventSelector::createMetaDataRootBranchAddresses start ...");
892 throw "xAODEventSelector: Unable to get m_tfile";
900 if (!
tree) std::abort();
901 TObjArray *leaves =
tree->GetListOfLeaves();
904 return StatusCode::SUCCESS;
908 for (Int_t i = 0; i < leaves->GetEntries(); ++i) {
909 TLeaf *leaf = (TLeaf *)leaves->At(i);
910 TBranch *branch = leaf->GetBranch();
915 const std::string type_name = leaf->GetTypeName();
916 const std::string br_name = branch->GetName();
918 const std::string toCheck =
"xAOD::";
919 if (type_name.find(toCheck) == std::string::npos) {
920 ATH_MSG_DEBUG(
"** Skip type-name = " << type_name <<
", br_name = " << br_name );
923 const std::string sg_key = br_name;
924 TClass *cls = TClass::GetClass(type_name.c_str());
925 const std::type_info *ti = 0;
929 if( br_name ==
"EventFormat" )
continue;
932 ti = cls->GetTypeInfo();
948 << type_name <<
"]");
954 ATH_MSG_DEBUG(
"id = " <<
id <<
", m_metadataName.value() = " <<
m_metadataName.value() <<
", br_name = " << br_name <<
", value_ptr = " << value_ptr);
957 (POOL_ROOTTREE_StorageType,
id,
960 (
unsigned long)(value_ptr),
961 (
unsigned long)(1)));
962 if (!
m_imetaStore->recordAddress(br_name, std::move(addr),
true).isSuccess()) {
963 ATH_MSG_ERROR(
"could not record address at [" << br_name <<
"] in store ["
975 ATH_MSG_DEBUG(
"In xAODEventSelector::createMetaDataRootBranchAddresses end ...");
977 return StatusCode::SUCCESS;
985 if(fname.empty())
return file;
988 file = (TFile*)gROOT->GetListOfFiles()->FindObject(fname.c_str());
991 file = TFile::Open(fname.c_str(),
"READ");
992 if (
file)
file->SetName(fname.c_str());
996 ATH_MSG_ERROR(
"could not open next file in input collection ["
1010 if(!newFile && !fname.empty()) {
1011 ATH_MSG_FATAL(
"xAODEventSelector: Unable to fetch Ntuple: " << fname);
1012 return StatusCode::FAILURE;
1016 const std::string currFile =
m_tfile->GetName();
1018 m_poolSvc->disconnectDb(
"PFN:"+currFile).ignore();
1026 if(!
m_tfile)
return StatusCode::SUCCESS;
1029 ATH_MSG_FATAL(
"xAODEventSelector: TEvent cannot read " << fname);
1030 return StatusCode::FAILURE;
1038 return StatusCode::FAILURE;
1045 m_poolSvc->createCollection(
"PFN:"+fname , fname );
1056 return StatusCode::SUCCESS;
1069 zero.min_entries = -1;
1070 zero.max_entries = -1;
1090 return StatusCode::SUCCESS;
1118 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)
StatusCode Init(const char *appname)
Function initialising ROOT/PyROOT for using the ATLAS EDM.
EventInfo_v1 EventInfo
Definition of the latest event info version.