|
| TagCollectionStream (const std::string &name, ISvcLocator *pSvcLocator) |
| Standard algorithm Constructor. More...
|
|
StatusCode | initialize () override |
| Initialize TagCollectionStream. More...
|
|
StatusCode | finalize () override |
| Terminate TagCollectionStream. More...
|
|
StatusCode | start () override |
| Start OutputStream. More...
|
|
StatusCode | initialize () override |
| Initialize OutputStream. More...
|
|
StatusCode | finalize () override |
| Terminate OutputStream. More...
|
|
StatusCode | execute () override |
| Working entry point. More...
|
|
virtual StatusCode | connectConversionSvc () |
|
virtual bool | collect (IRegistry *dir, int level) |
| Store agent's classback. More...
|
|
virtual StatusCode | collectObjects () |
| Collect all objects to be written to the output stream. More...
|
|
void | clearSelection () |
| Clear list of selected objects. More...
|
|
| LegacyAlgorithmAdapter (std::string name, ISvcLocator *svcloc, std::string version=PACKAGE_VERSION) |
|
const EventContext & | getContext () const |
|
bool | isExecuted () const |
| Has this algorithm been executed since the last reset? More...
|
|
void | setExecuted (bool state) const |
| Set the executed flag to the specified state. More...
|
|
bool | filterPassed () const |
| Did this algorithm pass or fail its filter criterion for the last event? More...
|
|
void | setFilterPassed (bool state) const |
| Set the filter passed flag to the specified state. More...
|
|
| Algorithm (std::string name, ISvcLocator *svcloc, std::string version=PACKAGE_VERSION) |
| Constructor. More...
|
|
StatusCode | sysStart () override |
| Reinitialization method invoked by the framework. More...
|
|
StatusCode | sysInitialize () override |
| Initialization method invoked by the framework. More...
|
|
StatusCode | sysReinitialize () override |
| Reinitialization method invoked by the framework. More...
|
|
StatusCode | sysRestart () override |
| Restart method invoked by the framework. More...
|
|
StatusCode | sysExecute (const EventContext &ctx) override |
| The actions to be performed by the algorithm on an event. More...
|
|
StatusCode | sysStop () override |
| System stop. More...
|
|
StatusCode | sysFinalize () override |
| System finalization. More...
|
|
const std::string & | name () const override |
| The identifying name of the algorithm object. More...
|
|
const Gaudi::StringKey & | nameKey () const override |
|
const std::string & | type () const override |
| The type of the algorithm object. More...
|
|
void | setType (std::string type) override |
|
const std::string & | version () const override |
|
unsigned int | index () const override |
|
StatusCode | configure () override |
| Dummy implementation of IStateful::configure() method. More...
|
|
StatusCode | terminate () override |
| Dummy implementation of IStateful::terminate() method. More...
|
|
StatusCode | initialize () override |
| the default (empty) implementation of IStateful::initialize() method More...
|
|
StatusCode | start () override |
| the default (empty) implementation of IStateful::start() method More...
|
|
StatusCode | stop () override |
| the default (empty) implementation of IStateful::stop() method More...
|
|
StatusCode | finalize () override |
| the default (empty) implementation of IStateful::finalize() method More...
|
|
StatusCode | reinitialize () override |
| the default (empty) implementation of IStateful::reinitialize() method More...
|
|
StatusCode | restart () override |
| the default (empty) implementation of IStateful::restart() method More...
|
|
Gaudi::StateMachine::State | FSMState () const override |
| returns the current state of the algorithm More...
|
|
Gaudi::StateMachine::State | targetFSMState () const override |
| returns the state the algorithm will be in after the ongoing transition More...
|
|
bool | isEnabled () const override |
| Is this algorithm enabled or disabled? More...
|
|
bool | isSequence () const override |
| Are we a Sequence? More...
|
|
unsigned int | errorCount () const |
| Get the number of failures of the algorithm. More...
|
|
template<class T > |
StatusCode | service (std::string_view name, T *&psvc, bool createIf=true) const |
| Access a service by name, creating it if it doesn't already exist. More...
|
|
template<class T > |
StatusCode | service (std::string_view svcType, std::string_view svcName, T *&psvc) const |
| Access a service by name and type, creating it if it doesn't already exist. More...
|
|
SmartIF< IService > | service (std::string_view name, const bool createIf=true, const bool quiet=false) const |
| Return a pointer to the service identified by name (or "type/name") More...
|
|
template<class T > |
SmartIF< T > | service (std::string_view name, bool createIf=true, bool quiet=false) const |
|
SmartIF< IAuditorSvc > & | auditorSvc () const |
| The standard auditor service.May not be invoked before sysInitialize() has been invoked. More...
|
|
SmartIF< IChronoStatSvc > & | chronoSvc () const |
| The standard Chrono & Stat service, Return a pointer to the service if present. More...
|
|
SmartIF< IDataProviderSvc > & | detSvc () const |
| The standard detector data service. More...
|
|
SmartIF< IConversionSvc > & | detCnvSvc () const |
| The standard detector data persistency conversion service. More...
|
|
SmartIF< IDataProviderSvc > & | eventSvc () const |
| The standard event data service. More...
|
|
SmartIF< IDataProviderSvc > & | evtSvc () const |
| shortcut for method eventSvc More...
|
|
SmartIF< IConversionSvc > & | eventCnvSvc () const |
| The standard event data persistency conversion service. More...
|
|
SmartIF< IHistogramSvc > & | histoSvc () const |
| The standard histogram service. More...
|
|
SmartIF< INTupleSvc > & | ntupleSvc () const |
| The standard N tuple service. More...
|
|
SmartIF< IRndmGenSvc > & | randSvc () const |
| The standard RandomGen service, Return a pointer to the service if present. More...
|
|
SmartIF< IToolSvc > & | toolSvc () const |
| The standard ToolSvc service, Return a pointer to the service if present. More...
|
|
SmartIF< IExceptionSvc > & | exceptionSvc () const |
| Get the exception Service. More...
|
|
SmartIF< IAlgContextSvc > & | contextSvc () const |
| get Algorithm Context Service More...
|
|
SmartIF< ITimelineSvc > & | timelineSvc () const |
|
SmartIF< ISvcLocator > & | serviceLocator () const override |
| The standard service locator. More...
|
|
SmartIF< ISvcLocator > & | svcLoc () const |
| shortcut for method serviceLocator More...
|
|
SmartIF< IHiveWhiteBoard > & | whiteboard () const |
|
SmartIF< IAlgExecStateSvc > & | algExecStateSvc () const |
|
bool | registerContext () const |
| register for Algorithm Context Service? More...
|
|
template<class T > |
Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, ToolHandle< T > &hndl, const std::string &doc="none") |
|
template<class T > |
Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, ToolHandleArray< T > &hndlArr, const std::string &doc="none") |
|
SmartIF< IMonitorSvc > & | monitorSvc () const |
| Access the monitor service. More...
|
|
template<class T > |
void | declareInfo (const std::string &name, const T &var, const std::string &desc) const |
| Declare monitoring information. More...
|
|
void | declareInfo (const std::string &name, const std::string &format, const void *var, int size, const std::string &desc) const |
| Declare monitoring information (special case) More...
|
|
void | acceptDHVisitor (IDataHandleVisitor *) const override |
|
void | registerTool (IAlgTool *tool) const |
|
void | deregisterTool (IAlgTool *tool) const |
|
template<class T > |
StatusCode | declareTool (ToolHandle< T > &handle, bool createIf=true) |
|
template<class T > |
StatusCode | declareTool (ToolHandle< T > &handle, std::string toolTypeAndName, bool createIf=true) |
|
template<class T > |
void | addToolsArray (ToolHandleArray< T > &hndlArr) |
|
const std::vector< IAlgTool * > & | tools () const |
|
bool | isBlocking () const |
|
void | setBlocking (bool value) |
|
unsigned int | cardinality () const override |
| Return the cardinality. More...
|
|
const std::vector< std::string > & | neededResources () const override |
|
AlgExecState & | execState (const EventContext &ctx) const override |
| reference to AlgExecState of Alg More...
|
|
std::ostream & | toControlFlowExpression (std::ostream &os) const override |
| Produce string represention of the control flow expression. More...
|
|
Public Member Functions inherited from DataHandleHolderBase< PropertyHolder< CommonMessaging< implements< IAlgorithm, IDataHandleHolder, IProperty, IStateful > > > > |
std::vector< Gaudi::DataHandle * > | inputHandles () const override |
|
std::vector< Gaudi::DataHandle * > | outputHandles () const override |
|
virtual const DataObjIDColl & | extraInputDeps () const override |
|
virtual const DataObjIDColl & | extraOutputDeps () const override |
|
void | declare (Gaudi::DataHandle &handle) override |
|
void | renounce (Gaudi::DataHandle &handle) override |
|
bool | renounceInput (const DataObjID &id) override |
|
const DataObjIDColl & | inputDataObjs () const override |
|
const DataObjIDColl & | outputDataObjs () const override |
|
void | addDependency (const DataObjID &id, const Gaudi::DataHandle::Mode &mode) override |
|
void * | i_cast (const InterfaceID &tid) const override |
| Implementation of IInterface::i_cast. More...
|
|
StatusCode | queryInterface (const InterfaceID &ti, void **pp) override |
| Implementation of IInterface::queryInterface. More...
|
|
std::vector< std::string > | getInterfaceNames () const override |
| Implementation of IInterface::getInterfaceNames. More...
|
|
| PropertyHolder ()=default |
|
Gaudi::Details::PropertyBase & | declareProperty (Gaudi::Details::PropertyBase &prop) |
| Declare a property. More...
|
|
Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, TYPE &value, const std::string &doc="none") |
| Helper to wrap a regular data member and use it as a regular property. More...
|
|
Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, Gaudi::Property< TYPE, VERIFIER, HANDLERS > &prop, const std::string &doc="none") |
| Declare a PropertyBase instance setting name and documentation. More...
|
|
Gaudi::Details::PropertyBase * | declareRemoteProperty (const std::string &name, IProperty *rsvc, const std::string &rname="") |
| Declare a remote property. More...
|
|
StatusCode | setProperty (const std::string &name, const Gaudi::Details::PropertyBase &p) override |
| set the property from another property with a different name More...
|
|
StatusCode | setProperty (const std::string &s) override |
| set the property from the formatted string More...
|
|
StatusCode | setProperty (const Gaudi::Details::PropertyBase &p) |
| Set the property from a property. More...
|
|
virtual StatusCode | setProperty (const std::string &name, const Gaudi::Details::PropertyBase &p)=0 |
| Set the property from a property with a different name. More...
|
|
virtual StatusCode | setProperty (const std::string &s)=0 |
| Set the property by string. More...
|
|
StatusCode | setProperty (const std::string &name, const char *v) |
| Special case for string literals. More...
|
|
StatusCode | setProperty (const std::string &name, const std::string &v) |
| Special case for std::string. More...
|
|
StatusCode | setProperty (const std::string &name, const TYPE &value) |
| set the property form the value More...
|
|
StatusCode | setPropertyRepr (const std::string &n, const std::string &r) override |
| set the property from name and value string representation More...
|
|
StatusCode | getProperty (Gaudi::Details::PropertyBase *p) const override |
| get the property More...
|
|
const Gaudi::Details::PropertyBase & | getProperty (std::string_view name) const override |
| get the property by name More...
|
|
StatusCode | getProperty (std::string_view n, std::string &v) const override |
| convert the property to the string More...
|
|
const std::vector< Gaudi::Details::PropertyBase * > & | getProperties () const override |
| get all properties More...
|
|
bool | hasProperty (std::string_view name) const override |
| Return true if we have a property with the given name. More...
|
|
Gaudi::Details::PropertyBase * | property (std::string_view name) const |
| \fixme property and bindPropertiesTo should be protected More...
|
|
void | bindPropertiesTo (Gaudi::Interfaces::IOptionsSvc &optsSvc) |
|
| PropertyHolder (const PropertyHolder &)=delete |
|
PropertyHolder & | operator= (const PropertyHolder &)=delete |
|
MSG::Level | msgLevel () const |
| get the cached level (originally extracted from the embedded MsgStream) More...
|
|
bool | msgLevel (MSG::Level lvl) const |
| get the output level from the embedded MsgStream More...
|
|
|
Gaudi::Property< std::string > | m_addrLeaf |
|
Gaudi::Property< std::string > | m_addrColName |
|
Gaudi::Property< std::string > | m_collSvcName { this, "TagCollectionSvc", "NTupleSvc", "name of the collection service" } |
|
Gaudi::Property< bool > | m_objectsFirst |
|
Gaudi::Property< std::string > | m_tagName { this, "Collection", "", "name of the tag collection in the transient store" } |
|
INTupleItem * | m_addrColumn = nullptr |
| NTuple column to hold the opaque address of the address leaf. More...
|
|
std::string | m_topLeafName |
| Name of the top leaf (performance cache) More...
|
|
bool | m_isTopLeaf = false |
| Short cut flag to indicate if the address leaf is the top leaf (performace cache) More...
|
|
SmartIF< INTupleSvc > | m_collectionSvc |
| Keep reference to the tuple service. More...
|
|
std::unique_ptr< GenericAddress > | m_addr |
| Address buffer. More...
|
|
NTuple::Item< IOpaqueAddress * > | m_item |
| Address item buffer. More...
|
|
Gaudi::Property< ItemNames > | m_itemNames { this, "ItemList", {}, "vector of item names to be saved to this stream" } |
|
Gaudi::Property< ItemNames > | m_optItemNames |
|
Gaudi::Property< AlgDependentItemNames > | m_algDependentItemList |
|
Gaudi::Property< bool > | m_doPreLoad |
|
Gaudi::Property< bool > | m_doPreLoadOpt |
|
Gaudi::Property< std::string > | m_output { this, "Output", {}, "name of the output file specification" } |
|
Gaudi::Property< std::string > | m_outputName { this, "OutputFile", {}, "name of the output file" } |
|
Gaudi::Property< std::string > | m_storeName |
|
Gaudi::Property< std::string > | m_persName |
|
Gaudi::Property< std::vector< std::string > > | m_acceptNames |
|
Gaudi::Property< std::vector< std::string > > | m_requireNames |
|
Gaudi::Property< std::vector< std::string > > | m_vetoNames |
|
Gaudi::Property< bool > | m_verifyItems |
|
bool | m_fireIncidents = true |
| should I fire incidents for writing opening/closing etc? in the baseclass, always fire the incidents by default in e.g. More...
|
|
SmartIF< IIncidentSvc > | m_incidentSvc |
| Reference to the incident service. More...
|
|
std::string | m_outputType = "UPDATE" |
| Output type: NEW(NEW,CREATE,WRITE,RECREATE), UPDATE) More...
|
|
SmartIF< IDataProviderSvc > | m_pDataProvider |
| Keep reference to the data provider service. More...
|
|
SmartIF< IDataManagerSvc > | m_pDataManager |
| Keep reference to the data manager service. More...
|
|
SmartIF< IConversionSvc > | m_pConversionSvc |
| Keep reference to the data conversion service. More...
|
|
DataStoreItem * | m_currentItem |
| Keep track of the current item. More...
|
|
Items | m_itemList |
| Vector of items to be saved to this stream. More...
|
|
Items | m_optItemList |
| Vector of optional items to be saved to this stream. More...
|
|
AlgDependentItems | m_algDependentItems |
| Items to be saved for specific algorithms. More...
|
|
IDataSelector | m_objects |
| Collection of objects being selected. More...
|
|
int | m_events |
| Number of events written to this output stream. More...
|
|
std::vector< Gaudi::Algorithm * > | m_acceptAlgs |
| Vector of Algorithms that this stream accepts. More...
|
|
std::vector< Gaudi::Algorithm * > | m_requireAlgs |
| Vector of Algorithms that this stream requires. More...
|
|
std::vector< Gaudi::Algorithm * > | m_vetoAlgs |
| Vector of Algorithms that this stream is vetoed by. More...
|
|
std::unique_ptr< IDataHandleVisitor > | m_updateDataHandles |
| Hook for for derived classes to provide a custom visitor for data handles. More...
|
|
Protected Attributes inherited from DataHandleHolderBase< PropertyHolder< CommonMessaging< implements< IAlgorithm, IDataHandleHolder, IProperty, IStateful > > > > |
DataObjIDColl | m_inputDataObjs |
|
DataObjIDColl | m_outputDataObjs |
|
Specialized output stream class for event tag collections, where the basic Event entry point should be placed as well into the collection itself. The TagCollectionStream is a rather specialized object combining features of NTuple I/O and object I/O. The main working points are:
1) Write a "normal" tag collection. The address column [property AddressColumn, default:"Address"] is added to the Ntuple identified by its name [mandatory property Collection]. The address column is set to the opaque address of the specified leaf [property "AddressLeaf", default:"/Event"]. The NTuple must be registered to the TES of the service [property: TagCollectionSvc, default:"NTupleSvc"]. This is the normal mode event tag collections work.
2) Write a tag collection with "REDIRECTED INPUT". Example: The collection is created from an intermediate file (MINI DST), but the Address column of the NTuple should point to the file e.g. containing the raw data.
- Set the property "AddressLeaf" to something different from "/Event" e.g. "/Event/DAQ/RawEvent"
Note: The actual address of "/Event" get changed. No other output should be created after writing such a tag collection.
3) Write an "EMBEDDED COLLECTION". In this mode the OutputStream and the NTuple stream are combined. depending on the property TagCollectionStream.ObjectsFirst the objects are written first and the the tags. The tag file and the file containing the objects may be identical.
Note:
- Also if the OutputStream features are NOT used, the options must still be properly set.
- Tags or objects are only written to the output stream if the event is accepted according to the output stream criteria (veto algorithms, etc.)
- If the address column is not present in the N-tuple (ie. it was not added by the N-tuple creator), it is automatically added at the first write attempt.
- If the logical N-tuple output file is not yet connected to the tuple service, it is automatically connected to the the same as the OutputStream device.
Author: M.Frank Version: 1.0
Definition at line 71 of file TagCollectionStream.h.