ATLAS Offline Software
Loading...
Searching...
No Matches
EventSelectorAthenaPool.h
Go to the documentation of this file.
1/*
2 Copyright (C) 2002-2026 CERN for the benefit of the ATLAS collaboration
3*/
4
5#ifndef EVENTSELECTORATHENAPOOL_H
6#define EVENTSELECTORATHENAPOOL_H
7
12
13#include "GaudiKernel/IEvtSelector.h"
14#include "GaudiKernel/IIoComponent.h"
15#include "GaudiKernel/IIncidentListener.h"
16#include "GaudiKernel/ServiceHandle.h"
17#include "GaudiKernel/ToolHandle.h"
19
26
28
29#include <map>
30#include <atomic>
31#include <cstdint>
32#include <memory>
33#include <optional>
34
35// Forward declarations
36class IIncidentSvc;
37class IOpaqueAddress;
38class ISvcLocator;
41class StoreGateSvc;
42namespace pool {
44}
45
50 public extends<::AthService, IEvtSelector, IEvtSelectorSeek, IIoComponent, IIncidentListener, ISecondaryEventSelector>
51{
52
53public: // Constructor and Destructor
55 EventSelectorAthenaPool(const std::string& name, ISvcLocator* pSvcLocator);
58
60 virtual StatusCode initialize() override;
61 virtual StatusCode start() override;
62 virtual StatusCode stop() override;
63 virtual StatusCode finalize() override;
64
65 //-------------------------------------------------
66 // IEventSelector
68 virtual StatusCode createContext(IEvtSelector::Context*& ctxt) const override;
69
71 virtual StatusCode next(IEvtSelector::Context& ctxt) const override;
74 virtual StatusCode next(IEvtSelector::Context& ctxt, int jump) const override;
75
77 virtual StatusCode previous(IEvtSelector::Context& ctxt) const override;
80 virtual StatusCode previous(IEvtSelector::Context& ctxt, int jump) const override;
81
83 virtual StatusCode last(IEvtSelector::Context& ctxt) const override;
84
86 virtual StatusCode rewind(IEvtSelector::Context& ctxt) const override;
87
90 virtual StatusCode createAddress(const IEvtSelector::Context& ctxt, IOpaqueAddress*& iop) const override;
91
93 virtual StatusCode releaseContext(IEvtSelector::Context*& ctxt) const override;
94
98 virtual StatusCode resetCriteria(const std::string& criteria, IEvtSelector::Context& ctxt) const override;
99
100 //-------------------------------------------------
101 // IEventSelectorSeek
105 virtual StatusCode seek(Context& ctxt, int evtnum) const override;
106
109 virtual int curEvent (const Context& ctxt) const override;
110
113 virtual int size (Context& ctxt) const override;
114
115 //-------------------------------------------------
116 // IIoComponent
118 virtual StatusCode io_reinit() override;
120 virtual StatusCode io_finalize() override;
121
122 //-------------------------------------------------
123 // IIncidentListener
125 virtual void handle(const Incident& incident) override;
126
127protected:
128 //-------------------------------------------------
129 // ISecondaryEventSelector
131 virtual StatusCode nextHandleFileTransition(IEvtSelector::Context& ctxt) const override;
133 virtual StatusCode nextWithSkip(IEvtSelector::Context& ctxt) const override;
135 virtual StatusCode recordAttributeList() const override;
137 virtual StatusCode fillAttributeList(coral::AttributeList *attrList, const std::string &suffix, bool copySource) const override;
139 virtual bool disconnectIfFinished(const SG::SourceID &fid) const override;
140
141private: // internal member functions
143 StoreGateSvc* eventStore() const;
145 StatusCode reinit() const;
147 std::unique_ptr<PoolCollectionConverter> getCollectionCnv(bool throwIncidents = false) const;
149 int findEvent(int evtNum) const;
150
151private: // data
153 mutable std::unique_ptr<PoolCollectionConverter> m_poolCollectionConverter ATLAS_THREAD_SAFE {};
154 mutable pool::ICollectionCursor* m_headerIterator ATLAS_THREAD_SAFE {};
155 mutable Guid m_guid ATLAS_THREAD_SAFE {};
156 mutable std::map<SG::SourceID, int> m_activeEventsPerSource ATLAS_THREAD_SAFE;
158 mutable std::optional<InputFileIncidentGuard> m_inputFileGuard ATLAS_THREAD_SAFE;
159
160 ServiceHandle<IAthenaPoolCnvSvc> m_athenaPoolCnvSvc{this, "ConversionService", "AthenaPoolCnvSvc", ""};
161 ServiceHandle<IIncidentSvc> m_incidentSvc{this, "IncidentSvc", "IncidentSvc", ""};
162
163private: // properties
165 Gaudi::Property<bool> m_isSecondary{this, "IsSecondary", false, ""};
167 Gaudi::Property<bool> m_processMetadata{this, "ProcessMetadata", true, ""};
169 Gaudi::Property<std::string> m_collectionType{this, "CollectionType", "ImplicitCollection", ""};
170
172 std::string m_attrListKey{"Input"};
173
175 Gaudi::Property<std::vector<std::string>> m_inputCollectionsProp{this, "InputCollections", {}, ""};
176 mutable std::vector<std::string>::const_iterator m_inputCollectionsIterator ATLAS_THREAD_SAFE;
177 void inputCollectionsHandler(Gaudi::Details::PropertyBase&);
179 mutable bool m_inputCollectionsChanged ATLAS_THREAD_SAFE;
180
183 Gaudi::Property<bool> m_keepInputFilesOpen{this, "KeepInputFilesOpen", false, ""};
184
186 mutable ToolHandleArray<IAthenaSelectorTool> m_helperTools ATLAS_THREAD_SAFE {this, "HelperTools", {}, ""};
187 ToolHandle<IAthenaSelectorTool> m_counterTool{this, "CounterTool", "", ""};
188
192 Gaudi::CheckedProperty<uint32_t> m_runNo{this, "RunNumber", 0, ""};
193 Gaudi::CheckedProperty<uint32_t> m_oldRunNo{this, "OldRunNumber", 0, ""};
194 Gaudi::Property<bool> m_overrideRunNumber{this, "OverrideRunNumber", false, ""};
195 Gaudi::Property<bool> m_overrideRunNumberFromInput{this, "OverrideRunNumberFromInput", false, ""};
196 // TODO: check if not really used
197 Gaudi::CheckedProperty<uint64_t> m_firstEventNo{this, "FirstEvent", 1, ""};
198 // TODO: check if not really used
199 Gaudi::CheckedProperty<uint64_t> m_eventsPerRun{this, "EventsPerRun", 1000000, ""};
200 Gaudi::CheckedProperty<uint32_t> m_firstLBNo{this, "FirstLB", 0, ""};
201 Gaudi::CheckedProperty<uint32_t> m_eventsPerLB{this, "EventsPerLB", 1000, ""};
202 Gaudi::CheckedProperty<uint32_t> m_initTimeStamp{this, "InitialTimeStamp", 0, ""};
203 Gaudi::Property<uint32_t> m_timeStampInterval{this, "TimeStampInterval", 0, ""};
204
205 mutable std::atomic_long m_curCollection{};
206 mutable std::vector<int> m_numEvt ATLAS_THREAD_SAFE;
207 mutable std::vector<int> m_firstEvt ATLAS_THREAD_SAFE;
208
210 Gaudi::Property<int> m_skipEvents{this, "SkipEvents", 0, ""};
211 Gaudi::Property<std::vector<long>> m_skipEventSequenceProp{this, "SkipEventSequence", {}, ""};
213 Gaudi::Property<std::string> m_skipEventRangesProp{this, "SkipEventRanges", {}, ""};
214 mutable std::vector<std::pair<long,long>> m_skipEventRanges ATLAS_THREAD_SAFE;
215
216 mutable std::atomic_int m_evtCount{}; // internal count of events
217 mutable std::atomic_bool m_firedIncident{};
218
219 typedef std::mutex CallMutex;
221
223
227
231};
232
233#endif
Maintain a set of objects, one per slot.
This file contains the class definition for the Guid class (migrated from POOL).
This file contains the class definition for the IAthenaPoolCnvSvc interface class.
This file contains the class definition for the IAthenaSelectorTool class.
Extension to IEvtSelector to allow for seeking.
Abstract interface for secondary event selectors.
RAII guard that guarantees a matching end-incident for every begin-incident.
size_t size() const
Number of registered mappings.
This class provides the context to access an event from POOL persistent store.
EventSelectorAthenaPool(const std::string &name, ISvcLocator *pSvcLocator)
Standard Service Constructor.
Gaudi::CheckedProperty< uint64_t > m_firstEventNo
virtual StatusCode start() override
std::unique_ptr< PoolCollectionConverter > getCollectionCnv(bool throwIncidents=false) const
Return pointer to new PoolCollectionConverter.
Gaudi::Property< bool > m_isSecondary
IsSecondary, know if this is an instance of secondary event selector.
Gaudi::Property< bool > m_overrideRunNumberFromInput
virtual StatusCode nextWithSkip(IEvtSelector::Context &ctxt) const override
Go to next event and skip if necessary.
virtual StatusCode initialize() override
Required of all Gaudi Services.
Gaudi::Property< int > m_skipEvents
SkipEvents, numbers of events to skip: default = 0.
Gaudi::Property< bool > m_processMetadata
ProcessMetadata, switch on firing of FileIncidents which will trigger processing of metadata: default...
virtual int curEvent(const Context &ctxt) const override
Return the current event number.
virtual StatusCode createContext(IEvtSelector::Context *&ctxt) const override
create context
friend class EventSelectorAthenaPoolSharedIO
make the EventSelectorAthenaPoolSharedIO a friend so it can access the internal EventSelectorAthenaPo...
virtual StatusCode io_finalize() override
Callback method to finalize the internal state of the component for I/O purposes (e....
Gaudi::Property< std::vector< long > > m_skipEventSequenceProp
friend class DoubleEventSelectorAthenaPool
make the DoubleEventSelectorAthenaPool a friend so it can access the internal EventSelectorAthenaPool...
Gaudi::CheckedProperty< uint32_t > m_initTimeStamp
void inputCollectionsHandler(Gaudi::Details::PropertyBase &)
virtual StatusCode io_reinit() override
Callback method to reinitialize the internal state of the component for I/O purposes (e....
virtual StatusCode resetCriteria(const std::string &criteria, IEvtSelector::Context &ctxt) const override
Set a selection criteria.
StatusCode reinit() const
Reinitialize the service when a fork() occurred/was-issued.
StoreGateSvc * eventStore() const
Return pointer to active event SG.
virtual StatusCode releaseContext(IEvtSelector::Context *&ctxt) const override
virtual StatusCode stop() override
ServiceHandle< IIncidentSvc > m_incidentSvc
virtual StatusCode next(IEvtSelector::Context &ctxt) const override
virtual ~EventSelectorAthenaPool()
Destructor.
std::unique_ptr< PoolCollectionConverter > m_poolCollectionConverter ATLAS_THREAD_SAFE
ToolHandle< IAthenaSelectorTool > m_counterTool
virtual StatusCode fillAttributeList(coral::AttributeList *attrList, const std::string &suffix, bool copySource) const override
Fill AttributeList with specific items from the selector and a suffix.
std::string m_attrListKey
AttributeList SG key.
virtual StatusCode seek(Context &ctxt, int evtnum) const override
Seek to a given event number.
SG::SlotSpecificObj< SG::SourceID > m_sourceID
virtual StatusCode last(IEvtSelector::Context &ctxt) const override
Gaudi::CheckedProperty< uint64_t > m_eventsPerRun
Gaudi::CheckedProperty< uint32_t > m_eventsPerLB
virtual StatusCode createAddress(const IEvtSelector::Context &ctxt, IOpaqueAddress *&iop) const override
virtual void handle(const Incident &incident) override
Incident service handle listening for BeginProcessing and EndProcessing.
virtual StatusCode previous(IEvtSelector::Context &ctxt) const override
ServiceHandle< IAthenaPoolCnvSvc > m_athenaPoolCnvSvc
virtual StatusCode rewind(IEvtSelector::Context &ctxt) const override
Gaudi::Property< bool > m_keepInputFilesOpen
KeepInputFilesOpen, boolean flag to keep files open after PoolCollection reaches end: default = false...
Gaudi::CheckedProperty< uint32_t > m_oldRunNo
Gaudi::Property< std::string > m_collectionType
CollectionType, type of the collection: default = "ImplicitCollection".
virtual StatusCode finalize() override
virtual bool disconnectIfFinished(const SG::SourceID &fid) const override
Disconnect DB if all events from the source FID were processed and the Selector moved to another file...
Gaudi::Property< std::vector< std::string > > m_inputCollectionsProp
InputCollections, vector with names of the input collections.
EventContextAthenaPool * m_endIter
virtual StatusCode nextHandleFileTransition(IEvtSelector::Context &ctxt) const override
Handle file transition at the next iteration.
virtual StatusCode recordAttributeList() const override
Record AttributeList in StoreGate.
Gaudi::CheckedProperty< uint32_t > m_runNo
The following are included for compatibility with McEventSelector and are not really used.
int findEvent(int evtNum) const
Search for event with number evtNum.
Gaudi::Property< bool > m_overrideRunNumber
Gaudi::Property< std::string > m_skipEventRangesProp
Skip Events - comma separated list of event to skip, ranges with '-': <start> - <end>.
Gaudi::Property< uint32_t > m_timeStampInterval
Gaudi::CheckedProperty< uint32_t > m_firstLBNo
This class provides a encapsulation of a GUID/UUID/CLSID/IID data structure (128 bit number).
Definition Guid.h:25
This class provides an interface to POOL collections.
Maintain a set of objects, one per slot.
The Athena Transient Store API.
An interface used to navigate the result of a query on a collection.
Framework include files.
Definition libname.h:15