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;
364 return StatusCode::SUCCESS;
382 throw GaudiException(
"xAODEventSelector::next() - Unable to get xAODEventContext",
"xAODEventSelector",StatusCode::FAILURE);
389 m_incsvc->fireIncident(FileIncident(name(),
"BeginInputFile",
file->GetName()));
393 auto& fnames = rctx->
files();
395 if( rctx->setFile(
"").isFailure() ) {
396 throw GaudiException(
"xAODEventSelector::next() - Fatal error when trying to setFile('')",
"xAODEventSelector",StatusCode::FAILURE);
402 if( rctx->setFile( fname ).isFailure() ) {
403 throw GaudiException(
"xAODEventSelector::next() - Fatal error when trying to setFile('" + fname +
"')",
"xAODEventSelector",StatusCode::FAILURE);
407 m_incsvc->fireIncident(FileIncident(
name(),
"BeginInputFile", rctx->
file()->GetName()));
410 return StatusCode::FAILURE;
424 int64_t global_entry = rctx->
entry();
425 int64_t
entry = global_entry;
439 if(
m_tevent->getEntry( entry ) < 0 ) {
440 ATH_MSG_ERROR(
"Failed to load entry " <<
static_cast< int >( entry ) );
441 throw GaudiException(
"xAODEventSelector::next() - xAOD::TEvent::getEntry returned less than 0 bytes",
"xAODEventSelector",StatusCode::FAILURE);
453 if(
m_tevent->retrieve( xaodEventInfo ,
"EventInfo").isFailure()) {
455 throw GaudiException(
"xAODEventSelector::next() - Could not find xAOD::EventInfo",
"xAODEventSelector",StatusCode::FAILURE);
458 EventType* evtType =
new EventType;
462 if ( !
m_dataStore->record( evtInfo,
"EventInfo" ).isSuccess() ) {
464 delete evtInfo; evtInfo = 0;
465 throw GaudiException(
"xAODEventSelector::next() - Could not record EventInfo",
"xAODEventSelector",StatusCode::FAILURE);
468 return StatusCode::SUCCESS;
472 auto& fnames = rctx->
files();
474 m_incsvc->fireIncident(FileIncident(
name(),
"EndInputFile", fnames[fidx]));
499 iaddr.second =
false;
500 SG::TransientAddress* taddr = iaddr.first;
503 const bool forceRemove =
false;
508 CHECK( rctx->setFile(
"") );
523 return StatusCode::FAILURE;
531 return next( ctx, -1 );
537 return next( ctx, -jump );
543 ATH_MSG_ERROR (
"............. Last Event Not Implemented .............");
544 return StatusCode::FAILURE;
559 return StatusCode::SUCCESS;
564 IOpaqueAddress*& )
const
567 return StatusCode::SUCCESS;
573 if(refCtxt==0)
return StatusCode::SUCCESS;
577 return StatusCode::SUCCESS;
580 return StatusCode::FAILURE;
586 ATH_MSG_ERROR (
"............. resetCriteria Not Implemented .............");
587 return StatusCode::FAILURE;
611 if (coll_idx == -1 && evtnum <
m_curEvt) {
615 if (coll_idx == -1) {
617 return StatusCode::RECOVERABLE;
624 return StatusCode::FAILURE;
632 return StatusCode::SUCCESS;
653 if (!iomgr.retrieve().isSuccess()) {
655 return StatusCode::FAILURE;
657 if (!iomgr->io_hasitem(
this)) {
658 ATH_MSG_FATAL(
"IoComponentMgr does not know about myself !");
659 return StatusCode::FAILURE;
668 std::string &fname = inputCollections[i];
670 if (!iomgr->io_contains(
this, fname)) {
671 ATH_MSG_ERROR(
"IoComponentMgr does not know about [" << fname <<
"] !");
672 return StatusCode::FAILURE;
674 if (!iomgr->io_retrieve(
this, fname).isSuccess()) {
675 ATH_MSG_FATAL(
"Could not retrieve new value for [" << fname <<
"] !");
676 return StatusCode::FAILURE;
696 return StatusCode::FAILURE;
700 return StatusCode::SUCCESS;
714 return StatusCode::SUCCESS;
726 return StatusCode::SUCCESS;
732 const EventContext& )
738 return StatusCode::SUCCESS;
741 << tad->
name() <<
") NOT known to us.");
742 return StatusCode::FAILURE;
746 return StatusCode::SUCCESS;
763 return(StatusCode::SUCCESS);
768 return StatusCode::FAILURE;
782 std::set<std::string> missingAux;
784 for(
auto itr =
m_tevent->inputEventFormat()->begin(); itr!=
m_tevent->inputEventFormat()->end();++itr) {
785 if(inputTree->GetBranch(itr->second.branchName().c_str())==0)
continue;
786 ATH_MSG_VERBOSE(
"EFE:" << itr->first <<
" branchName = " << itr->second.branchName() <<
" className=" << itr->second.className());
788 if(
m_clidsvc->getIDOfTypeInfoName(itr->second.className(),
id).isFailure() &&
789 m_clidsvc->getIDOfTypeName(itr->second.className(),
id).isFailure()) {
791 if(itr->second.branchName().compare(itr->second.branchName().length()-4,4,
"Aux.")==0) {
792 missingAux.insert( itr->second.className() );
continue;
795 TString className = itr->second.className();
799 TClass *cls = TClass::GetClass(className);
801 const std::type_info *ti = cls->GetTypeInfo();
802 if(ti) className = System::typeinfoName(*ti);
805 if(
m_clidsvc->getIDOfTypeInfoName(className.Data(),
id).isFailure() &&
806 m_clidsvc->getIDOfTypeName(className.Data(),
id).isFailure()) {
807 ATH_MSG_WARNING(
"No CLID for class " << itr->second.className() <<
" , cannot read " << itr->second.branchName());
813 const std::string br_name = itr->second.branchName();
816 (POOL_ROOTTREE_StorageType,
id,
819 (
unsigned long)(value_ptr),
832 if (old->clID() ==
id &&
833 old->name() == br_name) {
836 old->setAddress(addr);
838 iaddr->second =
true;
848 tads.push_back(taddr);
858 if(missingAux.size()) {
859 std::string allAux;
for(
auto& s : missingAux) allAux += s +
", ";
860 ATH_MSG_WARNING(
"The following AuxStore types are not directly accessible (missing CLID, possibly from schema evolution): " << allAux);
876 ATH_MSG_DEBUG(
"In xAODEventSelector::createRootBranchAddresses end ...");
878 return StatusCode::SUCCESS;
885 ATH_MSG_DEBUG(
"In xAODEventSelector::createMetaDataRootBranchAddresses start ...");
889 throw "xAODEventSelector: Unable to get m_tfile";
897 if (!
tree) std::abort();
898 TObjArray *leaves =
tree->GetListOfLeaves();
901 return StatusCode::SUCCESS;
905 for (Int_t i = 0; i < leaves->GetEntries(); ++i) {
906 TLeaf *leaf = (TLeaf *)leaves->At(i);
907 TBranch *branch = leaf->GetBranch();
912 const std::string type_name = leaf->GetTypeName();
913 const std::string br_name = branch->GetName();
915 const std::string toCheck =
"xAOD::";
916 if (type_name.find(toCheck) == std::string::npos) {
917 ATH_MSG_DEBUG(
"** Skip type-name = " << type_name <<
", br_name = " << br_name );
920 const std::string sg_key = br_name;
921 TClass *cls = TClass::GetClass(type_name.c_str());
922 const std::type_info *ti = 0;
926 if( br_name ==
"EventFormat" )
continue;
929 ti = cls->GetTypeInfo();
945 << type_name <<
"]");
951 ATH_MSG_DEBUG(
"id = " <<
id <<
", m_metadataName.value() = " <<
m_metadataName.value() <<
", br_name = " << br_name <<
", value_ptr = " << value_ptr);
954 (POOL_ROOTTREE_StorageType,
id,
957 (
unsigned long)(value_ptr),
958 (
unsigned long)(1)));
959 if (!
m_imetaStore->recordAddress(br_name, std::move(addr),
true).isSuccess()) {
960 ATH_MSG_ERROR(
"could not record address at [" << br_name <<
"] in store ["
972 ATH_MSG_DEBUG(
"In xAODEventSelector::createMetaDataRootBranchAddresses end ...");
974 return StatusCode::SUCCESS;
982 if(fname.empty())
return file;
985 file = (TFile*)gROOT->GetListOfFiles()->FindObject(fname.c_str());
988 file = TFile::Open(fname.c_str(),
"READ");
989 if (
file)
file->SetName(fname.c_str());
993 ATH_MSG_ERROR(
"could not open next file in input collection ["
1007 if(!newFile && !fname.empty()) {
1008 ATH_MSG_FATAL(
"xAODEventSelector: Unable to fetch Ntuple: " << fname);
1009 return StatusCode::FAILURE;
1013 const std::string currFile =
m_tfile->GetName();
1015 m_poolSvc->disconnectDb(
"PFN:"+currFile).ignore();
1023 if(!
m_tfile)
return StatusCode::SUCCESS;
1026 ATH_MSG_FATAL(
"xAODEventSelector: TEvent cannot read " << fname);
1027 return StatusCode::FAILURE;
1035 return StatusCode::FAILURE;
1042 m_poolSvc->createCollection(
"ImplicitCollection" ,
"PFN:"+fname , fname );
1053 return StatusCode::SUCCESS;
1066 zero.min_entries = -1;
1067 zero.max_entries = -1;
1087 return StatusCode::SUCCESS;
1115 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.
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 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.