The Gaudi Framework  master (ff829712)
Loading...
Searching...
No Matches
DataSvcFileEntriesTool Class Reference

Tool to scan a transient store branch that collects all the objects that belong to the same source (file). More...

Inheritance diagram for DataSvcFileEntriesTool:
Collaboration diagram for DataSvcFileEntriesTool:

Public Member Functions

StatusCode initialize () override
 Initialize the tool.
 
StatusCode finalize () override
 Finalize the tool.
 
const LeavesList & leaves () const override
 Return the list of collected objects.
 
void handle (const Incident &incident) override
 Call-back function for the BeginEvent incident.
 
- Public Member Functions inherited from extends< AlgTool, IDataStoreLeaves, IIncidentListener >
void const * i_cast (const InterfaceID &tid) const override
 Implementation of IInterface::i_cast.
 
StatusCode queryInterface (const InterfaceID &ti, void **pp) override
 Implementation of IInterface::queryInterface.
 
std::vector< std::string > getInterfaceNames () const override
 Implementation of IInterface::getInterfaceNames.
 
- Public Member Functions inherited from AlgTool
StatusCode queryInterface (const InterfaceID &riid, void **ppvUnknown) override
 Query for a given interface.
 
void const * i_cast (const InterfaceID &riid) const override
 
const std::string & name () const override
 Retrieve full identifying name of the concrete tool object.
 
const std::string & type () const override
 Retrieve type (concrete class) of the sub-algtool.
 
const IInterfaceparent () const override
 Retrieve parent of the sub-algtool.
 
StatusCode configure () override
 
StatusCode initialize () override
 
StatusCode start () override
 
StatusCode stop () override
 
StatusCode finalize () override
 
StatusCode terminate () override
 
StatusCode reinitialize () override
 
StatusCode restart () override
 
Gaudi::StateMachine::State FSMState () const override
 
Gaudi::StateMachine::State targetFSMState () const override
 
StatusCode sysInitialize () override
 Initialize AlgTool.
 
StatusCode sysStart () override
 Start AlgTool.
 
StatusCode sysStop () override
 Stop AlgTool.
 
StatusCode sysFinalize () override
 Finalize AlgTool.
 
StatusCode sysReinitialize () override
 Initialize AlgTool.
 
StatusCode sysRestart () override
 Start AlgTool.
 
 AlgTool (std::string type, std::string name, const IInterface *parent)
 Standard Constructor.
 
SmartIF< ISvcLocator > & serviceLocator () const override
 Retrieve pointer to service locator.
 
ISvcLocatorsvcLoc () const
 shortcut for the method service locator
 
IDataProviderSvcevtSvc () const
 accessor to event service service
 
IToolSvctoolSvc () const
 The standard ToolSvc service, Return a pointer to the service if present.
 
SmartIF< IServiceservice (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")
 
template<typename T>
SmartIF< T > service (std::string_view name, const bool createIf=true, const bool quiet=false) const
 
template<class T>
Gaudi::Details::PropertyBasedeclareProperty (const std::string &name, ToolHandle< T > &hndl, const std::string &doc="none")
 
template<class T>
StatusCode declareTool (ToolHandle< T > &handle, bool createIf=true)
 
template<class T>
StatusCode declareTool (ToolHandle< T > &handle, const std::string &toolTypeAndName, bool createIf=true)
 
template<class T>
Gaudi::Details::PropertyBasedeclareProperty (const std::string &name, ToolHandleArray< T > &hndlArr, const std::string &doc="none")
 
template<class T>
void addToolsArray (ToolHandleArray< T > &hndlArr)
 
void acceptDHVisitor (IDataHandleVisitor *) const override
 
void registerTool (IAlgTool *tool) const
 
void deregisterTool (IAlgTool *tool) const
 
const std::vector< IAlgTool * > & tools () const
 
IAuditorSvcauditorSvc () const
 Access the auditor service.
 
IMonitorSvcmonitorSvc () const
 Access the monitor service.
 
template<class T>
void declareInfo (const std::string &name, const T &var, const std::string &desc) const
 Declare monitoring information.
 
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)
 
 ~AlgTool () override
 
- Public Member Functions inherited from DataHandleHolderBase< PropertyHolder< CommonMessaging< implements< IAlgTool, IDataHandleHolder, IProperty, IStateful > > > >
std::vector< Gaudi::DataHandle * > inputHandles () const override
 
std::vector< Gaudi::DataHandle * > outputHandles () const override
 
virtual const DataObjIDCollextraInputDeps () const override
 
virtual const DataObjIDCollextraOutputDeps () const override
 
void declare (Gaudi::DataHandle &handle) override
 
void renounce (Gaudi::DataHandle &handle) override
 
bool renounceInput (const DataObjID &id) override
 
const DataObjIDCollinputDataObjs () const override
 
const DataObjIDColloutputDataObjs () const override
 
void addDependency (const DataObjID &id, const Gaudi::DataHandle::Mode &mode) override
 
- Public Member Functions inherited from extends< PropertyHolder< CommonMessaging< implements< IAlgTool, IDataHandleHolder, IProperty, IStateful > > >, IDataHandleHolder >
void const * i_cast (const InterfaceID &tid) const override
 Implementation of IInterface::i_cast.
 
StatusCode queryInterface (const InterfaceID &ti, void **pp) override
 Implementation of IInterface::queryInterface.
 
std::vector< std::string > getInterfaceNames () const override
 Implementation of IInterface::getInterfaceNames.
 
- Public Member Functions inherited from PropertyHolder< CommonMessaging< implements< IAlgTool, IDataHandleHolder, IProperty, IStateful > > >
StatusCode setProperty (const Gaudi::Details::PropertyBase &p)
 Set the property from a property.
 
StatusCode setProperty (const std::string &name, const char *v)
 Special case for string literals.
 
StatusCode setProperty (const std::string &name, const std::string &v)
 Special case for std::string.
 
StatusCode setProperty (const std::string &name, const TYPE &value)
 set the property form the value
 
 PropertyHolder ()=default
 
Gaudi::Details::PropertyBasedeclareProperty (Gaudi::Details::PropertyBase &prop)
 Declare a property.
 
Gaudi::Details::PropertyBasedeclareProperty (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.
 
Gaudi::Details::PropertyBasedeclareProperty (const std::string &name, Gaudi::Property< TYPE, VERIFIER, HANDLERS > &prop, const std::string &doc="none")
 Declare a PropertyBase instance setting name and documentation.
 
Gaudi::Details::PropertyBasedeclareRemoteProperty (const std::string &name, IProperty *rsvc, const std::string &rname="")
 Declare a remote property.
 
StatusCode setProperty (const std::string &name, const Gaudi::Details::PropertyBase &p) override
 set the property from another property with a different name
 
StatusCode setProperty (const std::string &s) override
 set the property from the formatted string
 
StatusCode setProperty (const Gaudi::Details::PropertyBase &p)
 Set the property from a property.
 
StatusCode setProperty (const std::string &name, const char *v)
 Special case for string literals.
 
StatusCode setProperty (const std::string &name, const std::string &v)
 Special case for std::string.
 
StatusCode setProperty (const std::string &name, const TYPE &value)
 set the property form the value
 
StatusCode setPropertyRepr (const std::string &n, const std::string &r) override
 set the property from name and value string representation
 
StatusCode getProperty (Gaudi::Details::PropertyBase *p) const override
 get the property
 
const Gaudi::Details::PropertyBasegetProperty (std::string_view name) const override
 get the property by name
 
StatusCode getProperty (std::string_view n, std::string &v) const override
 convert the property to the string
 
const std::vector< Gaudi::Details::PropertyBase * > & getProperties () const override
 get all properties
 
bool hasProperty (std::string_view name) const override
 Return true if we have a property with the given name.
 
Gaudi::Details::PropertyBaseproperty (std::string_view name) const
 \fixme property and bindPropertiesTo should be protected
 
void bindPropertiesTo (Gaudi::Interfaces::IOptionsSvc &optsSvc)
 
 PropertyHolder (const PropertyHolder &)=delete
 
PropertyHolderoperator= (const PropertyHolder &)=delete
 
- Public Member Functions inherited from CommonMessaging< implements< IAlgTool, IDataHandleHolder, IProperty, IStateful > >
MSG::Level msgLevel () const
 get the cached level (originally extracted from the embedded MsgStream)
 
bool msgLevel (MSG::Level lvl) const
 get the output level from the embedded MsgStream
 
- Public Member Functions inherited from CommonMessagingBase
virtual ~CommonMessagingBase ()=default
 Virtual destructor.
 
const SmartIF< IMessageSvc > & msgSvc () const
 The standard message service.
 
MsgStreammsgStream () const
 Return an uninitialized MsgStream.
 
MsgStreammsgStream (const MSG::Level level) const
 Predefined configurable message stream for the efficient printouts.
 
MsgStreamalways () const
 shortcut for the method msgStream(MSG::ALWAYS)
 
MsgStreamfatal () const
 shortcut for the method msgStream(MSG::FATAL)
 
MsgStreamerr () const
 shortcut for the method msgStream(MSG::ERROR)
 
MsgStreamerror () const
 shortcut for the method msgStream(MSG::ERROR)
 
MsgStreamwarning () const
 shortcut for the method msgStream(MSG::WARNING)
 
MsgStreaminfo () const
 shortcut for the method msgStream(MSG::INFO)
 
MsgStreamdebug () const
 shortcut for the method msgStream(MSG::DEBUG)
 
MsgStreamverbose () const
 shortcut for the method msgStream(MSG::VERBOSE)
 
MsgStreammsg () const
 shortcut for the method msgStream(MSG::INFO)
 

Private Member Functions

void i_collectLeaves ()
 Scan the data service starting from the node specified as Root.
 
void i_collectLeaves (IRegistry *reg)
 Scan the data service starting from the specified node.
 
IRegistryi_getRootNode ()
 Return the pointer to the IRegistry object associated to the node specified as Root.
 

Private Attributes

Gaudi::Property< std::string > m_dataSvcName { this, "DataService", "EventDataSvc", "Name of the data service to use" }
 
Gaudi::Property< std::string > m_rootNode { this, "Root", "", "Path to the element from which to start the scan" }
 
Gaudi::Property< bool > m_scanOnBeginEvent
 
Gaudi::Property< bool > m_ignoreOriginChange
 
SmartIF< IIncidentSvcm_incidentSvc
 Pointer to the incident service.
 
SmartIF< IDataManagerSvcm_dataMgrSvc
 Pointer to the IDataManagerSvc interface of the data service.
 
SmartIF< IDataProviderSvcm_dataSvc
 Pointer to the IDataProviderSvc interface of the data service.
 
LeavesList m_leaves
 Internal cache for the list of objects found during the scan.
 
std::string m_initialBase
 File ID of the Root node.
 

Additional Inherited Members

- Public Types inherited from extends< AlgTool, IDataStoreLeaves, IIncidentListener >
using base_class
 Typedef to this class.
 
using extend_interfaces_base
 Typedef to the base of this class.
 
- Public Types inherited from AlgTool
using Factory = Gaudi::PluginService::Factory<IAlgTool*( const std::string&, const std::string&, const IInterface* )>
 
- Public Types inherited from extends< PropertyHolder< CommonMessaging< implements< IAlgTool, IDataHandleHolder, IProperty, IStateful > > >, IDataHandleHolder >
using base_class
 Typedef to this class.
 
using extend_interfaces_base
 Typedef to the base of this class.
 
- Public Types inherited from PropertyHolder< CommonMessaging< implements< IAlgTool, IDataHandleHolder, IProperty, IStateful > > >
using PropertyHolderImpl
 Typedef used to refer to this class from derived classes, as in.
 
- Public Types inherited from CommonMessaging< implements< IAlgTool, IDataHandleHolder, IProperty, IStateful > >
using base_class
 
- Public Types inherited from extend_interfaces< Interfaces... >
using ext_iids
 take union of the ext_iids of all Interfaces...
 
- Protected Member Functions inherited from AlgTool
template<typename I>
void declareInterface (I *i)
 
std::vector< IAlgTool * > & tools ()
 
- Protected Member Functions inherited from DataHandleHolderBase< PropertyHolder< CommonMessaging< implements< IAlgTool, IDataHandleHolder, IProperty, IStateful > > > >
void initDataHandleHolder ()
 initializes all handles - called by the sysInitialize method of any descendant of this
 
- Protected Member Functions inherited from CommonMessaging< implements< IAlgTool, IDataHandleHolder, IProperty, IStateful > >
MSG::Level setUpMessaging () const
 Set up local caches.
 
MSG::Level resetMessaging ()
 Reinitialize internal states.
 
void updateMsgStreamOutputLevel (int level)
 Update the output level of the cached MsgStream.
 
- Protected Attributes inherited from AlgTool
std::unique_ptr< IDataHandleVisitorm_updateDataHandles
 Hook for for derived classes to provide a custom visitor for data handles.
 
- Protected Attributes inherited from DataHandleHolderBase< PropertyHolder< CommonMessaging< implements< IAlgTool, IDataHandleHolder, IProperty, IStateful > > > >
DataObjIDColl m_inputDataObjs
 
DataObjIDColl m_outputDataObjs
 

Detailed Description

Tool to scan a transient store branch that collects all the objects that belong to the same source (file).

By default, the list of entries is cached and the cache is cleared at every BeginEvent incident.

Properties:
DataService (string): Name of the data service to use [EventDataSvc]
Root (string): Path to the element from which to start the scan [root of the data service]
ScanOnBeginEvent (bool): If the scan has to be started during the BeginEvent incident (true) or on demand (false, default)

Definition at line 37 of file DataSvcFileEntriesTool.cpp.

Member Function Documentation

◆ finalize()

StatusCode DataSvcFileEntriesTool::finalize ( )
override

Finalize the tool.

Definition at line 135 of file DataSvcFileEntriesTool.cpp.

135 {
136 // unregister from the incident service
137 if ( m_incidentSvc ) { m_incidentSvc->removeListener( this, IncidentType::BeginEvent ); }
138 // Release the services
139 m_incidentSvc.reset();
140 m_dataMgrSvc.reset();
141 m_dataSvc.reset();
142
143 return AlgTool::finalize();
144}
StatusCode finalize() override
Definition AlgTool.cpp:225
SmartIF< IIncidentSvc > m_incidentSvc
Pointer to the incident service.
SmartIF< IDataManagerSvc > m_dataMgrSvc
Pointer to the IDataManagerSvc interface of the data service.
SmartIF< IDataProviderSvc > m_dataSvc
Pointer to the IDataProviderSvc interface of the data service.

◆ handle()

void DataSvcFileEntriesTool::handle ( const Incident & incident)
override

Call-back function for the BeginEvent incident.

Clears the internal cache, cache the file ID of the Root node and, if the property ScanOnBeginEvent is set to true, scans the data service.

Definition at line 146 of file DataSvcFileEntriesTool.cpp.

146 {
147 // Get the file id of the root node at every event
148 IOpaqueAddress* addr = i_getRootNode()->address();
149 if ( addr )
150 m_initialBase = addr->par()[0];
151 else
152 m_initialBase.clear(); // use empty file id if there is no address
153
154 m_leaves.clear();
155 if ( m_scanOnBeginEvent ) {
156 verbose() << "::handle scanning on " << incident.type() << endmsg;
158 }
159}
MsgStream & endmsg(MsgStream &s)
MsgStream Modifier: endmsg. Calls the output method of the MsgStream.
Definition MsgStream.h:198
MsgStream & verbose() const
shortcut for the method msgStream(MSG::VERBOSE)
Gaudi::Property< bool > m_scanOnBeginEvent
std::string m_initialBase
File ID of the Root node.
void i_collectLeaves()
Scan the data service starting from the node specified as Root.
LeavesList m_leaves
Internal cache for the list of objects found during the scan.
IRegistry * i_getRootNode()
Return the pointer to the IRegistry object associated to the node specified as Root.
virtual const std::string * par() const =0
Retrieve String parameters.
virtual IOpaqueAddress * address() const =0
Retrieve opaque storage address.
const std::string & type() const
Access to the incident type.
Definition Incident.h:43

◆ i_collectLeaves() [1/2]

void DataSvcFileEntriesTool::i_collectLeaves ( )
private

Scan the data service starting from the node specified as Root.

Definition at line 175 of file DataSvcFileEntriesTool.cpp.

◆ i_collectLeaves() [2/2]

void DataSvcFileEntriesTool::i_collectLeaves ( IRegistry * reg)
private

Scan the data service starting from the specified node.

todo: implement the scanning as an IDataStoreAgent

Definition at line 178 of file DataSvcFileEntriesTool.cpp.

178 {
179 // I do not put sanity checks on the pointers because I know how I'm calling the function
180 IOpaqueAddress* addr = reg->address();
181 if ( addr ) { // we consider only objects that are in a file
182 if ( msgLevel( MSG::VERBOSE ) ) verbose() << "::i_collectLeaves added " << reg->identifier() << endmsg;
183 m_leaves.push_back( reg->object() ); // add this object
184 // Origin of the current object
185 const std::string& base = addr->par()[0];
186 // Compare with the origin seen during BeginEvent
187 if ( !m_ignoreOriginChange && ( m_initialBase != base ) )
188 throw GaudiException( "Origin of data has changed ('" + m_initialBase + "' != '" + base +
189 "'), probably OutputStream was called before "
190 "InputCopyStream: check options",
192
193 std::vector<IRegistry*> lfs; // leaves of the current object
194 StatusCode sc = m_dataMgrSvc->objectLeaves( reg, lfs );
195 if ( sc.isSuccess() ) {
196 for ( const auto& i : lfs ) {
197 // Continue if the leaf has the same database as the parent
198 if ( i->address() && i->address()->par()[0] == base ) {
199 DataObject* obj = nullptr;
200 sc = m_dataSvc->retrieveObject( reg, i->name(), obj );
201 if ( sc.isSuccess() ) {
202 i_collectLeaves( i );
203 } else {
204 throw GaudiException( "Cannot get " + i->identifier() + " from " + m_dataSvcName, name(),
206 }
207 }
208 }
209 }
210 }
211}
const std::string & name() const override
Retrieve full identifying name of the concrete tool object.
Definition AlgTool.cpp:72
Gaudi::Property< std::string > m_dataSvcName
Gaudi::Property< bool > m_ignoreOriginChange
virtual const id_type & identifier() const =0
Full identifier (or key)
virtual DataObject * object() const =0
Retrieve object behind the link.
bool isSuccess() const
Definition StatusCode.h:314
constexpr static const auto FAILURE
Definition StatusCode.h:100
@ VERBOSE
Definition IMessageSvc.h:22

◆ i_getRootNode()

IRegistry * DataSvcFileEntriesTool::i_getRootNode ( )
private

Return the pointer to the IRegistry object associated to the node specified as Root.

Definition at line 166 of file DataSvcFileEntriesTool.cpp.

166 {
167 DataObject* obj = nullptr;
168 StatusCode sc = m_dataSvc->retrieveObject( m_rootNode.value(), obj );
169 if ( sc.isFailure() ) {
170 throw GaudiException( "Cannot get " + m_rootNode + " from " + m_dataSvcName, name(), StatusCode::FAILURE );
171 }
172 return obj->registry();
173}
IRegistry * registry() const
Get pointer to Registry.
Definition DataObject.h:79
Gaudi::Property< std::string > m_rootNode
bool isFailure() const
Definition StatusCode.h:129

◆ initialize()

StatusCode DataSvcFileEntriesTool::initialize ( )
override

Initialize the tool.

Definition at line 106 of file DataSvcFileEntriesTool.cpp.

106 {
107 StatusCode sc = AlgTool::initialize();
108 if ( sc.isFailure() ) return sc;
109
110 // Retrieve the pointer to the needed services.
111
112 m_incidentSvc = serviceLocator()->service( "IncidentSvc" );
113 if ( !m_incidentSvc ) {
114 error() << "Cannot get IncidentSvc" << endmsg;
115 return StatusCode::FAILURE;
116 }
117
119 if ( !m_dataSvc || !m_dataMgrSvc ) {
120 error() << "Cannot get IDataProviderSvc+IDataManagerSvc " << m_dataSvcName << endmsg;
121 return StatusCode::FAILURE;
122 }
123
124 // Register ourself to the incident service as listener for BeginEvent
125 m_incidentSvc->addListener( this, IncidentType::BeginEvent );
126
127 // If the Root node is not specified, take the name from the data service itself.
128 if ( m_rootNode.empty() ) { m_rootNode = m_dataMgrSvc->rootName(); }
129
130 // Clear the cache (in case the instance is re-initilized).
131 m_leaves.clear();
132 return StatusCode::SUCCESS;
133}
StatusCode initialize() override
Definition AlgTool.cpp:173
SmartIF< ISvcLocator > & serviceLocator() const override
Retrieve pointer to service locator.
Definition AlgTool.cpp:78
MsgStream & error() const
shortcut for the method msgStream(MSG::ERROR)
virtual SmartIF< IService > & service(const Gaudi::Utils::TypeNameString &typeName, const bool createIf=true)=0
Returns a smart pointer to a service.
constexpr static const auto SUCCESS
Definition StatusCode.h:99

◆ leaves()

const IDataStoreLeaves::LeavesList & DataSvcFileEntriesTool::leaves ( ) const
override

Return the list of collected objects.

If the scan was not yet done since the last BeginEvent incident, it is done when calling this function. The result of the scan is cached.

Definition at line 161 of file DataSvcFileEntriesTool.cpp.

161 {
162 if ( m_leaves.empty() ) { const_cast<DataSvcFileEntriesTool*>( this )->i_collectLeaves(); }
163 return m_leaves;
164}

Member Data Documentation

◆ m_dataMgrSvc

SmartIF<IDataManagerSvc> DataSvcFileEntriesTool::m_dataMgrSvc
private

Pointer to the IDataManagerSvc interface of the data service.

Definition at line 72 of file DataSvcFileEntriesTool.cpp.

◆ m_dataSvc

SmartIF<IDataProviderSvc> DataSvcFileEntriesTool::m_dataSvc
private

Pointer to the IDataProviderSvc interface of the data service.

Definition at line 74 of file DataSvcFileEntriesTool.cpp.

◆ m_dataSvcName

Gaudi::Property<std::string> DataSvcFileEntriesTool::m_dataSvcName { this, "DataService", "EventDataSvc", "Name of the data service to use" }
private

Definition at line 60 of file DataSvcFileEntriesTool.cpp.

60{ this, "DataService", "EventDataSvc", "Name of the data service to use" };

◆ m_ignoreOriginChange

Gaudi::Property<bool> DataSvcFileEntriesTool::m_ignoreOriginChange
private
Initial value:
{
this, "IgnoreOriginChange", false,
"Disable the detection of the change in the origin of object between the BeginEvent and the scan" }

Definition at line 65 of file DataSvcFileEntriesTool.cpp.

65 {
66 this, "IgnoreOriginChange", false,
67 "Disable the detection of the change in the origin of object between the BeginEvent and the scan" };

◆ m_incidentSvc

SmartIF<IIncidentSvc> DataSvcFileEntriesTool::m_incidentSvc
private

Pointer to the incident service.

Definition at line 70 of file DataSvcFileEntriesTool.cpp.

◆ m_initialBase

std::string DataSvcFileEntriesTool::m_initialBase
private

File ID of the Root node.

It is cached every BeginEvent to be compared with the one seen during the collection of the leaves, to avoid that the collection is altered by previous calls to an OutputStream.

Definition at line 92 of file DataSvcFileEntriesTool.cpp.

◆ m_leaves

LeavesList DataSvcFileEntriesTool::m_leaves
private

Internal cache for the list of objects found during the scan.

Definition at line 77 of file DataSvcFileEntriesTool.cpp.

◆ m_rootNode

Gaudi::Property<std::string> DataSvcFileEntriesTool::m_rootNode { this, "Root", "", "Path to the element from which to start the scan" }
private

Definition at line 61 of file DataSvcFileEntriesTool.cpp.

61{ this, "Root", "", "Path to the element from which to start the scan" };

◆ m_scanOnBeginEvent

Gaudi::Property<bool> DataSvcFileEntriesTool::m_scanOnBeginEvent
private
Initial value:
{
this, "ScanOnBeginEvent", false,
"If the scan has to be started during the BeginEvent incident (true) or on demand (false, default)" }

Definition at line 62 of file DataSvcFileEntriesTool.cpp.

62 {
63 this, "ScanOnBeginEvent", false,
64 "If the scan has to be started during the BeginEvent incident (true) or on demand (false, default)" };

The documentation for this class was generated from the following file: