The Gaudi Framework  v33r0 (d5ea422b)
MultiStoreSvc Class Reference

Data service base class. More...

Inheritance diagram for MultiStoreSvc:
Collaboration diagram for MultiStoreSvc:

Classes

struct  tagROOT
 Root type (address or object) More...
 

Public Member Functions

CLID rootCLID () const override
 IDataManagerSvc: Accessor for root event CLID. More...
 
const std::stringrootName () const override
 Name for root Event. More...
 
StatusCode registerAddress (std::string_view path, ADDRESS *pAddr) override
 IDataManagerSvc: Register object address with the data store. More...
 
StatusCode registerAddress (IRegistry *parent, std::string_view path, ADDRESS *pAddr) override
 IDataManagerSvc: Register object address with the data store. More...
 
StatusCode unregisterAddress (std::string_view path) override
 IDataManagerSvc: Unregister object address from the data store. More...
 
StatusCode unregisterAddress (IRegistry *pParent, std::string_view path) override
 IDataManagerSvc: Unregister object address from the data store. More...
 
StatusCode objectLeaves (const OBJECT *pObject, std::vector< IRegistry * > &leaves) override
 Explore the object store: retrieve all leaves attached to the object. More...
 
StatusCode objectLeaves (const IRegistry *pObject, std::vector< IRegistry * > &leaves) override
 Explore the object store: retrieve all leaves attached to the object. More...
 
StatusCode objectParent (const OBJECT *pObject, IRegistry *&refpParent) override
 IDataManagerSvc: Explore the object store: retrieve the object's parent. More...
 
StatusCode objectParent (const IRegistry *pObject, IRegistry *&refpParent) override
 IDataManagerSvc: Explore the object store: retrieve the object's parent. More...
 
StatusCode clearSubTree (std::string_view path) override
 Remove all data objects below the sub tree identified. More...
 
StatusCode clearSubTree (OBJECT *pObject) override
 Remove all data objects below the sub tree identified. More...
 
StatusCode clearStore () override
 IDataManagerSvc: Remove all data objects in the data store. More...
 
StatusCode traverseSubTree (std::string_view path, AGENT *pAgent) override
 Analyze by traversing all data objects below the sub tree. More...
 
StatusCode traverseSubTree (OBJECT *pObject, AGENT *pAgent) override
 IDataManagerSvc: Analyze by traversing all data objects below the sub tree. More...
 
StatusCode traverseTree (AGENT *pAgent) override
 IDataManagerSvc: Analyze by traversing all data objects in the data store. More...
 
StatusCode setRoot (std::string path, OBJECT *pObj) override
 Initialize data store for new event by giving new event path and root object. More...
 
StatusCode setRoot (std::string path, ADDRESS *pAddr) override
 Initialize data store for new event by giving new event path and address of root object. More...
 
StatusCode setDataLoader (IConversionSvc *pDataLoader, IDataProviderSvc *dpsvc=nullptr) override
 IDataManagerSvc: Pass a default data loader to the service. More...
 
StatusCode addPreLoadItem (const DataStoreItem &item) override
 Add an item to the preload list. More...
 
StatusCode removePreLoadItem (const DataStoreItem &item) override
 Remove an item from the preload list. More...
 
StatusCode resetPreLoad () override
 Clear the preload list. More...
 
StatusCode preLoad () override
 load all preload items of the list More...
 
StatusCode registerObject (std::string_view parent, std::string_view obj, OBJECT *pObj) override
 Register object with the data store. More...
 
StatusCode registerObject (OBJECT *parent, std::string_view obj, OBJECT *pObj) override
 Register object with the data store. More...
 
StatusCode unregisterObject (std::string_view path) override
 Unregister object from the data store. More...
 
StatusCode unregisterObject (OBJECT *pObj) override
 Unregister object from the data store. More...
 
StatusCode unregisterObject (OBJECT *pObj, std::string_view path) override
 Unregister object from the data store. More...
 
StatusCode retrieveObject (IRegistry *parent, std::string_view path, OBJECT *&pObj) override
 Retrieve object from data store. More...
 
StatusCode findObject (std::string_view path, OBJECT *&pObj) override
 Find object identified by its full path in the data store. More...
 
StatusCode findObject (IRegistry *parent, std::string_view path, OBJECT *&pObj) override
 Find object identified by its full path in the data store. More...
 
StatusCode linkObject (IRegistry *from, std::string_view objPath, OBJECT *to) override
 Add a link to another object. More...
 
StatusCode linkObject (std::string_view fullPath, OBJECT *to) override
 Add a link to another object. More...
 
StatusCode unlinkObject (IRegistry *from, std::string_view objPath) override
 Remove a link to another object. More...
 
StatusCode unlinkObject (OBJECT *from, std::string_view objPath) override
 Remove a link to another object. More...
 
StatusCode unlinkObject (std::string_view path) override
 Remove a link to another object. More...
 
StatusCode updateObject (IRegistry *pDirectory) override
 Update object identified by its directory entry. More...
 
StatusCode updateObject (OBJECT *pObj) override
 Update object. More...
 
StatusCode create (CSTR &nam, CSTR &typ) override
 Create a partition object. The name identifies the partition uniquely. More...
 
StatusCode create (CSTR &nam, CSTR &typ, IInterface *&pPartition) override
 Create a partition object. The name identifies the partition uniquely. More...
 
StatusCode drop (CSTR &nam) override
 Drop a partition object. The name identifies the partition uniquely. More...
 
StatusCode drop (IInterface *pPartition) override
 Drop a partition object. The name identifies the partition uniquely. More...
 
StatusCode activate (CSTR &nam) override
 Activate a partition object. The name identifies the partition uniquely. More...
 
StatusCode activate (IInterface *pPartition) override
 Activate a partition object. More...
 
StatusCode get (CSTR &nam, IInterface *&pPartition) const override
 Access a partition object. The name identifies the partition uniquely. More...
 
StatusCode activePartition (std::string &nam, IInterface *&pPartition) const override
 Access the active partition object. More...
 
StatusCode attachServices ()
 
StatusCode detachServices ()
 
StatusCode initialize () override
 Service initialisation. More...
 
StatusCode reinitialize () override
 Service initialisation. More...
 
StatusCode finalize () override
 Service initialisation. More...
 
 ~MultiStoreSvc () override
 Standard Destructor. More...
 
StatusCode preparePartitions ()
 Prepare partition for usage. More...
 
StatusCode clearPartitions ()
 Clear all partitions. More...
 
StatusCode makePartitions ()
 Create all partitions according to job options. More...
 
- Public Member Functions inherited from extends< Service, IDataProviderSvc, IDataManagerSvc, IPartitionControl >
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::stringgetInterfaceNames () const override
 Implementation of IInterface::getInterfaceNames. More...
 
- Public Member Functions inherited from Service
const std::stringname () const override
 Retrieve name of the service. More...
 
StatusCode configure () override
 
StatusCode initialize () override
 
StatusCode start () override
 
StatusCode stop () override
 
StatusCode finalize () override
 
StatusCode terminate () override
 
Gaudi::StateMachine::State FSMState () const override
 
Gaudi::StateMachine::State targetFSMState () const override
 
StatusCode reinitialize () override
 
StatusCode restart () override
 
StatusCode sysInitialize () override
 Initialize Service. More...
 
StatusCode sysStart () override
 Initialize Service. More...
 
StatusCode sysStop () override
 Initialize Service. More...
 
StatusCode sysFinalize () override
 Finalize Service. More...
 
StatusCode sysReinitialize () override
 Re-initialize the Service. More...
 
StatusCode sysRestart () override
 Re-initialize the Service. More...
 
 Service (std::string name, ISvcLocator *svcloc)
 Standard Constructor. More...
 
SmartIF< ISvcLocator > & serviceLocator () const override
 Retrieve pointer to service locator. More...
 
StatusCode setProperties ()
 Method for setting declared properties to the values specified for the job. More...
 
template<class T >
StatusCode service (const std::string &name, const 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 (const std::string &name, T *&psvc, bool createIf=true) const
 
template<typename IFace = IService>
SmartIF< IFace > service (const std::string &name, bool createIf=true) const
 
template<class T >
StatusCode service (const std::string &svcType, const std::string &svcName, T *&psvc) const
 Access a service by name and type, creating it if it doesn't already exist. More...
 
template<class T >
StatusCode declareTool (ToolHandle< T > &handle, std::string toolTypeAndName, bool createIf=true)
 Declare used tool. More...
 
SmartIF< IAuditorSvc > & auditorSvc () const
 The standard auditor service.May not be invoked before sysInitialize() has been invoked. More...
 
- Public Member Functions inherited from PropertyHolder< CommonMessaging< implements< IService, IProperty, IStateful > > >
 PropertyHolder ()=default
 
Gaudi::Details::PropertyBasedeclareProperty (Gaudi::Details::PropertyBase &prop)
 Declare a property. More...
 
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. More...
 
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. More...
 
Gaudi::Details::PropertyBasedeclareRemoteProperty (const std::string &name, IProperty *rsvc, const std::string &rname="")
 Declare a remote property. More...
 
StatusCode setProperty (const Gaudi::Details::PropertyBase &p) override
 set the property form another property More...
 
StatusCode setProperty (const std::string &s) override
 set the property from the formatted string More...
 
StatusCode setProperty (const std::string &n, const std::string &v) override
 set the property from name and the value More...
 
StatusCode setProperty (const std::string &name, const TYPE &value)
 set the property form the value More...
 
StatusCode getProperty (Gaudi::Details::PropertyBase *p) const override
 get the property More...
 
const Gaudi::Details::PropertyBasegetProperty (const std::string &name) const override
 get the property by name More...
 
StatusCode getProperty (const std::string &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 (const std::string &name) const override
 Return true if we have a property with the given name. More...
 
 PropertyHolder (const PropertyHolder &)=delete
 
PropertyHolderoperator= (const PropertyHolder &)=delete
 
- Public Member Functions inherited from CommonMessaging< implements< IService, IProperty, IStateful > >
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...
 
MSG::Level outputLevel () const
 Backward compatibility function for getting the output level. More...
 
- Public Member Functions inherited from CommonMessagingBase
virtual ~CommonMessagingBase ()=default
 Virtual destructor. More...
 
const SmartIF< IMessageSvc > & msgSvc () const
 The standard message service. More...
 
MsgStreammsgStream () const
 Return an uninitialized MsgStream. More...
 
MsgStreammsgStream (const MSG::Level level) const
 Predefined configurable message stream for the efficient printouts. More...
 
MsgStreamalways () const
 shortcut for the method msgStream(MSG::ALWAYS) More...
 
MsgStreamfatal () const
 shortcut for the method msgStream(MSG::FATAL) More...
 
MsgStreamerr () const
 shortcut for the method msgStream(MSG::ERROR) More...
 
MsgStreamerror () const
 shortcut for the method msgStream(MSG::ERROR) More...
 
MsgStreamwarning () const
 shortcut for the method msgStream(MSG::WARNING) More...
 
MsgStreaminfo () const
 shortcut for the method msgStream(MSG::INFO) More...
 
MsgStreamdebug () const
 shortcut for the method msgStream(MSG::DEBUG) More...
 
MsgStreamverbose () const
 shortcut for the method msgStream(MSG::VERBOSE) More...
 
MsgStreammsg () const
 shortcut for the method msgStream(MSG::INFO) More...
 

Protected Types

typedef std::vector< std::stringPartitionDefs
 
typedef std::map< std::string, Partition > Partitions
 

Protected Member Functions

template<typename Fun >
StatusCode fwd (Fun f)
 
- Protected Member Functions inherited from Service
 ~Service () override
 Standard Destructor. More...
 
int outputLevel () const
 get the Service's output level More...
 
- Protected Member Functions inherited from PropertyHolder< CommonMessaging< implements< IService, IProperty, IStateful > > >
Gaudi::Details::PropertyBaseproperty (const std::string &name) const
 
- Protected Member Functions inherited from CommonMessaging< implements< IService, IProperty, IStateful > >
MSG::Level setUpMessaging () const
 Set up local caches. More...
 
MSG::Level resetMessaging ()
 Reinitialize internal states. More...
 
void updateMsgStreamOutputLevel (int level)
 Update the output level of the cached MsgStream. More...
 

Protected Attributes

Gaudi::Property< CLIDm_rootCLID {this, "RootCLID", 110, "CLID of root entry"}
 
Gaudi::Property< std::stringm_rootName {this, "RootName", "/Event", "name of root entry"}
 
Gaudi::Property< PartitionDefsm_partitionDefs {this, "Partitions", {}, "datastore partition definitions"}
 
Gaudi::Property< std::stringm_loader {this, "DataLoader", "EventPersistencySvc", "data loader name"}
 
Gaudi::Property< std::stringm_defaultPartition {this, "DefaultPartition", "Default", "default partition name"}
 
SmartIF< IConversionSvcm_dataLoader
 Pointer to data loader service. More...
 
SmartIF< IAddressCreatorm_addrCreator
 Reference to address creator. More...
 
struct MultiStoreSvc::tagROOT m_root
 
Partition m_current
 Current partition. More...
 
Partitions m_partitions
 Datastore partitions. More...
 
- Protected Attributes inherited from Service
Gaudi::StateMachine::State m_state = Gaudi::StateMachine::OFFLINE
 Service state. More...
 
Gaudi::StateMachine::State m_targetState = Gaudi::StateMachine::OFFLINE
 Service state. More...
 
Gaudi::Property< int > m_outputLevel {this, "OutputLevel", MSG::NIL, "output level"}
 
Gaudi::Property< bool > m_auditInit {this, "AuditServices", false, " unused"}
 
Gaudi::Property< bool > m_auditorInitialize {this, "AuditInitialize", false, "trigger auditor on initialize()"}
 
Gaudi::Property< bool > m_auditorStart {this, "AuditStart", false, "trigger auditor on start()"}
 
Gaudi::Property< bool > m_auditorStop {this, "AuditStop", false, "trigger auditor on stop()"}
 
Gaudi::Property< bool > m_auditorFinalize {this, "AuditFinalize", false, "trigger auditor on finalize()"}
 
Gaudi::Property< bool > m_auditorReinitialize {this, "AuditReinitialize", false, "trigger auditor on reinitialize()"}
 
Gaudi::Property< bool > m_auditorRestart {this, "AuditRestart", false, "trigger auditor on restart()"}
 
SmartIF< IAuditorSvcm_pAuditorSvc
 Auditor Service. More...
 

Additional Inherited Members

- Public Types inherited from extends< Service, IDataProviderSvc, IDataManagerSvc, IPartitionControl >
using base_class = extends
 Typedef to this class. More...
 
using extend_interfaces_base = extend_interfaces< Interfaces... >
 Typedef to the base of this class. More...
 
- Public Types inherited from Service
using Factory = Gaudi::PluginService::Factory< IService *(const std::string &, ISvcLocator *)>
 
- Public Types inherited from PropertyHolder< CommonMessaging< implements< IService, IProperty, IStateful > > >
using PropertyHolderImpl = PropertyHolder< CommonMessaging< implements< IService, IProperty, IStateful > > >
 Typedef used to refer to this class from derived classes, as in. More...
 
- Public Types inherited from CommonMessaging< implements< IService, IProperty, IStateful > >
using base_class = CommonMessaging
 
- Public Types inherited from extend_interfaces< Interfaces... >
using ext_iids = typename Gaudi::interface_list_cat< typename Interfaces::ext_iids... >::type
 take union of the ext_iids of all Interfaces... More...
 

Detailed Description

Data service base class.

A data service manages the transient data stores and implements the IDataProviderSvc, the IDataManagerSvc and the IPartitionControl interfaces.

Author
Markus Frank
Sebastien Ponce
Version
1.0

Definition at line 106 of file MultiStoreSvc.cpp.

Member Typedef Documentation

◆ PartitionDefs

Definition at line 108 of file MultiStoreSvc.cpp.

◆ Partitions

typedef std::map<std::string, Partition> MultiStoreSvc::Partitions
protected

Definition at line 109 of file MultiStoreSvc.cpp.

Constructor & Destructor Documentation

◆ ~MultiStoreSvc()

MultiStoreSvc::~MultiStoreSvc ( )
inlineoverride

Standard Destructor.

Definition at line 489 of file MultiStoreSvc.cpp.

489  {
490  setDataLoader( nullptr ).ignore();
491  resetPreLoad().ignore();
492  clearStore().ignore();
494  }
StatusCode clearStore() override
IDataManagerSvc: Remove all data objects in the data store.
StatusCode clearPartitions()
Clear all partitions.
const StatusCode & ignore() const
Ignore/check StatusCode.
Definition: StatusCode.h:164
StatusCode resetPreLoad() override
Clear the preload list.
StatusCode setDataLoader(IConversionSvc *pDataLoader, IDataProviderSvc *dpsvc=nullptr) override
IDataManagerSvc: Pass a default data loader to the service.

Member Function Documentation

◆ activate() [1/2]

StatusCode MultiStoreSvc::activate ( CSTR nam)
inlineoverride

Activate a partition object. The name identifies the partition uniquely.

Definition at line 364 of file MultiStoreSvc.cpp.

364  {
365  auto i = m_partitions.find( nam );
366  if ( i != m_partitions.end() ) {
367  m_current = i->second;
368  return StatusCode::SUCCESS;
369  }
370  m_current = {};
372  }
Partitions m_partitions
Datastore partitions.
constexpr static const auto SUCCESS
Definition: StatusCode.h:96
T end(T... args)
Partition m_current
Current partition.
T find(T... args)

◆ activate() [2/2]

StatusCode MultiStoreSvc::activate ( IInterface pPartition)
inlineoverride

Activate a partition object.

Definition at line 375 of file MultiStoreSvc.cpp.

375  {
376  auto provider = SmartIF<IDataProviderSvc>( pPartition );
377  m_current = Partition();
378  if ( !provider ) return IInterface::Status::NO_INTERFACE;
380  [&]( Partitions::const_reference p ) { return p.second.dataProvider == provider; } );
382  m_current = i->second;
383  return StatusCode::SUCCESS;
384  }
Requested interface is not available.
Partitions m_partitions
Datastore partitions.
constexpr static const auto SUCCESS
Definition: StatusCode.h:96
T end(T... args)
Partition m_current
Current partition.
T find_if(T... args)
T begin(T... args)

◆ activePartition()

StatusCode MultiStoreSvc::activePartition ( std::string nam,
IInterface *&  pPartition 
) const
inlineoverride

Access the active partition object.

Definition at line 398 of file MultiStoreSvc.cpp.

398  {
399  if ( m_current.dataProvider ) {
400  nam = m_current.name;
401  pPartition = m_current.dataProvider;
402  return StatusCode::SUCCESS;
403  }
404  nam.clear();
405  pPartition = nullptr;
407  }
constexpr static const auto SUCCESS
Definition: StatusCode.h:96
T clear(T... args)
Partition m_current
Current partition.

◆ addPreLoadItem()

StatusCode MultiStoreSvc::addPreLoadItem ( const DataStoreItem item)
inlineoverride

Add an item to the preload list.

Definition at line 248 of file MultiStoreSvc.cpp.

248  {
249  return fwd( [&]( IDataProviderSvc& svc ) { return svc.addPreLoadItem( item ); } );
250  }
StatusCode fwd(Fun f)
virtual StatusCode addPreLoadItem(const DataStoreItem &item)=0
Add an item to the preload list.
Data provider interface definition.

◆ attachServices()

StatusCode MultiStoreSvc::attachServices ( )
inline

Definition at line 409 of file MultiStoreSvc.cpp.

409  {
410  // Attach address creator facility
411  m_addrCreator = service( m_loader, true );
412  if ( !m_addrCreator ) {
413  error() << "Failed to retrieve data loader "
414  << "\"" << m_loader << "\"" << endmsg;
415  return StatusCode::FAILURE;
416  }
417  // Attach data loader facility
418  auto dataLoader = service<IConversionSvc>( m_loader, true );
419  if ( !dataLoader ) {
420  error() << "Failed to retrieve data loader "
421  << "\"" << m_loader << "\"" << endmsg;
422  return StatusCode::FAILURE;
423  }
424  auto sc = setDataLoader( dataLoader.get() );
425  if ( !sc.isSuccess() ) {
426  error() << "Failed to set data loader "
427  << "\"" << m_loader << "\"" << endmsg;
428  }
429  return sc;
430  }
MsgStream & error() const
shortcut for the method msgStream(MSG::ERROR)
Gaudi::Property< std::string > m_loader
SmartIF< IAddressCreator > m_addrCreator
Reference to address creator.
constexpr static const auto FAILURE
Definition: StatusCode.h:97
StatusCode service(const std::string &name, const T *&psvc, bool createIf=true) const
Access a service by name, creating it if it doesn't already exist.
Definition: Service.h:93
StatusCode setDataLoader(IConversionSvc *pDataLoader, IDataProviderSvc *dpsvc=nullptr) override
IDataManagerSvc: Pass a default data loader to the service.
MsgStream & endmsg(MsgStream &s)
MsgStream Modifier: endmsg. Calls the output method of the MsgStream.
Definition: MsgStream.h:202

◆ clearPartitions()

StatusCode MultiStoreSvc::clearPartitions ( )
inline

Clear all partitions.

Definition at line 522 of file MultiStoreSvc.cpp.

522  {
523  for ( auto& i : m_partitions ) i.second.dataManager->clearStore().ignore();
525  return StatusCode::SUCCESS;
526  }
Partitions m_partitions
Datastore partitions.
constexpr static const auto SUCCESS
Definition: StatusCode.h:96
T clear(T... args)

◆ clearStore()

StatusCode MultiStoreSvc::clearStore ( )
inlineoverride

IDataManagerSvc: Remove all data objects in the data store.

Definition at line 185 of file MultiStoreSvc.cpp.

185  {
186  for ( auto& i : m_partitions ) { i.second.dataManager->clearStore().ignore(); }
187  visit(
188  m_root.root,
189  []( auto* p ) {
190  if ( p ) p->release();
191  },
192  []( std::monostate ) {} );
193  m_root.root = {};
194  m_root.path.clear();
195  return StatusCode::SUCCESS;
196  }
std::variant< std::monostate, ADDRESS *, OBJECT * > root
Partitions m_partitions
Datastore partitions.
struct MultiStoreSvc::tagROOT m_root
constexpr static const auto SUCCESS
Definition: StatusCode.h:96
T clear(T... args)

◆ clearSubTree() [1/2]

StatusCode MultiStoreSvc::clearSubTree ( std::string_view  path)
inlineoverride

Remove all data objects below the sub tree identified.

Definition at line 177 of file MultiStoreSvc.cpp.

177  {
178  return fwd( [&]( IDataManagerSvc& svc ) { return svc.clearSubTree( path ); } );
179  }
StatusCode fwd(Fun f)
virtual StatusCode clearSubTree(std::string_view sub_path)=0
Remove all data objects below the sub tree identified by its full path name.

◆ clearSubTree() [2/2]

StatusCode MultiStoreSvc::clearSubTree ( OBJECT pObject)
inlineoverride

Remove all data objects below the sub tree identified.

Definition at line 181 of file MultiStoreSvc.cpp.

181  {
182  return fwd( [&]( IDataManagerSvc& svc ) { return svc.clearSubTree( pObject ); } );
183  }
StatusCode fwd(Fun f)
virtual StatusCode clearSubTree(std::string_view sub_path)=0
Remove all data objects below the sub tree identified by its full path name.

◆ create() [1/2]

StatusCode MultiStoreSvc::create ( CSTR nam,
CSTR typ 
)
inlineoverride

Create a partition object. The name identifies the partition uniquely.

Definition at line 324 of file MultiStoreSvc.cpp.

324  {
325  IInterface* pPartition = nullptr;
326  return create( nam, typ, pPartition );
327  }
StatusCode create(CSTR &nam, CSTR &typ) override
Create a partition object. The name identifies the partition uniquely.
Definition of the basic interface.
Definition: IInterface.h:254

◆ create() [2/2]

StatusCode MultiStoreSvc::create ( CSTR nam,
CSTR typ,
IInterface *&  pPartition 
)
inlineoverride

Create a partition object. The name identifies the partition uniquely.

Fix-Me:
: In the old implementation the services were "unmanaged" (non-active)

Definition at line 329 of file MultiStoreSvc.cpp.

329  {
330  if ( get( nam, pPartition ).isSuccess() ) return IPartitionControl::Status::PARTITION_EXISTS;
332  auto isvc = serviceLocator()->service<IService>( typ );
333  if ( !isvc ) return IInterface::Status::NO_INTERFACE;
334  auto dataMgr = isvc.as<IDataManagerSvc>();
335  auto dataProv = isvc.as<IDataProviderSvc>();
336  if ( !dataMgr || !dataProv ) return IInterface::Status::NO_INTERFACE;
337  m_partitions.emplace( nam, Partition{dataProv, dataMgr, nam} );
338  return StatusCode::SUCCESS;
339  }
Requested interface is not available.
SmartIF< ISvcLocator > & serviceLocator() const override
Retrieve pointer to service locator.
Definition: Service.cpp:287
Partitions m_partitions
Datastore partitions.
constexpr static const auto SUCCESS
Definition: StatusCode.h:96
Data provider interface definition.
StatusCode get(CSTR &nam, IInterface *&pPartition) const override
Access a partition object. The name identifies the partition uniquely.
StatusCode service(const Gaudi::Utils::TypeNameString &name, T *&svc, bool createIf=true)
Templated method to access a service by name.
Definition: ISvcLocator.h:86
General service interface definition.
Definition: IService.h:28
T emplace(T... args)

◆ detachServices()

StatusCode MultiStoreSvc::detachServices ( )
inline

Definition at line 432 of file MultiStoreSvc.cpp.

432  {
435  return StatusCode::SUCCESS;
436  }
constexpr static const auto SUCCESS
Definition: StatusCode.h:96
SmartIF< IConversionSvc > m_dataLoader
Pointer to data loader service.
SmartIF< IAddressCreator > m_addrCreator
Reference to address creator.
void reset(TYPE *ptr=nullptr)
Set the internal pointer to the passed one disposing of the old one.
Definition: SmartIF.h:96

◆ drop() [1/2]

StatusCode MultiStoreSvc::drop ( CSTR nam)
inlineoverride

Drop a partition object. The name identifies the partition uniquely.

Definition at line 342 of file MultiStoreSvc.cpp.

342  {
343  auto i = m_partitions.find( nam );
345  if ( i->second.dataManager == m_current.dataManager ) { m_current = Partition(); }
346  i->second.dataManager->clearStore().ignore();
347  m_partitions.erase( i );
348  return StatusCode::SUCCESS;
349  }
Partitions m_partitions
Datastore partitions.
constexpr static const auto SUCCESS
Definition: StatusCode.h:96
T end(T... args)
T erase(T... args)
Partition m_current
Current partition.
T find(T... args)

◆ drop() [2/2]

StatusCode MultiStoreSvc::drop ( IInterface pPartition)
inlineoverride

Drop a partition object. The name identifies the partition uniquely.

Definition at line 352 of file MultiStoreSvc.cpp.

352  {
353  auto provider = SmartIF<IDataProviderSvc>( pPartition );
354  if ( !provider ) return IInterface::Status::NO_INTERFACE;
356  [&]( Partitions::const_reference p ) { return p.second.dataProvider == provider; } );
358  i->second.dataManager->clearStore().ignore();
359  m_partitions.erase( i );
360  return StatusCode::SUCCESS;
361  }
Requested interface is not available.
Partitions m_partitions
Datastore partitions.
constexpr static const auto SUCCESS
Definition: StatusCode.h:96
T end(T... args)
T erase(T... args)
T find_if(T... args)
T begin(T... args)

◆ finalize()

StatusCode MultiStoreSvc::finalize ( )
inlineoverride

Service initialisation.

Definition at line 474 of file MultiStoreSvc.cpp.

474  {
475  setDataLoader( nullptr ).ignore();
476  clearStore().ignore();
478  m_current = Partition();
479  detachServices();
480  return Service::finalize();
481  }
StatusCode detachServices()
StatusCode clearStore() override
IDataManagerSvc: Remove all data objects in the data store.
StatusCode finalize() override
Definition: Service.cpp:174
StatusCode clearPartitions()
Clear all partitions.
Partition m_current
Current partition.
const StatusCode & ignore() const
Ignore/check StatusCode.
Definition: StatusCode.h:164
StatusCode setDataLoader(IConversionSvc *pDataLoader, IDataProviderSvc *dpsvc=nullptr) override
IDataManagerSvc: Pass a default data loader to the service.

◆ findObject() [1/2]

StatusCode MultiStoreSvc::findObject ( std::string_view  path,
OBJECT *&  pObj 
)
inlineoverride

Find object identified by its full path in the data store.

Definition at line 288 of file MultiStoreSvc.cpp.

288  {
289  return fwd( [&]( IDataProviderSvc& svc ) { return svc.retrieveObject( path, pObj ); } );
290  }
StatusCode fwd(Fun f)
Data provider interface definition.
virtual StatusCode retrieveObject(IRegistry *pDirectory, std::string_view path, DataObject *&pObject)=0
Retrieve object identified by its directory entry.

◆ findObject() [2/2]

StatusCode MultiStoreSvc::findObject ( IRegistry parent,
std::string_view  path,
OBJECT *&  pObj 
)
inlineoverride

Find object identified by its full path in the data store.

Definition at line 292 of file MultiStoreSvc.cpp.

292  {
293  return fwd( [&]( IDataProviderSvc& svc ) { return svc.findObject( parent, path, pObj ); } );
294  }
StatusCode fwd(Fun f)
Data provider interface definition.
virtual StatusCode findObject(IRegistry *pDirectory, std::string_view path, DataObject *&pObject)=0
Find object identified by its directory entry.

◆ fwd()

template<typename Fun >
StatusCode MultiStoreSvc::fwd ( Fun  f)
inlineprotected

Definition at line 133 of file MultiStoreSvc.cpp.

133  {
134  auto* svc = m_current.get<std::decay_t<detail::argument_t<Fun>>>();
135  return svc ? f( *svc ) : IDataProviderSvc::Status::INVALID_ROOT;
136  }
Data provider interface definition.
Partition m_current
Current partition.

◆ get()

StatusCode MultiStoreSvc::get ( CSTR nam,
IInterface *&  pPartition 
) const
inlineoverride

Access a partition object. The name identifies the partition uniquely.

Definition at line 387 of file MultiStoreSvc.cpp.

387  {
388  auto i = m_partitions.find( nam );
389  if ( i != m_partitions.end() ) {
390  pPartition = i->second.dataProvider;
391  return StatusCode::SUCCESS;
392  }
393  pPartition = nullptr;
395  }
Partitions m_partitions
Datastore partitions.
constexpr static const auto SUCCESS
Definition: StatusCode.h:96
T end(T... args)
T find(T... args)

◆ initialize()

StatusCode MultiStoreSvc::initialize ( )
inlineoverride

Service initialisation.

Definition at line 439 of file MultiStoreSvc.cpp.

439  {
440  // Nothing to do: just call base class initialisation
442  if ( !sc.isSuccess() ) return sc;
443  sc = makePartitions();
444  if ( !sc.isSuccess() ) {
445  error() << "Failed to connect to all store partitions." << endmsg;
446  return sc;
447  }
448  return attachServices();
449  }
StatusCode initialize() override
Definition: Service.cpp:70
StatusCode attachServices()
MsgStream & error() const
shortcut for the method msgStream(MSG::ERROR)
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:61
bool isSuccess() const
Definition: StatusCode.h:361
StatusCode makePartitions()
Create all partitions according to job options.
MsgStream & endmsg(MsgStream &s)
MsgStream Modifier: endmsg. Calls the output method of the MsgStream.
Definition: MsgStream.h:202

◆ linkObject() [1/2]

StatusCode MultiStoreSvc::linkObject ( IRegistry from,
std::string_view  objPath,
OBJECT to 
)
inlineoverride

Add a link to another object.

Definition at line 296 of file MultiStoreSvc.cpp.

296  {
297  return fwd( [&]( IDataProviderSvc& svc ) { return svc.linkObject( from, objPath, to ); } );
298  }
StatusCode fwd(Fun f)
virtual StatusCode linkObject(IRegistry *from, std::string_view objPath, DataObject *toObj)=0
Add a link to another object.
Data provider interface definition.

◆ linkObject() [2/2]

StatusCode MultiStoreSvc::linkObject ( std::string_view  fullPath,
OBJECT to 
)
inlineoverride

Add a link to another object.

Definition at line 300 of file MultiStoreSvc.cpp.

300  {
301  return fwd( [&]( IDataProviderSvc& svc ) { return svc.linkObject( fullPath, to ); } );
302  }
StatusCode fwd(Fun f)
virtual StatusCode linkObject(IRegistry *from, std::string_view objPath, DataObject *toObj)=0
Add a link to another object.
Data provider interface definition.

◆ makePartitions()

StatusCode MultiStoreSvc::makePartitions ( )
inline

Create all partitions according to job options.

Definition at line 529 of file MultiStoreSvc.cpp.

529  {
530  using Parser = Gaudi::Utils::AttribStringParser;
531  std::string typ, nam;
533  for ( auto part : m_partitionDefs ) {
534  for ( auto attrib : Parser( std::move( part ) ) ) {
535  switch ( ::toupper( attrib.tag[0] ) ) {
536  case 'N':
537  nam = std::move( attrib.value );
538  break;
539  case 'T':
540  typ = std::move( attrib.value );
541  break;
542  }
543  }
544  StatusCode sc = create( nam, typ );
545  if ( !sc.isSuccess() ) return sc;
546  if ( m_defaultPartition.empty() ) m_defaultPartition = nam;
547  }
548  return StatusCode::SUCCESS;
549  }
Parse attribute strings allowing iteration over the various attributes.
StatusCode create(CSTR &nam, CSTR &typ) override
Create a partition object. The name identifies the partition uniquely.
constexpr static const auto SUCCESS
Definition: StatusCode.h:96
STL class.
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:61
StatusCode clearPartitions()
Clear all partitions.
Gaudi::Property< std::string > m_defaultPartition
bool isSuccess() const
Definition: StatusCode.h:361
T move(T... args)
const StatusCode & ignore() const
Ignore/check StatusCode.
Definition: StatusCode.h:164
Gaudi::Property< PartitionDefs > m_partitionDefs
void toupper(std::string &s)

◆ objectLeaves() [1/2]

StatusCode MultiStoreSvc::objectLeaves ( const OBJECT pObject,
std::vector< IRegistry * > &  leaves 
)
inlineoverride

Explore the object store: retrieve all leaves attached to the object.

Definition at line 161 of file MultiStoreSvc.cpp.

161  {
162  return fwd( [&]( IDataManagerSvc& svc ) { return svc.objectLeaves( pObject, leaves ); } );
163  }
virtual StatusCode objectLeaves(const DataObject *pObject, std::vector< IRegistry * > &refLeaves)=0
Explore the object store: retrieve all leaves attached to the object The object is identified by its ...
StatusCode fwd(Fun f)

◆ objectLeaves() [2/2]

StatusCode MultiStoreSvc::objectLeaves ( const IRegistry pObject,
std::vector< IRegistry * > &  leaves 
)
inlineoverride

Explore the object store: retrieve all leaves attached to the object.

Definition at line 165 of file MultiStoreSvc.cpp.

165  {
166  return fwd( [&]( IDataManagerSvc& svc ) { return svc.objectLeaves( pObject, leaves ); } );
167  }
virtual StatusCode objectLeaves(const DataObject *pObject, std::vector< IRegistry * > &refLeaves)=0
Explore the object store: retrieve all leaves attached to the object The object is identified by its ...
StatusCode fwd(Fun f)

◆ objectParent() [1/2]

StatusCode MultiStoreSvc::objectParent ( const OBJECT pObject,
IRegistry *&  refpParent 
)
inlineoverride

IDataManagerSvc: Explore the object store: retrieve the object's parent.

Definition at line 169 of file MultiStoreSvc.cpp.

169  {
170  return fwd( [&]( IDataManagerSvc& svc ) { return svc.objectParent( pObject, refpParent ); } );
171  }
StatusCode fwd(Fun f)
virtual StatusCode objectParent(const DataObject *pObject, IRegistry *&refpParent)=0
IDataManagerSvc: Explore the object store: retrieve the object's parent.

◆ objectParent() [2/2]

StatusCode MultiStoreSvc::objectParent ( const IRegistry pObject,
IRegistry *&  refpParent 
)
inlineoverride

IDataManagerSvc: Explore the object store: retrieve the object's parent.

Definition at line 173 of file MultiStoreSvc.cpp.

173  {
174  return fwd( [&]( IDataManagerSvc& svc ) { return svc.objectParent( pObject, refpParent ); } );
175  }
StatusCode fwd(Fun f)
virtual StatusCode objectParent(const DataObject *pObject, IRegistry *&refpParent)=0
IDataManagerSvc: Explore the object store: retrieve the object's parent.

◆ preLoad()

StatusCode MultiStoreSvc::preLoad ( )
inlineoverride

load all preload items of the list

Definition at line 260 of file MultiStoreSvc.cpp.

260  {
261  return fwd( [&]( IDataProviderSvc& svc ) { return svc.preLoad(); } );
262  }
StatusCode fwd(Fun f)
virtual StatusCode preLoad()=0
Load all preload items of the list.
Data provider interface definition.

◆ preparePartitions()

StatusCode MultiStoreSvc::preparePartitions ( )
inline

Prepare partition for usage.

Definition at line 497 of file MultiStoreSvc.cpp.

497  {
499  for ( auto& i : m_partitions ) {
500  StatusCode sc = visit(
501  m_root.root,
502  [&]( ADDRESS* address ) -> StatusCode {
503  if ( !address ) return StatusCode::FAILURE;
504  ADDRESS* pAdd = nullptr;
505  ADDRESS* p = address;
506  auto sc = m_addrCreator->createAddress( p->svcType(), p->clID(), p->par(), p->ipar(), pAdd );
507  return sc.isSuccess() ? i.second.dataManager->setRoot( m_root.path, pAdd ) : sc;
508  },
509  [&]( OBJECT* object ) -> StatusCode {
510  if ( object && object->clID() == CLID_DataObject ) {
511  return i.second.dataManager->setRoot( m_root.path, new DataObject() );
512  }
513  return StatusCode::FAILURE;
514  },
515  []( std::monostate ) -> StatusCode { return StatusCode::FAILURE; } );
516  if ( !sc.isSuccess() ) iret = sc;
517  }
518  return iret;
519  }
std::variant< std::monostate, ADDRESS *, OBJECT * > root
Partitions m_partitions
Datastore partitions.
struct MultiStoreSvc::tagROOT m_root
constexpr static const auto SUCCESS
Definition: StatusCode.h:96
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:61
bool isSuccess() const
Definition: StatusCode.h:361
constexpr static const auto FAILURE
Definition: StatusCode.h:97
Opaque address interface definition.
A DataObject is the base class of any identifiable object on any data store.
Definition: DataObject.h:40

◆ registerAddress() [1/2]

StatusCode MultiStoreSvc::registerAddress ( std::string_view  path,
ADDRESS pAddr 
)
inlineoverride

IDataManagerSvc: Register object address with the data store.

Definition at line 145 of file MultiStoreSvc.cpp.

145  {
146  return fwd( [&]( IDataManagerSvc& svc ) { return svc.registerAddress( path, pAddr ); } );
147  }
StatusCode fwd(Fun f)
virtual StatusCode registerAddress(std::string_view fullPath, IOpaqueAddress *pAddress)=0
Register object address with the data store.

◆ registerAddress() [2/2]

StatusCode MultiStoreSvc::registerAddress ( IRegistry parent,
std::string_view  path,
ADDRESS pAddr 
)
inlineoverride

IDataManagerSvc: Register object address with the data store.

Definition at line 149 of file MultiStoreSvc.cpp.

149  {
150  return fwd( [&]( IDataManagerSvc& svc ) { return svc.registerAddress( parent, path, pAddr ); } );
151  }
StatusCode fwd(Fun f)
virtual StatusCode registerAddress(std::string_view fullPath, IOpaqueAddress *pAddress)=0
Register object address with the data store.

◆ registerObject() [1/2]

StatusCode MultiStoreSvc::registerObject ( std::string_view  parent,
std::string_view  obj,
OBJECT pObj 
)
inlineoverride

Register object with the data store.

Definition at line 264 of file MultiStoreSvc.cpp.

264  {
265  return fwd( [&]( IDataProviderSvc& svc ) { return svc.registerObject( parent, obj, pObj ); } );
266  }
StatusCode fwd(Fun f)
Data provider interface definition.
StatusCode registerObject(std::string_view fullPath, DataObject *pObject)
Register object with the data store.

◆ registerObject() [2/2]

StatusCode MultiStoreSvc::registerObject ( OBJECT parent,
std::string_view  obj,
OBJECT pObj 
)
inlineoverride

Register object with the data store.

Definition at line 268 of file MultiStoreSvc.cpp.

268  {
269  return fwd( [&]( IDataProviderSvc& svc ) { return svc.registerObject( parent, obj, pObj ); } );
270  }
StatusCode fwd(Fun f)
Data provider interface definition.
StatusCode registerObject(std::string_view fullPath, DataObject *pObject)
Register object with the data store.

◆ reinitialize()

StatusCode MultiStoreSvc::reinitialize ( )
inlineoverride

Service initialisation.

Definition at line 452 of file MultiStoreSvc.cpp.

452  {
454  if ( !sc.isSuccess() ) {
455  error() << "Enable to reinitialize base class" << endmsg;
456  return sc;
457  }
458  detachServices();
459  sc = attachServices();
460  if ( !sc.isSuccess() ) {
461  error() << "Failed to attach necessary services." << endmsg;
462  return sc;
463  }
464  sc = makePartitions();
465  if ( !sc.isSuccess() ) {
466  error() << "Failed to connect to store partitions." << endmsg;
467  return sc;
468  }
469  // return
470  return StatusCode::SUCCESS;
471  }
StatusCode detachServices()
constexpr static const auto SUCCESS
Definition: StatusCode.h:96
StatusCode attachServices()
MsgStream & error() const
shortcut for the method msgStream(MSG::ERROR)
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:61
StatusCode reinitialize() override
Definition: Service.cpp:247
bool isSuccess() const
Definition: StatusCode.h:361
StatusCode makePartitions()
Create all partitions according to job options.
MsgStream & endmsg(MsgStream &s)
MsgStream Modifier: endmsg. Calls the output method of the MsgStream.
Definition: MsgStream.h:202

◆ removePreLoadItem()

StatusCode MultiStoreSvc::removePreLoadItem ( const DataStoreItem item)
inlineoverride

Remove an item from the preload list.

Definition at line 252 of file MultiStoreSvc.cpp.

252  {
253  return fwd( [&]( IDataProviderSvc& svc ) { return svc.removePreLoadItem( item ); } );
254  }
StatusCode fwd(Fun f)
Data provider interface definition.
virtual StatusCode removePreLoadItem(const DataStoreItem &item)=0
Remove an item from the preload list.

◆ resetPreLoad()

StatusCode MultiStoreSvc::resetPreLoad ( )
inlineoverride

Clear the preload list.

Definition at line 256 of file MultiStoreSvc.cpp.

256  {
257  return fwd( [&]( IDataProviderSvc& svc ) { return svc.resetPreLoad(); } );
258  }
StatusCode fwd(Fun f)
virtual StatusCode resetPreLoad()=0
Clear the preload list.
Data provider interface definition.

◆ retrieveObject()

StatusCode MultiStoreSvc::retrieveObject ( IRegistry parent,
std::string_view  path,
OBJECT *&  pObj 
)
inlineoverride

Retrieve object from data store.

Definition at line 284 of file MultiStoreSvc.cpp.

284  {
285  return fwd( [&]( IDataProviderSvc& svc ) { return svc.retrieveObject( parent, path, pObj ); } );
286  }
StatusCode fwd(Fun f)
Data provider interface definition.
virtual StatusCode retrieveObject(IRegistry *pDirectory, std::string_view path, DataObject *&pObject)=0
Retrieve object identified by its directory entry.

◆ rootCLID()

CLID MultiStoreSvc::rootCLID ( ) const
inlineoverride

IDataManagerSvc: Accessor for root event CLID.

Definition at line 140 of file MultiStoreSvc.cpp.

140 { return m_rootCLID; }
Gaudi::Property< CLID > m_rootCLID

◆ rootName()

const std::string& MultiStoreSvc::rootName ( ) const
inlineoverride

Name for root Event.

Definition at line 142 of file MultiStoreSvc.cpp.

142 { return m_rootName; }
Gaudi::Property< std::string > m_rootName

◆ setDataLoader()

StatusCode MultiStoreSvc::setDataLoader ( IConversionSvc pDataLoader,
IDataProviderSvc dpsvc = nullptr 
)
inlineoverride

IDataManagerSvc: Pass a default data loader to the service.

Definition at line 241 of file MultiStoreSvc.cpp.

241  {
242  m_dataLoader = pDataLoader;
243  if ( m_dataLoader ) m_dataLoader->setDataProvider( dpsvc ? dpsvc : this );
244  for ( auto& i : m_partitions ) { i.second.dataManager->setDataLoader( m_dataLoader.get() ).ignore(); }
245  return StatusCode::SUCCESS;
246  }
Partitions m_partitions
Datastore partitions.
virtual StatusCode setDataProvider(IDataProviderSvc *pService)=0
Set Data provider service.
constexpr static const auto SUCCESS
Definition: StatusCode.h:96
TYPE * get() const
Get interface pointer.
Definition: SmartIF.h:86
SmartIF< IConversionSvc > m_dataLoader
Pointer to data loader service.

◆ setRoot() [1/2]

StatusCode MultiStoreSvc::setRoot ( std::string  path,
OBJECT pObj 
)
inlineoverride

Initialize data store for new event by giving new event path and root object.

Takes care to clear the store before reinitializing it

Definition at line 211 of file MultiStoreSvc.cpp.

211  {
212  visit(
213  m_root.root,
214  []( auto* p ) {
215  if ( p ) p->release();
216  },
217  []( std::monostate ) {} );
218  m_root.path = std::move( path );
219  m_root.root = pObj;
221  return activate( m_defaultPartition );
222  }
std::variant< std::monostate, ADDRESS *, OBJECT * > root
struct MultiStoreSvc::tagROOT m_root
Gaudi::Property< std::string > m_defaultPartition
StatusCode preparePartitions()
Prepare partition for usage.
T move(T... args)
StatusCode activate(CSTR &nam) override
Activate a partition object. The name identifies the partition uniquely.

◆ setRoot() [2/2]

StatusCode MultiStoreSvc::setRoot ( std::string  path,
ADDRESS pAddr 
)
inlineoverride

Initialize data store for new event by giving new event path and address of root object.

Takes care to clear the store before reinitializing it

Definition at line 226 of file MultiStoreSvc.cpp.

226  {
227  visit(
228  m_root.root,
229  []( auto* p ) {
230  if ( p ) p->release();
231  },
232  []( std::monostate ) {} );
233  m_root.path = std::move( path );
234  m_root.root = pAddr;
235  if ( !pAddr ) return StatusCode::FAILURE;
236  pAddr->addRef();
238  return activate( m_defaultPartition );
239  }
std::variant< std::monostate, ADDRESS *, OBJECT * > root
struct MultiStoreSvc::tagROOT m_root
Gaudi::Property< std::string > m_defaultPartition
StatusCode preparePartitions()
Prepare partition for usage.
T move(T... args)
StatusCode activate(CSTR &nam) override
Activate a partition object. The name identifies the partition uniquely.
constexpr static const auto FAILURE
Definition: StatusCode.h:97
virtual unsigned long addRef()=0
Add reference to object.

◆ traverseSubTree() [1/2]

StatusCode MultiStoreSvc::traverseSubTree ( std::string_view  path,
AGENT pAgent 
)
inlineoverride

Analyze by traversing all data objects below the sub tree.

Definition at line 198 of file MultiStoreSvc.cpp.

198  {
199  return fwd( [&]( IDataManagerSvc& svc ) { return svc.traverseSubTree( path, pAgent ); } );
200  }
StatusCode fwd(Fun f)
virtual StatusCode traverseSubTree(std::string_view sub_tree_path, IDataStoreAgent *pAgent)=0
Analyse by traversing all data objects below the sub tree identified by its full path name.

◆ traverseSubTree() [2/2]

StatusCode MultiStoreSvc::traverseSubTree ( OBJECT pObject,
AGENT pAgent 
)
inlineoverride

IDataManagerSvc: Analyze by traversing all data objects below the sub tree.

Definition at line 202 of file MultiStoreSvc.cpp.

202  {
203  return fwd( [&]( IDataManagerSvc& svc ) { return svc.traverseSubTree( pObject, pAgent ); } );
204  }
StatusCode fwd(Fun f)
virtual StatusCode traverseSubTree(std::string_view sub_tree_path, IDataStoreAgent *pAgent)=0
Analyse by traversing all data objects below the sub tree identified by its full path name.

◆ traverseTree()

StatusCode MultiStoreSvc::traverseTree ( AGENT pAgent)
inlineoverride

IDataManagerSvc: Analyze by traversing all data objects in the data store.

Definition at line 206 of file MultiStoreSvc.cpp.

206  {
207  return fwd( [&]( IDataManagerSvc& svc ) { return svc.traverseTree( pAgent ); } );
208  }
virtual StatusCode traverseTree(IDataStoreAgent *pAgent)=0
Analyse by traversing all data objects in the data store.
StatusCode fwd(Fun f)

◆ unlinkObject() [1/3]

StatusCode MultiStoreSvc::unlinkObject ( IRegistry from,
std::string_view  objPath 
)
inlineoverride

Remove a link to another object.

Definition at line 304 of file MultiStoreSvc.cpp.

304  {
305  return fwd( [&]( IDataProviderSvc& svc ) { return svc.unlinkObject( from, objPath ); } );
306  }
StatusCode fwd(Fun f)
Data provider interface definition.
virtual StatusCode unlinkObject(IRegistry *from, std::string_view objPath)=0
Remove a link to another object.

◆ unlinkObject() [2/3]

StatusCode MultiStoreSvc::unlinkObject ( OBJECT from,
std::string_view  objPath 
)
inlineoverride

Remove a link to another object.

Definition at line 308 of file MultiStoreSvc.cpp.

308  {
309  return fwd( [&]( IDataProviderSvc& svc ) { return svc.unlinkObject( from, objPath ); } );
310  }
StatusCode fwd(Fun f)
Data provider interface definition.
virtual StatusCode unlinkObject(IRegistry *from, std::string_view objPath)=0
Remove a link to another object.

◆ unlinkObject() [3/3]

StatusCode MultiStoreSvc::unlinkObject ( std::string_view  path)
inlineoverride

Remove a link to another object.

Definition at line 312 of file MultiStoreSvc.cpp.

312  {
313  return fwd( [&]( IDataProviderSvc& svc ) { return svc.unlinkObject( path ); } );
314  }
StatusCode fwd(Fun f)
Data provider interface definition.
virtual StatusCode unlinkObject(IRegistry *from, std::string_view objPath)=0
Remove a link to another object.

◆ unregisterAddress() [1/2]

StatusCode MultiStoreSvc::unregisterAddress ( std::string_view  path)
inlineoverride

IDataManagerSvc: Unregister object address from the data store.

Definition at line 153 of file MultiStoreSvc.cpp.

153  {
154  return fwd( [&]( IDataManagerSvc& svc ) { return svc.unregisterAddress( path ); } );
155  }
StatusCode fwd(Fun f)
virtual StatusCode unregisterAddress(std::string_view fullPath)=0
Unregister object address from the data store.

◆ unregisterAddress() [2/2]

StatusCode MultiStoreSvc::unregisterAddress ( IRegistry pParent,
std::string_view  path 
)
inlineoverride

IDataManagerSvc: Unregister object address from the data store.

Definition at line 157 of file MultiStoreSvc.cpp.

157  {
158  return fwd( [&]( IDataManagerSvc& svc ) { return svc.unregisterAddress( pParent, path ); } );
159  }
StatusCode fwd(Fun f)
virtual StatusCode unregisterAddress(std::string_view fullPath)=0
Unregister object address from the data store.

◆ unregisterObject() [1/3]

StatusCode MultiStoreSvc::unregisterObject ( std::string_view  path)
inlineoverride

Unregister object from the data store.

Definition at line 272 of file MultiStoreSvc.cpp.

272  {
273  return fwd( [&]( IDataProviderSvc& svc ) { return svc.unregisterObject( path ); } );
274  }
StatusCode fwd(Fun f)
Data provider interface definition.
virtual StatusCode unregisterObject(std::string_view fullPath)=0
Unregister object from the data store.

◆ unregisterObject() [2/3]

StatusCode MultiStoreSvc::unregisterObject ( OBJECT pObj)
inlineoverride

Unregister object from the data store.

Definition at line 276 of file MultiStoreSvc.cpp.

276  {
277  return fwd( [&]( IDataProviderSvc& svc ) { return svc.unregisterObject( pObj ); } );
278  }
StatusCode fwd(Fun f)
Data provider interface definition.
virtual StatusCode unregisterObject(std::string_view fullPath)=0
Unregister object from the data store.

◆ unregisterObject() [3/3]

StatusCode MultiStoreSvc::unregisterObject ( OBJECT pObj,
std::string_view  path 
)
inlineoverride

Unregister object from the data store.

Definition at line 280 of file MultiStoreSvc.cpp.

280  {
281  return fwd( [&]( IDataProviderSvc& svc ) { return svc.unregisterObject( pObj, path ); } );
282  }
StatusCode fwd(Fun f)
Data provider interface definition.
virtual StatusCode unregisterObject(std::string_view fullPath)=0
Unregister object from the data store.

◆ updateObject() [1/2]

StatusCode MultiStoreSvc::updateObject ( IRegistry pDirectory)
inlineoverride

Update object identified by its directory entry.

Definition at line 316 of file MultiStoreSvc.cpp.

316  {
317  return fwd( [&]( IDataProviderSvc& svc ) { return svc.updateObject( pDirectory ); } );
318  }
StatusCode fwd(Fun f)
Data provider interface definition.
virtual StatusCode updateObject(IRegistry *pDirectory)=0
Update object identified by its directory entry.

◆ updateObject() [2/2]

StatusCode MultiStoreSvc::updateObject ( OBJECT pObj)
inlineoverride

Update object.

Definition at line 320 of file MultiStoreSvc.cpp.

320  {
321  return fwd( [&]( IDataProviderSvc& svc ) { return svc.updateObject( pObj ); } );
322  }
StatusCode fwd(Fun f)
Data provider interface definition.
virtual StatusCode updateObject(IRegistry *pDirectory)=0
Update object identified by its directory entry.

Member Data Documentation

◆ m_addrCreator

SmartIF<IAddressCreator> MultiStoreSvc::m_addrCreator
protected

Reference to address creator.

Definition at line 120 of file MultiStoreSvc.cpp.

◆ m_current

Partition MultiStoreSvc::m_current
protected

Current partition.

Definition at line 127 of file MultiStoreSvc.cpp.

◆ m_dataLoader

SmartIF<IConversionSvc> MultiStoreSvc::m_dataLoader
protected

Pointer to data loader service.

Definition at line 118 of file MultiStoreSvc.cpp.

◆ m_defaultPartition

Gaudi::Property<std::string> MultiStoreSvc::m_defaultPartition {this, "DefaultPartition", "Default", "default partition name"}
protected

Definition at line 115 of file MultiStoreSvc.cpp.

◆ m_loader

Gaudi::Property<std::string> MultiStoreSvc::m_loader {this, "DataLoader", "EventPersistencySvc", "data loader name"}
protected

Definition at line 114 of file MultiStoreSvc.cpp.

◆ m_partitionDefs

Gaudi::Property<PartitionDefs> MultiStoreSvc::m_partitionDefs {this, "Partitions", {}, "datastore partition definitions"}
protected

Definition at line 113 of file MultiStoreSvc.cpp.

◆ m_partitions

Partitions MultiStoreSvc::m_partitions
protected

Datastore partitions.

Definition at line 129 of file MultiStoreSvc.cpp.

◆ m_root

struct MultiStoreSvc::tagROOT MultiStoreSvc::m_root
protected

◆ m_rootCLID

Gaudi::Property<CLID> MultiStoreSvc::m_rootCLID {this, "RootCLID", 110, "CLID of root entry"}
protected

Definition at line 111 of file MultiStoreSvc.cpp.

◆ m_rootName

Gaudi::Property<std::string> MultiStoreSvc::m_rootName {this, "RootName", "/Event", "name of root entry"}
protected

Definition at line 112 of file MultiStoreSvc.cpp.


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