The Gaudi Framework  v30r4 (9b837755)
NTupleSvc Class Reference

NTuple service. More...

#include <src/NTupleSvc/NTupleSvc.h>

Inheritance diagram for NTupleSvc:
Collaboration diagram for NTupleSvc:

Classes

struct  Connection
 

Public Member Functions

StatusCode initialize () override
 DataSvc overrides: Initialize the service. More...
 
StatusCode reinitialize () override
 DataSvc overrides: reinitialize service. More...
 
StatusCode finalize () override
 DataSvc overrides: stop the service. More...
 
IConversionSvcgetDataLoader (IRegistry *pReg) override
 DataSvc overrides: Retrieve data loader. More...
 
NTuple::DirectorycreateDirectory (DataObject *pParent, const std::string &title) override
 Create Ntuple directory and register it with the data store. More...
 
NTuple::DirectorycreateDirectory (DataObject *pParent, long id) override
 Create Ntuple directory and register it with the data store. More...
 
NTuple::DirectorycreateDirectory (const std::string &dirPath, long id) override
 Create Ntuple directory and register it with the data store. More...
 
NTuple::DirectorycreateDirectory (const std::string &dirPath, const std::string &title) override
 Create Ntuple directory and register it with the data store. More...
 
NTuple::DirectorycreateDirectory (const std::string &fullPath) override
 Create Ntuple directory and register it with the data store. More...
 
StatusCode create (const CLID &typ, const std::string &title, NTuple::Tuple *&refpTuple) override
 Create requested N tuple (Hide constructor) More...
 
NTuple::Tuplebook (const std::string &fullPath, const CLID &type, const std::string &title) override
 Book Ntuple and register it with the data store. More...
 
NTuple::Tuplebook (const std::string &dirPath, const std::string &relPath, const CLID &type, const std::string &title) override
 Book Ntuple and register it with the data store. More...
 
NTuple::Tuplebook (const std::string &dirPath, long id, const CLID &type, const std::string &title) override
 Book Ntuple and register it with the data store. More...
 
NTuple::Tuplebook (DataObject *pParent, const std::string &relPath, const CLID &type, const std::string &title) override
 Book Ntuple and register it with the data store. More...
 
NTuple::Tuplebook (DataObject *pParent, long id, const CLID &type, const std::string &title) override
 Book Ntuple and register it with the data store. More...
 
NTuple::Tupleaccess (const std::string &fullPath, const std::string &filename) override
 Access N tuple on disk. More...
 
StatusCode save (const std::string &fullPath) override
 Save N tuple to disk. Must be called in order to close the ntuple file properly. More...
 
StatusCode save (NTuple::Tuple *tuple) override
 Save N tuple to disk. Must be called in order to close the ntuple file properly. More...
 
StatusCode save (DataObject *pParent, const std::string &relPath) override
 Save N tuple to disk. Must be called in order to close the ntuple file properly. More...
 
StatusCode writeRecord (NTuple::Tuple *tuple) override
 Write single record to N tuple. More...
 
StatusCode writeRecord (const std::string &fullPath) override
 Write single record to N tuple. More...
 
StatusCode writeRecord (DataObject *pParent, const std::string &relPath) override
 Write single record to N tuple. More...
 
StatusCode readRecord (NTuple::Tuple *tuple) override
 Read single record from N tuple. More...
 
StatusCode readRecord (const std::string &fullPath) override
 Read single record from N tuple. More...
 
StatusCode readRecord (DataObject *pParent, const std::string &relPath) override
 Read single record from N tuple. More...
 
bool isConnected (const std::string &identifier) const override
 Check if a datasource is connected. More...
 
StatusCode connect (const std::string &ident) override
 Add file to list I/O list. More...
 
StatusCode connect (const std::string &ident, std::string &logname) override
 Add file to list I/O list. More...
 
StatusCode disconnect (const std::string &nam) override
 Close open connection. More...
 
StatusCode disconnectAll () override
 Close all open connections. More...
 
 NTupleSvc (const std::string &name, ISvcLocator *svc)
 Standard Constructor. More...
 
- Public Member Functions inherited from extends< DataSvc, INTupleSvc, IDataSourceMgr >
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 DataSvc
CLID rootCLID () const override
 IDataManagerSvc: Accessor for root event CLID. More...
 
const std::stringrootName () const override
 IDataManagerSvc: Accessor for root event name. More...
 
StatusCode registerAddress (boost::string_ref fullPath, IOpaqueAddress *pAddress) override
 IDataManagerSvc: Register object address with the data store. More...
 
StatusCode registerAddress (IRegistry *parentObj, boost::string_ref objectPath, IOpaqueAddress *pAddress) override
 IDataManagerSvc: Register object address with the data store. More...
 
StatusCode unregisterAddress (boost::string_ref fullPath) override
 IDataManagerSvc: Unregister object address from the data store. More...
 
StatusCode unregisterAddress (IRegistry *pParent, boost::string_ref objPath) override
 IDataManagerSvc: Unregister object address from the data store. More...
 
StatusCode objectLeaves (const DataObject *pObject, std::vector< IRegistry * > &refLeaves) override
 IDataManagerSvc: Explore the object store: retrieve all leaves attached to the object. More...
 
StatusCode objectLeaves (const IRegistry *pRegistry, std::vector< IRegistry * > &refLeaves) override
 IDataManagerSvc: Explore the object store: retrieve all leaves attached to the object. More...
 
StatusCode objectParent (const DataObject *pObject, IRegistry *&refpParent) override
 IDataManagerSvc: Explore the object store: retrieve the object's parent. More...
 
StatusCode objectParent (const IRegistry *pRegistry, IRegistry *&refpParent) override
 IDataManagerSvc: Explore the object store: retrieve the object's parent. More...
 
StatusCode clearSubTree (boost::string_ref sub_tree_path) override
 IDataManagerSvc: Remove all data objects below the sub tree identified by its full path name. More...
 
StatusCode clearSubTree (DataObject *pObject) override
 IDataManagerSvc: Remove all data objects below the sub tree identified by the object. More...
 
StatusCode clearStore () override
 IDataManagerSvc: Remove all data objects in the data store. More...
 
StatusCode traverseSubTree (boost::string_ref sub_tree_path, IDataStoreAgent *pAgent) override
 IDataManagerSvc: Analyze by traversing all data objects below the sub tree identified by its full path name. More...
 
StatusCode traverseSubTree (DataObject *pObject, IDataStoreAgent *pAgent) override
 IDataManagerSvc: Analyze by traversing all data objects below the sub tree. More...
 
StatusCode traverseTree (IDataStoreAgent *pAgent) override
 IDataManagerSvc: Analyze by traversing all data objects in the data store. More...
 
StatusCode setRoot (std::string root_name, DataObject *pRootObj) override
 Initialize data store for new event by giving new event path and root object. More...
 
virtual StatusCode i_setRoot (std::string root_name, DataObject *pRootObj)
 Initialize data store for new event by giving new event path and root object. More...
 
StatusCode setRoot (std::string root_path, IOpaqueAddress *pRootAddr) override
 Initialize data store for new event by giving new event path and address of root object. More...
 
virtual StatusCode i_setRoot (std::string root_path, IOpaqueAddress *pRootAddr)
 Initialize data store for new event by giving new event path and address of root object. More...
 
StatusCode setDataLoader (IConversionSvc *svc, IDataProviderSvc *dpsvc=nullptr) override
 IDataManagerSvc: IDataManagerSvc: Pass a default data loader to the service and optionally a data provider. 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...
 
virtual StatusCode preLoad (int depth, int load_depth, DataObject *pObject)
 Execute one level of preloading and recursively load until the final level is reached. More...
 
StatusCode preLoad () override
 load all preload items of the list More...
 
StatusCode registerObject (boost::string_ref parentPath, boost::string_ref objPath, DataObject *pObject) override
 Register object with the data store. More...
 
StatusCode registerObject (DataObject *parentObj, boost::string_ref objPath, DataObject *pObject) override
 Register object with the data store. More...
 
StatusCode unregisterObject (boost::string_ref fullPath) override
 Unregister object from the data store. More...
 
StatusCode unregisterObject (DataObject *pObject) override
 Unregister object from the data store. More...
 
StatusCode unregisterObject (DataObject *pObject, boost::string_ref objectPath) override
 Unregister object from the data store. More...
 
StatusCode retrieveObject (IRegistry *pDirectory, boost::string_ref path, DataObject *&pObject) override
 Retrieve object from data store. More...
 
StatusCode findObject (boost::string_ref fullPath, DataObject *&pObject) override
 Find object identified by its full path in the data store. More...
 
StatusCode findObject (IRegistry *pDirectory, boost::string_ref path, DataObject *&pObject) override
 Find object identified by its full path in the data store. More...
 
StatusCode linkObject (IRegistry *from, boost::string_ref objPath, DataObject *to) override
 Add a link to another object. More...
 
StatusCode linkObject (boost::string_ref fullPath, DataObject *to) override
 Add a link to another object. More...
 
StatusCode unlinkObject (IRegistry *from, boost::string_ref objPath) override
 Remove a link to another object. More...
 
StatusCode unlinkObject (DataObject *fromObj, boost::string_ref objPath) override
 Remove a link to another object. More...
 
StatusCode unlinkObject (boost::string_ref fullPath) override
 Remove a link to another object. More...
 
StatusCode updateObject (IRegistry *pDirectory) override
 Update object identified by its directory entry. More...
 
StatusCode updateObject (DataObject *toUpdate) override
 Update object. More...
 
StatusCode initialize () override
 Service initialization. More...
 
StatusCode reinitialize () override
 Service initialization. More...
 
StatusCode finalize () override
 Service initialization. More...
 
 DataSvc (const DataSvc &)=delete
 copy constructor disabled More...
 
DataSvcoperator= (const DataSvc &)=delete
 Fake assignment operator (never implemented). More...
 
- Public Member Functions inherited from extends< Service, IDataProviderSvc, IDataManagerSvc >
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::stringDBaseEntries
 
typedef std::pair< std::string, std::stringProp
 

Protected Member Functions

StatusCode createService (const std::string &nam, const std::string &typ, const std::vector< Prop > &props, IConversionSvc *&pSvc)
 Create conversion service. More...
 
void releaseConnection (Connection &c)
 Finalize single service. More...
 
StatusCode attachTuple (const std::string &filename, const std::string &logname, const char typ, const long t)
 Attach output/input file. More...
 
StatusCode updateDirectories ()
 Update directory data. More...
 
- Protected Member Functions inherited from DataSvc
bool checkRoot ()
 Check if root path is valid. More...
 
virtual DataObjectcreateDefaultObject () const
 Create default objects in case forced creation of leaves is requested. More...
 
virtual StatusCode loadObject (IRegistry *pNode)
 Invoke Persistency service to create transient object from its persistent representation. More...
 
virtual StatusCode loadObject (IConversionSvc *pLoader, IRegistry *pNode)
 Invoke Persistency service to create transient object from its persistent representation. More...
 
StatusCode retrieveEntry (DataSvcHelpers::RegistryEntry *pNode, boost::string_ref path, DataSvcHelpers::RegistryEntry *&pEntry)
 Retrieve registry entry from store. More...
 
DataObjecthandleDataFault (IRegistry *pReg, boost::string_ref path="")
 Invoke data fault handling if enabled. More...
 
- 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< DBaseEntriesm_input {this, "Input", {}, "input streams"}
 
Gaudi::Property< DBaseEntriesm_output {this, "Output", {}, "output streams"}
 
std::map< std::string, Connectionm_connections
 Container of connection points. More...
 
- Protected Attributes inherited from DataSvc
SmartIF< IIncidentSvcm_incidentSvc = nullptr
 Pointer to incident service. More...
 
Gaudi::Property< CLIDm_rootCLID {this, "RootCLID", 110 , "CLID of root entry"}
 
Gaudi::Property< std::stringm_rootName {this, "RootName", "/Event", "name of root entry"}
 
std::unique_ptr< DataSvcHelpers::RegistryEntrym_root
 Pointer to root entry. 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, "[[deprecated]] 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< DataSvc, INTupleSvc, IDataSourceMgr >
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 extends< Service, IDataProviderSvc, IDataManagerSvc >
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

NTuple service.

See the Interface definition files for more detailed documentation of the implementing class. Base class: Gaudi/DataSvc/DataSvc.h Generic N tuple service interface: Gaudi/Interfaces/INTupleSvc.h Generic IAddressCreator interface: Gaudi/Interfaces/IAddressCreator.h Generic IConversionSvc interface: Gaudi/Interfaces/IConversionSvc.h

Author
M.Frank

Definition at line 23 of file NTupleSvc.h.

Member Typedef Documentation

Definition at line 31 of file NTupleSvc.h.

Definition at line 32 of file NTupleSvc.h.

Constructor & Destructor Documentation

NTupleSvc::NTupleSvc ( const std::string name,
ISvcLocator svc 
)

Standard Constructor.

Definition at line 51 of file NTupleSvc.cpp.

51  : base_class( name, svc )
52 {
53  m_rootName = "/NTUPLES";
54  m_rootCLID = CLID_DataObject;
55 }
Gaudi::Property< CLID > m_rootCLID
Definition: DataSvc.h:53
Gaudi::Property< std::string > m_rootName
Definition: DataSvc.h:54
extends base_class
Typedef to this class.
Definition: extends.h:15

Member Function Documentation

NTuple::Tuple * NTupleSvc::access ( const std::string fullPath,
const std::string filename 
)
override

Access N tuple on disk.

Definition at line 512 of file NTupleSvc.cpp.

512 { return nullptr; }
StatusCode NTupleSvc::attachTuple ( const std::string filename,
const std::string logname,
const char  typ,
const long  t 
)
protected

Attach output/input file.

Definition at line 452 of file NTupleSvc.cpp.

454 {
455  DataObject* p;
456  // First get the root object
457  StatusCode status = retrieveObject( m_rootName.value(), p );
458  if ( status.isSuccess() ) {
459  // Now add the registry entry to the store
460  std::string entryname = m_rootName;
461  entryname += '/';
462  entryname += logname;
463  GenericAddress* pA = new GenericAddress( t, CLID_NTupleFile, filename, entryname, 0, typ );
464  status = registerAddress( p, logname, pA );
465  if ( status.isSuccess() ) {
466  info() << "Added stream file:" << filename << " as " << logname << endmsg;
467  return status;
468  }
469  pA->release();
470  }
471  error() << "Cannot add file:" << filename << " as " << logname << endmsg;
472  return status;
473 }
StatusCode registerAddress(boost::string_ref fullPath, IOpaqueAddress *pAddress) override
IDataManagerSvc: Register object address with the data store.
Definition: DataSvc.cpp:235
MsgStream & info() const
shortcut for the method msgStream(MSG::INFO)
bool isSuccess() const
Definition: StatusCode.h:287
unsigned long release() override
release reference to object
Gaudi::Property< std::string > m_rootName
Definition: DataSvc.h:54
Generic Transient Address.
STL class.
MsgStream & error() const
shortcut for the method msgStream(MSG::ERROR)
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:51
StatusCode retrieveObject(IRegistry *pDirectory, boost::string_ref path, DataObject *&pObject) override
Retrieve object from data store.
Definition: DataSvc.cpp:679
A DataObject is the base class of any identifiable object on any data store.
Definition: DataObject.h:30
MsgStream & endmsg(MsgStream &s)
MsgStream Modifier: endmsg. Calls the output method of the MsgStream.
Definition: MsgStream.h:209
NTuple::Tuple * NTupleSvc::book ( const std::string fullPath,
const CLID type,
const std::string title 
)
override

Book Ntuple and register it with the data store.

Definition at line 335 of file NTupleSvc.cpp.

336 {
337  DataObject* pObj = nullptr;
338  std::string path = fullPath;
339  assert( !path.empty() );
340  if ( path[0] != SEPARATOR ) {
341  path = m_rootName;
342  path += SEPARATOR;
343  path += fullPath;
344  }
345  StatusCode status = retrieveObject( path, pObj );
346  if ( status.isSuccess() ) {
347  error() << "Cannot book N-tuple " << path << " (Exists already)" << endmsg;
348  return nullptr;
349  }
350  auto sep = path.rfind( SEPARATOR );
351  if ( sep == std::string::npos ) {
352  error() << "Cannot book N-tuple " << path << " (Invalid path)" << endmsg;
353  return nullptr;
354  }
355 
356  std::string p_path( path, 0, sep );
357  std::string o_path( path, sep, path.length() );
358  DataObject* dir = createDirectory( p_path );
359  if ( !dir ) {
360  error() << "Cannot book N-tuple " << path << " (Invalid parent directory)" << endmsg;
361  return nullptr;
362  }
363 
364  NTuple::Tuple* tup = book( dir, o_path, type, title );
365  if ( !tup ) {
366  error() << "Cannot book N-tuple " << path << " (Unknown reason)" << endmsg;
367  }
368  return tup;
369 }
T empty(T...args)
constexpr char SEPARATOR
bool isSuccess() const
Definition: StatusCode.h:287
T rfind(T...args)
Gaudi::Property< std::string > m_rootName
Definition: DataSvc.h:54
NTuple::Tuple * book(const std::string &fullPath, const CLID &type, const std::string &title) override
Book Ntuple and register it with the data store.
Definition: NTupleSvc.cpp:335
STL class.
MsgStream & error() const
shortcut for the method msgStream(MSG::ERROR)
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:51
NTuple::Directory * createDirectory(DataObject *pParent, const std::string &title) override
Create Ntuple directory and register it with the data store.
Definition: NTupleSvc.cpp:415
Abstract base class which allows the user to interact with the actual N tuple implementation.
Definition: NTuple.h:407
T length(T...args)
StatusCode retrieveObject(IRegistry *pDirectory, boost::string_ref path, DataObject *&pObject) override
Retrieve object from data store.
Definition: DataSvc.cpp:679
A DataObject is the base class of any identifiable object on any data store.
Definition: DataObject.h:30
MsgStream & endmsg(MsgStream &s)
MsgStream Modifier: endmsg. Calls the output method of the MsgStream.
Definition: MsgStream.h:209
NTuple::Tuple * NTupleSvc::book ( const std::string dirPath,
const std::string relPath,
const CLID type,
const std::string title 
)
override

Book Ntuple and register it with the data store.

Definition at line 372 of file NTupleSvc.cpp.

374 {
375  std::string full = dirPath;
376  assert( !relPath.empty() );
377  if ( relPath[0] != SEPARATOR ) full += SEPARATOR;
378  full += relPath;
379  return book( full, type, title );
380 }
T empty(T...args)
constexpr char SEPARATOR
NTuple::Tuple * book(const std::string &fullPath, const CLID &type, const std::string &title) override
Book Ntuple and register it with the data store.
Definition: NTupleSvc.cpp:335
STL class.
NTuple::Tuple * NTupleSvc::book ( const std::string dirPath,
long  id,
const CLID type,
const std::string title 
)
override

Book Ntuple and register it with the data store.

Definition at line 383 of file NTupleSvc.cpp.

384 {
385  return book( dirPath, std::to_string( id ), type, title );
386 }
T to_string(T...args)
NTuple::Tuple * book(const std::string &fullPath, const CLID &type, const std::string &title) override
Book Ntuple and register it with the data store.
Definition: NTupleSvc.cpp:335
NTuple::Tuple * NTupleSvc::book ( DataObject pParent,
const std::string relPath,
const CLID type,
const std::string title 
)
override

Book Ntuple and register it with the data store.

Definition at line 389 of file NTupleSvc.cpp.

391 {
392  NTuple::Tuple* pObj = nullptr;
393  // Check if object is already present
394  StatusCode status = findObject( pParent, relPath, *pp_cast<DataObject>( &pObj ) );
395  // No ? Then create it!
396  if ( !status.isSuccess() ) {
397  status = create( type, title, pObj );
398  if ( status.isSuccess() ) {
399  // Finally register the created N tuple with the store
400  status = registerObject( pParent, relPath, pObj );
401  if ( status.isSuccess() ) return pObj;
402  pObj->release();
403  }
404  }
405  return nullptr;
406 }
bool isSuccess() const
Definition: StatusCode.h:287
StatusCode registerObject(boost::string_ref parentPath, boost::string_ref objPath, DataObject *pObject) override
Register object with the data store.
Definition: DataSvc.cpp:323
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:51
Abstract base class which allows the user to interact with the actual N tuple implementation.
Definition: NTuple.h:407
virtual unsigned long release()
release reference to object
Definition: DataObject.cpp:51
StatusCode create(const CLID &typ, const std::string &title, NTuple::Tuple *&refpTuple) override
Create requested N tuple (Hide constructor)
Definition: NTupleSvc.cpp:315
StatusCode findObject(boost::string_ref fullPath, DataObject *&pObject) override
Find object identified by its full path in the data store.
Definition: DataSvc.cpp:703
NTuple::Tuple * NTupleSvc::book ( DataObject pParent,
long  id,
const CLID type,
const std::string title 
)
override

Book Ntuple and register it with the data store.

Definition at line 409 of file NTupleSvc.cpp.

410 {
411  return book( pParent, std::to_string( id ), type, title );
412 }
T to_string(T...args)
NTuple::Tuple * book(const std::string &fullPath, const CLID &type, const std::string &title) override
Book Ntuple and register it with the data store.
Definition: NTupleSvc.cpp:335
StatusCode NTupleSvc::connect ( const std::string ident)
override

Add file to list I/O list.

Definition at line 191 of file NTupleSvc.cpp.

192 {
193  std::string logName;
194  return connect( ident, logName );
195 }
STL class.
StatusCode connect(const std::string &ident) override
Add file to list I/O list.
Definition: NTupleSvc.cpp:191
StatusCode NTupleSvc::connect ( const std::string ident,
std::string logname 
)
override

Add file to list I/O list.

Definition at line 197 of file NTupleSvc.cpp.

198 {
199  DataObject* pO = nullptr;
200  StatusCode status = findObject( m_rootName.value(), pO );
201  if ( status.isSuccess() ) {
202  char typ = 0;
203  std::vector<Prop> props;
204  long loc = ident.find( " " );
205  std::string filename, auth, svc = "", db_typ = "";
206  logname = ident.substr( 0, loc );
207  using Parser = Gaudi::Utils::AttribStringParser;
208  // we assume that there is always a " "
209  // (but if it is not there, we probably will not match the pattern)
210  for ( auto attrib : Parser( ident.substr( loc + 1 ) ) ) {
211  switch (::toupper( attrib.tag[0] ) ) {
212  case 'A':
213  break;
214  case 'F': // FILE='<file name>'
215  case 'D': // DATAFILE='<file name>'
216  filename = std::move( attrib.value );
217  break;
218  case 'O': // OPT='<NEW<CREATE,WRITE>, UPDATE, READ>'
219  switch (::toupper( attrib.value[0] ) ) {
220  case 'C':
221  case 'N':
222  case 'W':
223  typ = 'N';
224  break;
225  case 'U':
226  typ = 'U';
227  break;
228  case 'O':
229  case 'R':
230  typ = 'O';
231  break;
232  default:
233  typ = 0;
234  break;
235  }
236  break;
237  case 'T': // TYP='<HBOOK,ROOT,OBJY,...>'
238  db_typ = std::move( attrib.value );
239  break;
240  default:
241  props.emplace_back( attrib.tag, attrib.value );
242  break;
243  }
244  }
245  if ( 0 != typ ) {
246  IConversionSvc* pSvc = nullptr;
247  status = createService( name() + '.' + logname, db_typ, props, pSvc );
248  if ( status.isSuccess() ) {
249  status = attachTuple( filename, logname, typ, pSvc->repSvcType() );
250  if ( status.isSuccess() ) {
251  m_connections.insert( {m_rootName + '/' + logname, Connection( pSvc )} );
252  return StatusCode::SUCCESS;
253  }
254  }
255  }
256  }
257  error() << "Cannot add " << ident << " invalid filename!" << endmsg;
258  return StatusCode::FAILURE;
259 }
Parse attribute strings allowing iteration over the various attributes.
constexpr static const auto FAILURE
Definition: StatusCode.h:88
const std::string & name() const override
Retrieve name of the service.
Definition: Service.cpp:288
bool isSuccess() const
Definition: StatusCode.h:287
Gaudi::Property< std::string > m_rootName
Definition: DataSvc.h:54
std::map< std::string, Connection > m_connections
Container of connection points.
Definition: NTupleSvc.h:119
StatusCode createService(const std::string &nam, const std::string &typ, const std::vector< Prop > &props, IConversionSvc *&pSvc)
Create conversion service.
Definition: NTupleSvc.cpp:261
STL class.
MsgStream & error() const
shortcut for the method msgStream(MSG::ERROR)
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:51
T move(T...args)
constexpr static const auto SUCCESS
Definition: StatusCode.h:87
T find(T...args)
STL class.
virtual long repSvcType() const =0
Retrieve the class type of the data store the converter uses.
T substr(T...args)
StatusCode attachTuple(const std::string &filename, const std::string &logname, const char typ, const long t)
Attach output/input file.
Definition: NTupleSvc.cpp:452
A DataObject is the base class of any identifiable object on any data store.
Definition: DataObject.h:30
StatusCode findObject(boost::string_ref fullPath, DataObject *&pObject) override
Find object identified by its full path in the data store.
Definition: DataSvc.cpp:703
void toupper(std::string &s)
MsgStream & endmsg(MsgStream &s)
MsgStream Modifier: endmsg. Calls the output method of the MsgStream.
Definition: MsgStream.h:209
T emplace_back(T...args)
StatusCode NTupleSvc::create ( const CLID typ,
const std::string title,
NTuple::Tuple *&  refpTuple 
)
override

Create requested N tuple (Hide constructor)

Eventually allow loading through factory?

Definition at line 315 of file NTupleSvc.cpp.

316 {
317  NTuple::TupleImp* pTuple = nullptr;
319  if ( typ == CLID_ColumnWiseTuple ) {
320  pTuple = new NTuple::ColumnWiseTuple( title );
321  } else if ( typ == CLID_RowWiseTuple ) {
322  pTuple = new NTuple::RowWiseTuple( title );
323  } else {
325  }
326  if ( pTuple ) {
327  pTuple->setTupleService( this );
328  status = StatusCode::SUCCESS;
329  }
330  refpTuple = pTuple;
331  return status;
332 }
constexpr static const auto FAILURE
Definition: StatusCode.h:88
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:51
constexpr static const auto SUCCESS
Definition: StatusCode.h:87
void setTupleService(INTupleSvc *svc)
Access conversion service.
NTuple::Directory * NTupleSvc::createDirectory ( DataObject pParent,
const std::string title 
)
override

Create Ntuple directory and register it with the data store.

Definition at line 415 of file NTupleSvc.cpp.

416 {
417  assert( !relPath.empty() );
418  if ( pParent ) {
419  IRegistry* pDir = pParent->registry();
420  if ( pDir ) {
421  std::string full = pDir->identifier();
422  if ( relPath[0] != '/' ) full += "/";
423  full += relPath;
424  return createDirectory( full );
425  }
426  }
427  return nullptr;
428 }
IRegistry * registry() const
Get pointer to Registry.
Definition: DataObject.h:73
STL class.
virtual const id_type & identifier() const =0
Full identifier (or key)
NTuple::Directory * createDirectory(DataObject *pParent, const std::string &title) override
Create Ntuple directory and register it with the data store.
Definition: NTupleSvc.cpp:415
The IRegistry represents the entry door to the environment any data object residing in a transient da...
Definition: IRegistry.h:22
NTuple::Directory * NTupleSvc::createDirectory ( DataObject pParent,
long  id 
)
override

Create Ntuple directory and register it with the data store.

Definition at line 431 of file NTupleSvc.cpp.

432 {
433  return createDirectory( pParent, std::to_string( id ) );
434 }
T to_string(T...args)
NTuple::Directory * createDirectory(DataObject *pParent, const std::string &title) override
Create Ntuple directory and register it with the data store.
Definition: NTupleSvc.cpp:415
NTuple::Directory * NTupleSvc::createDirectory ( const std::string dirPath,
long  id 
)
override

Create Ntuple directory and register it with the data store.

Definition at line 437 of file NTupleSvc.cpp.

438 {
439  return createDirectory( dirPath, std::to_string( id ) );
440 }
T to_string(T...args)
NTuple::Directory * createDirectory(DataObject *pParent, const std::string &title) override
Create Ntuple directory and register it with the data store.
Definition: NTupleSvc.cpp:415
NTuple::Directory * NTupleSvc::createDirectory ( const std::string dirPath,
const std::string title 
)
override

Create Ntuple directory and register it with the data store.

Definition at line 443 of file NTupleSvc.cpp.

444 {
445  assert( !relPath.empty() );
446  std::string full = dirPath;
447  if ( relPath[0] != '/' ) full += "/";
448  full += relPath;
449  return createDirectory( full );
450 }
STL class.
NTuple::Directory * createDirectory(DataObject *pParent, const std::string &title) override
Create Ntuple directory and register it with the data store.
Definition: NTupleSvc.cpp:415
NTuple::Directory * NTupleSvc::createDirectory ( const std::string fullPath)
override

Create Ntuple directory and register it with the data store.

Definition at line 476 of file NTupleSvc.cpp.

477 {
478  NTuple::Directory* p = nullptr;
479  StatusCode status = findObject( fullPath, *pp_cast<DataObject>( &p ) );
480  if ( !status.isSuccess() ) {
481  auto sep2 = fullPath.rfind( SEPARATOR );
482  if ( sep2 != std::string::npos ) {
483  std::string relPath = fullPath.substr( 0, sep2 );
484  p = createDirectory( relPath );
485  if ( p ) {
486  p = new NTuple::Directory();
487  // Finally register the created N tuple with the store
488  status = registerObject( fullPath, p );
489  if ( status.isSuccess() ) {
490  // ...starting from the file entries
491  IConversionSvc* svc = getDataLoader( p->registry() );
492  if ( svc ) {
493  IOpaqueAddress* pAddr = nullptr;
494  status = svc->createRep( p, pAddr );
495  if ( status.isSuccess() ) {
496  p->registry()->setAddress( pAddr );
497  status = svc->fillRepRefs( pAddr, p );
498  if ( status.isSuccess() ) return p;
499  }
500  }
501  unregisterObject( p );
502  }
503  p->release();
504  p = nullptr;
505  }
506  }
507  }
508  return dynamic_cast<NTuple::Directory*>( p );
509 }
StatusCode unregisterObject(boost::string_ref fullPath) override
Unregister object from the data store.
Definition: DataSvc.cpp:407
constexpr char SEPARATOR
bool isSuccess() const
Definition: StatusCode.h:287
T rfind(T...args)
virtual StatusCode createRep(DataObject *pObject, IOpaqueAddress *&refpAddress)=0
Convert the transient object to the requested representation.
StatusCode registerObject(boost::string_ref parentPath, boost::string_ref objPath, DataObject *pObject) override
Register object with the data store.
Definition: DataSvc.cpp:323
IRegistry * registry() const
Get pointer to Registry.
Definition: DataObject.h:73
STL class.
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:51
NTuple::Directory * createDirectory(DataObject *pParent, const std::string &title) override
Create Ntuple directory and register it with the data store.
Definition: NTupleSvc.cpp:415
virtual unsigned long release()
release reference to object
Definition: DataObject.cpp:51
IConversionSvc * getDataLoader(IRegistry *pReg) override
DataSvc overrides: Retrieve data loader.
Definition: NTupleSvc.cpp:91
virtual void setAddress(IOpaqueAddress *pAddress)=0
Set/Update Opaque storage address.
T substr(T...args)
Small class representing an N tuple directory in the transient store.
Definition: NTuple.h:978
Opaque address interface definition.
virtual StatusCode fillRepRefs(IOpaqueAddress *pAddress, DataObject *pObject)=0
Resolve the references of the converted object.
StatusCode findObject(boost::string_ref fullPath, DataObject *&pObject) override
Find object identified by its full path in the data store.
Definition: DataSvc.cpp:703
StatusCode NTupleSvc::createService ( const std::string nam,
const std::string typ,
const std::vector< Prop > &  props,
IConversionSvc *&  pSvc 
)
protected

Create conversion service.

CGL: set the storage type

Definition at line 261 of file NTupleSvc.cpp.

263 {
265  // Get the value of the Stat persistancy mechanism from the AppMgr
266  auto appPropMgr = serviceLocator()->as<IProperty>();
267  if ( !appPropMgr ) {
268  // Report an error and return the FAILURE status code
269  error() << "Could not get PropMgr" << endmsg;
270  return StatusCode::FAILURE;
271  }
272 
273  Gaudi::Property<std::string> sp( "HistogramPersistency", "" );
274  StatusCode sts = appPropMgr->getProperty( &sp );
275  if ( !sts.isSuccess() ) {
276  error() << "Could not get NTuple Persistency format"
277  << " from ApplicationMgr properties" << endmsg;
278  return sts;
279  }
280 
281  long storage_typ = TEST_StorageType;
282  if ( sp.value() == "HBOOK" ) {
283  storage_typ = HBOOK_StorageType;
284  } else if ( sp.value() == "ROOT" ) {
285  storage_typ = ROOT_StorageType;
286  } else {
287  error() << "Unknown NTuple Persistency format: " << sp.value() << endmsg;
288  return StatusCode::FAILURE;
289  }
290 
291  if ( !typ.empty() && typ != sp.value() ) {
292  warning() << "NTuple persistency type is " << sp.value() << "." << endmsg << "Type given by job option "
293  << "NTupleSvc.Input/Output ignored!" << endmsg;
294  }
295 
296  // debug() << "storage type: " << m_storageType << endmsg;
297 
298  // FIXME: (MCl) why NTupleSvc has to directly create a ConversionSvc?
299  IInterface* iface = new ConversionSvc( name() + "Conversions", serviceLocator(), storage_typ );
300  auto pService = SmartIF<IService>( iface );
301  if ( !pService ) return StatusCode::FAILURE;
302 
303  auto cnvSvc = pService.as<IConversionSvc>();
304  if ( !cnvSvc ) return StatusCode::FAILURE;
305 
306  pSvc = cnvSvc.get();
307  pSvc->addRef(); // make sure the caller gets a pSvc which points at something
308  // with a refCount of (at least) one...
309  auto status = pService->sysInitialize();
310  if ( !status.isSuccess() ) return status;
311  return pSvc->setDataProvider( this );
312 }
const long TEST_StorageType
Definition: ClassID.h:49
constexpr static const auto FAILURE
Definition: StatusCode.h:88
T empty(T...args)
const long HBOOK_StorageType
Definition: ClassID.h:56
const std::string & name() const override
Retrieve name of the service.
Definition: Service.cpp:288
Implementation of property with value of concrete type.
Definition: Property.h:383
bool isSuccess() const
Definition: StatusCode.h:287
virtual StatusCode setDataProvider(IDataProviderSvc *pService)=0
Set Data provider service.
SmartIF< IFace > as()
Definition: ISvcLocator.h:109
MsgStream & error() const
shortcut for the method msgStream(MSG::ERROR)
MsgStream & warning() const
shortcut for the method msgStream(MSG::WARNING)
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:51
Definition of the basic interface.
Definition: IInterface.h:277
const long ROOT_StorageType
Definition: ClassID.h:52
virtual unsigned long addRef()=0
Increment the reference count of Interface instance.
Base class for all conversion services.
Definition: ConversionSvc.h:45
The IProperty is the basic interface for all components which have properties that can be set or get...
Definition: IProperty.h:20
SmartIF< ISvcLocator > & serviceLocator() const override
Retrieve pointer to service locator.
Definition: Service.cpp:291
MsgStream & endmsg(MsgStream &s)
MsgStream Modifier: endmsg. Calls the output method of the MsgStream.
Definition: MsgStream.h:209
StatusCode NTupleSvc::disconnect ( const std::string nam)
override

Close open connection.

Definition at line 164 of file NTupleSvc.cpp.

165 {
166  auto i = m_connections.find( nam );
167  if ( i == m_connections.end() ) return StatusCode::FAILURE;
168  releaseConnection( i->second );
169  m_connections.erase( i );
170  return StatusCode::SUCCESS;
171 }
void releaseConnection(Connection &c)
Finalize single service.
Definition: NTupleSvc.cpp:155
constexpr static const auto FAILURE
Definition: StatusCode.h:88
std::map< std::string, Connection > m_connections
Container of connection points.
Definition: NTupleSvc.h:119
constexpr static const auto SUCCESS
Definition: StatusCode.h:87
StatusCode NTupleSvc::disconnectAll ( )
override

Close all open connections.

Definition at line 174 of file NTupleSvc.cpp.

175 {
176  for ( auto& i : m_connections ) releaseConnection( i.second );
177  m_connections.clear();
178  return StatusCode::SUCCESS;
179 }
void releaseConnection(Connection &c)
Finalize single service.
Definition: NTupleSvc.cpp:155
std::map< std::string, Connection > m_connections
Container of connection points.
Definition: NTupleSvc.h:119
constexpr static const auto SUCCESS
Definition: StatusCode.h:87
StatusCode NTupleSvc::finalize ( )
override

DataSvc overrides: stop the service.

stop the service.

Definition at line 182 of file NTupleSvc.cpp.

183 {
184  StatusCode status = updateDirectories();
185  status = clearStore();
186  status = DataSvc::finalize();
187  status = disconnectAll();
188  return status;
189 }
StatusCode updateDirectories()
Update directory data.
Definition: NTupleSvc.cpp:102
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:51
StatusCode finalize() override
Service initialization.
Definition: DataSvc.cpp:937
StatusCode disconnectAll() override
Close all open connections.
Definition: NTupleSvc.cpp:174
StatusCode clearStore() override
IDataManagerSvc: Remove all data objects in the data store.
Definition: DataSvc.cpp:108
IConversionSvc * NTupleSvc::getDataLoader ( IRegistry pReg)
overridevirtual

DataSvc overrides: Retrieve data loader.

DataSvc override: Retrieve data loader.

Reimplemented from DataSvc.

Definition at line 91 of file NTupleSvc.cpp.

92 {
93  if ( !pRegistry ) return nullptr;
94  std::string full = pRegistry->identifier();
95  auto len = m_rootName.length();
96  auto idx = full.find( SEPARATOR, len + 1 );
97  std::string path = ( idx == std::string::npos ) ? full : full.substr( 0, idx );
98  auto i = m_connections.find( path );
99  return ( i != m_connections.end() ) ? i->second.service : nullptr;
100 }
constexpr char SEPARATOR
Gaudi::Property< std::string > m_rootName
Definition: DataSvc.h:54
std::map< std::string, Connection > m_connections
Container of connection points.
Definition: NTupleSvc.h:119
STL class.
T find(T...args)
T substr(T...args)
StatusCode NTupleSvc::initialize ( )
override

DataSvc overrides: Initialize the service.

Definition at line 58 of file NTupleSvc.cpp.

59 {
61  if ( status.isSuccess() ) {
62  status = setProperties();
63  if ( status.isSuccess() ) {
64  StatusCode iret( StatusCode::SUCCESS, true );
66  status = setRoot( m_rootName, root );
67  for ( auto& i : m_output ) {
68  iret = connect( i );
69  if ( !iret.isSuccess() ) status = iret;
70  }
71  for ( auto& j : m_input ) {
72  iret = connect( j );
73  if ( !iret.isSuccess() ) status = iret;
74  }
75  }
76  }
77  return status;
78 }
bool isSuccess() const
Definition: StatusCode.h:287
StatusCode setRoot(std::string root_name, DataObject *pRootObj) override
Initialize data store for new event by giving new event path and root object.
Definition: DataSvc.cpp:143
Gaudi::Property< std::string > m_rootName
Definition: DataSvc.h:54
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:51
Gaudi::Property< DBaseEntries > m_output
Definition: NTupleSvc.h:116
StatusCode setProperties()
Method for setting declared properties to the values specified for the job.
Definition: Service.cpp:294
constexpr static const auto SUCCESS
Definition: StatusCode.h:87
StatusCode initialize() override
Service initialization.
Definition: DataSvc.cpp:900
Gaudi::Property< DBaseEntries > m_input
Definition: NTupleSvc.h:115
StatusCode connect(const std::string &ident) override
Add file to list I/O list.
Definition: NTupleSvc.cpp:191
Small class representing an N tuple directory in the transient store.
Definition: NTuple.h:978
A DataObject is the base class of any identifiable object on any data store.
Definition: DataObject.h:30
bool NTupleSvc::isConnected ( const std::string identifier) const
override

Check if a datasource is connected.

Definition at line 84 of file NTupleSvc.cpp.

85 {
86  auto i = m_connections.find( identifier );
87  return i != m_connections.end();
88 }
std::map< std::string, Connection > m_connections
Container of connection points.
Definition: NTupleSvc.h:119
StatusCode NTupleSvc::readRecord ( NTuple::Tuple tuple)
override

Read single record from N tuple.

Definition at line 596 of file NTupleSvc.cpp.

597 {
598  StatusCode status = Status::INVALID_OBJECT;
599  NTuple::TupleImp* tuple = (NTuple::TupleImp*)n_tuple;
600  if ( tuple ) {
601  try {
602  IConversionSvc* pSvc = tuple->conversionService();
603  if ( !pSvc ) {
604  pSvc = getDataLoader( n_tuple->registry() );
605  tuple->setConversionService( pSvc );
606  }
607  if ( pSvc ) {
608  IRegistry* pReg = n_tuple->registry();
609  IOpaqueAddress* pAddr = pReg->address();
610  status = pSvc->updateObj( pAddr, n_tuple );
611  if ( status.isSuccess() ) {
612  status = pSvc->updateObjRefs( pAddr, n_tuple );
613  }
614  return status;
615  }
616  status = Status::NO_DATA_LOADER;
617  } catch ( ... ) {
618  status = Status::INVALID_OBJECT;
619  }
620  }
621  return status;
622 }
bool isSuccess() const
Definition: StatusCode.h:287
virtual StatusCode updateObj(IOpaqueAddress *pAddress, DataObject *refpObject)=0
Update the transient object from the other representation.
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:51
virtual StatusCode updateObjRefs(IOpaqueAddress *pAddress, DataObject *pObject)=0
Update the references of an updated transient object.
The IRegistry represents the entry door to the environment any data object residing in a transient da...
Definition: IRegistry.h:22
IConversionSvc * getDataLoader(IRegistry *pReg) override
DataSvc overrides: Retrieve data loader.
Definition: NTupleSvc.cpp:91
void setConversionService(IConversionSvc *svc)
Access conversion service.
Opaque address interface definition.
virtual IOpaqueAddress * address() const =0
Retrieve opaque storage address.
IConversionSvc * conversionService() const
Access conversion service.
StatusCode NTupleSvc::readRecord ( const std::string fullPath)
override

Read single record from N tuple.

Definition at line 625 of file NTupleSvc.cpp.

626 {
627  NTuple::Tuple* pObj = nullptr;
628  StatusCode status = findObject( fullPath, *pp_cast<DataObject>( &pObj ) ); // Check if object is present
629  return status.isSuccess() ? readRecord( pObj ) : Status::INVALID_OBJ_PATH;
630 }
bool isSuccess() const
Definition: StatusCode.h:287
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:51
StatusCode readRecord(NTuple::Tuple *tuple) override
Read single record from N tuple.
Definition: NTupleSvc.cpp:596
Abstract base class which allows the user to interact with the actual N tuple implementation.
Definition: NTuple.h:407
StatusCode findObject(boost::string_ref fullPath, DataObject *&pObject) override
Find object identified by its full path in the data store.
Definition: DataSvc.cpp:703
StatusCode NTupleSvc::readRecord ( DataObject pParent,
const std::string relPath 
)
override

Read single record from N tuple.

Definition at line 633 of file NTupleSvc.cpp.

634 {
635  NTuple::Tuple* pObj = nullptr;
636  StatusCode status = findObject( pParent, relPath, *pp_cast<DataObject>( &pObj ) ); // Check if object is present
637  return status.isSuccess() ? readRecord( pObj ) : Status::INVALID_OBJ_PATH;
638 }
bool isSuccess() const
Definition: StatusCode.h:287
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:51
StatusCode readRecord(NTuple::Tuple *tuple) override
Read single record from N tuple.
Definition: NTupleSvc.cpp:596
Abstract base class which allows the user to interact with the actual N tuple implementation.
Definition: NTuple.h:407
StatusCode findObject(boost::string_ref fullPath, DataObject *&pObject) override
Find object identified by its full path in the data store.
Definition: DataSvc.cpp:703
StatusCode NTupleSvc::reinitialize ( )
override

DataSvc overrides: reinitialize service.

Initialize the service.

Definition at line 81 of file NTupleSvc.cpp.

81 { return StatusCode::SUCCESS; }
constexpr static const auto SUCCESS
Definition: StatusCode.h:87
void NTupleSvc::releaseConnection ( Connection c)
protected

Finalize single service.

Definition at line 155 of file NTupleSvc.cpp.

156 {
157  SmartIF<IService> isvc( c.service );
158  if ( isvc ) isvc->finalize().ignore();
159  c.service->release();
160  c.service = nullptr;
161 }
StatusCode NTupleSvc::save ( const std::string fullPath)
override

Save N tuple to disk. Must be called in order to close the ntuple file properly.

Definition at line 515 of file NTupleSvc.cpp.

516 {
517  NTuple::Tuple* pObj = nullptr;
518  StatusCode status = findObject( fullPath, *pp_cast<DataObject>( &pObj ) ); // Check if object is present
519  return status.isSuccess() ? save( pObj ) : Status::INVALID_OBJ_PATH;
520 }
bool isSuccess() const
Definition: StatusCode.h:287
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:51
Abstract base class which allows the user to interact with the actual N tuple implementation.
Definition: NTuple.h:407
StatusCode save(const std::string &fullPath) override
Save N tuple to disk. Must be called in order to close the ntuple file properly.
Definition: NTupleSvc.cpp:515
StatusCode findObject(boost::string_ref fullPath, DataObject *&pObject) override
Find object identified by its full path in the data store.
Definition: DataSvc.cpp:703
StatusCode NTupleSvc::save ( NTuple::Tuple tuple)
override

Save N tuple to disk. Must be called in order to close the ntuple file properly.

Definition at line 523 of file NTupleSvc.cpp.

524 {
525  NTuple::TupleImp* tuple = (NTuple::TupleImp*)n_tuple;
526  if ( tuple ) {
527  try {
528  IConversionSvc* pSvc = tuple->conversionService();
529  IRegistry* pReg = tuple->registry();
530  if ( pSvc && pReg ) {
531  IOpaqueAddress* pAddr = pReg->address();
532  StatusCode sc = pSvc->updateRep( pAddr, n_tuple );
533  if ( sc.isSuccess() ) sc = pSvc->updateRepRefs( pAddr, n_tuple );
534  return sc;
535  }
536  return Status::NO_DATA_LOADER;
537  } catch ( ... ) {
538  }
539  }
540  return Status::INVALID_OBJECT;
541 }
bool isSuccess() const
Definition: StatusCode.h:287
virtual StatusCode updateRepRefs(IOpaqueAddress *pAddress, DataObject *pObject)=0
Update the references of an already converted object.
IRegistry * registry() const
Get pointer to Registry.
Definition: DataObject.h:73
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:51
The IRegistry represents the entry door to the environment any data object residing in a transient da...
Definition: IRegistry.h:22
virtual StatusCode updateRep(IOpaqueAddress *pAddress, DataObject *pObject)=0
Update the converted representation of a transient object.
Opaque address interface definition.
virtual IOpaqueAddress * address() const =0
Retrieve opaque storage address.
IConversionSvc * conversionService() const
Access conversion service.
StatusCode NTupleSvc::save ( DataObject pParent,
const std::string relPath 
)
override

Save N tuple to disk. Must be called in order to close the ntuple file properly.

Definition at line 544 of file NTupleSvc.cpp.

545 {
546  NTuple::Tuple* pObj = nullptr;
547  StatusCode status = findObject( pParent, relPath, *pp_cast<DataObject>( &pObj ) ); // Check if object is present
548  return status.isSuccess() ? save( pObj ) : Status::INVALID_OBJ_PATH;
549 }
bool isSuccess() const
Definition: StatusCode.h:287
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:51
Abstract base class which allows the user to interact with the actual N tuple implementation.
Definition: NTuple.h:407
StatusCode save(const std::string &fullPath) override
Save N tuple to disk. Must be called in order to close the ntuple file properly.
Definition: NTupleSvc.cpp:515
StatusCode findObject(boost::string_ref fullPath, DataObject *&pObject) override
Find object identified by its full path in the data store.
Definition: DataSvc.cpp:703
StatusCode NTupleSvc::updateDirectories ( )
protected

Update directory data.

Definition at line 102 of file NTupleSvc.cpp.

103 {
104  long need_update = 0;
105  DataObject* pO = nullptr;
106  StatusCode iret = findObject( m_rootName.value(), pO );
107  // debug() << "in finalize()" << endmsg;
108  if ( iret.isSuccess() ) {
110  iret = objectLeaves( pO, leaves );
111  if ( iret.isSuccess() ) {
112  // Only traverse the tree below the files
113  for ( auto d = leaves.begin(); d != leaves.end(); d++ ) {
114  if ( !( *d )->object() ) continue;
115  IOpaqueAddress* pA = ( *d )->address();
116  if ( !pA ) continue;
117  unsigned long typ = pA->ipar()[1];
118  if ( typ != 'R' && typ != 'N' && typ != 'U' ) continue;
119  // ...starting from the file entries: first save the directories/ntuples
120  IConversionSvc* svc = getDataLoader( *d );
121  if ( !svc ) continue;
122 
124  IDataManagerSvc::traverseSubTree( ( *d )->object(), [&sel]( IRegistry* r, int ) {
125  DataObject* obj = r->object();
126  if ( obj ) sel.push_back( obj );
127  return true;
128  } ).ignore();
129  for ( DataObject* o : reverse( sel ) ) {
130  IRegistry* r = o->registry();
131  auto status = svc->updateRep( r->address(), o );
132  if ( !status.isSuccess() ) iret = status;
133  }
134  for ( DataObject* o : reverse( sel ) ) {
135  IRegistry* r = o->registry();
136  auto status = svc->updateRepRefs( r->address(), o );
137  if ( !status.isSuccess() ) iret = status;
138  }
139 
140  if ( iret.isSuccess() ) need_update += sel.size();
141  }
142  }
143  }
144  if ( !iret.isSuccess() ) {
145  error() << "ERROR while saving NTuples" << endmsg;
146  return iret;
147  }
148  if ( need_update > 0 ) {
149  info() << "NTuples saved successfully" << endmsg;
150  }
151  return iret;
152 }
MsgStream & info() const
shortcut for the method msgStream(MSG::INFO)
bool isSuccess() const
Definition: StatusCode.h:287
::details::reverse_wrapper< T > reverse(T &&iterable)
Definition: reverse.h:52
sel
Definition: IOTest.py:95
Gaudi::Property< std::string > m_rootName
Definition: DataSvc.h:54
T end(T...args)
virtual StatusCode updateRepRefs(IOpaqueAddress *pAddress, DataObject *pObject)=0
Update the references of an already converted object.
virtual StatusCode traverseSubTree(boost::string_ref sub_tree_path, IDataStoreAgent *pAgent)=0
Analyse by traversing all data objects below the sub tree identified by its full path name...
T push_back(T...args)
MsgStream & error() const
shortcut for the method msgStream(MSG::ERROR)
virtual const unsigned long * ipar() const =0
Access to generic link parameters.
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:51
StatusCode objectLeaves(const DataObject *pObject, std::vector< IRegistry * > &refLeaves) override
IDataManagerSvc: Explore the object store: retrieve all leaves attached to the object.
Definition: DataSvc.cpp:216
The IRegistry represents the entry door to the environment any data object residing in a transient da...
Definition: IRegistry.h:22
virtual StatusCode updateRep(IOpaqueAddress *pAddress, DataObject *pObject)=0
Update the converted representation of a transient object.
virtual DataObject * object() const =0
Retrieve object behind the link.
T size(T...args)
IConversionSvc * getDataLoader(IRegistry *pReg) override
DataSvc overrides: Retrieve data loader.
Definition: NTupleSvc.cpp:91
T begin(T...args)
Opaque address interface definition.
virtual IOpaqueAddress * address() const =0
Retrieve opaque storage address.
A DataObject is the base class of any identifiable object on any data store.
Definition: DataObject.h:30
StatusCode findObject(boost::string_ref fullPath, DataObject *&pObject) override
Find object identified by its full path in the data store.
Definition: DataSvc.cpp:703
MsgStream & endmsg(MsgStream &s)
MsgStream Modifier: endmsg. Calls the output method of the MsgStream.
Definition: MsgStream.h:209
StatusCode NTupleSvc::writeRecord ( NTuple::Tuple tuple)
override

Write single record to N tuple.

Definition at line 552 of file NTupleSvc.cpp.

553 {
554  NTuple::TupleImp* tuple = (NTuple::TupleImp*)n_tuple;
555  if ( tuple ) {
556  try {
557  IConversionSvc* pSvc = tuple->conversionService();
558  if ( !pSvc ) {
559  pSvc = getDataLoader( n_tuple->registry() );
560  tuple->setConversionService( pSvc );
561  }
562  if ( pSvc ) {
563  IRegistry* pReg = n_tuple->registry();
564  IOpaqueAddress* pAddr = pReg->address();
565  StatusCode status = pSvc->createRep( n_tuple, pAddr );
566  if ( status.isSuccess() ) {
567  pReg->setAddress( pAddr );
568  status = pSvc->fillRepRefs( pAddr, n_tuple );
569  }
570  return status;
571  }
572  return Status::NO_DATA_LOADER;
573  } catch ( ... ) {
574  }
575  }
576  return Status::INVALID_OBJECT;
577 }
bool isSuccess() const
Definition: StatusCode.h:287
virtual StatusCode createRep(DataObject *pObject, IOpaqueAddress *&refpAddress)=0
Convert the transient object to the requested representation.
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:51
The IRegistry represents the entry door to the environment any data object residing in a transient da...
Definition: IRegistry.h:22
IConversionSvc * getDataLoader(IRegistry *pReg) override
DataSvc overrides: Retrieve data loader.
Definition: NTupleSvc.cpp:91
virtual void setAddress(IOpaqueAddress *pAddress)=0
Set/Update Opaque storage address.
void setConversionService(IConversionSvc *svc)
Access conversion service.
Opaque address interface definition.
virtual IOpaqueAddress * address() const =0
Retrieve opaque storage address.
virtual StatusCode fillRepRefs(IOpaqueAddress *pAddress, DataObject *pObject)=0
Resolve the references of the converted object.
IConversionSvc * conversionService() const
Access conversion service.
StatusCode NTupleSvc::writeRecord ( const std::string fullPath)
override

Write single record to N tuple.

Definition at line 580 of file NTupleSvc.cpp.

581 {
582  NTuple::Tuple* pObj = nullptr;
583  StatusCode status = findObject( fullPath, *pp_cast<DataObject>( &pObj ) ); // Check if object is present
584  return status.isSuccess() ? writeRecord( pObj ) : Status::INVALID_OBJ_PATH;
585 }
StatusCode writeRecord(NTuple::Tuple *tuple) override
Write single record to N tuple.
Definition: NTupleSvc.cpp:552
bool isSuccess() const
Definition: StatusCode.h:287
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:51
Abstract base class which allows the user to interact with the actual N tuple implementation.
Definition: NTuple.h:407
StatusCode findObject(boost::string_ref fullPath, DataObject *&pObject) override
Find object identified by its full path in the data store.
Definition: DataSvc.cpp:703
StatusCode NTupleSvc::writeRecord ( DataObject pParent,
const std::string relPath 
)
override

Write single record to N tuple.

Definition at line 588 of file NTupleSvc.cpp.

589 {
590  NTuple::Tuple* pObj = nullptr;
591  StatusCode status = findObject( pParent, relPath, *pp_cast<DataObject>( &pObj ) ); // Check if object is present
592  return status.isSuccess() ? writeRecord( pObj ) : Status::INVALID_OBJ_PATH;
593 }
StatusCode writeRecord(NTuple::Tuple *tuple) override
Write single record to N tuple.
Definition: NTupleSvc.cpp:552
bool isSuccess() const
Definition: StatusCode.h:287
This class is used for returning status codes from appropriate routines.
Definition: StatusCode.h:51
Abstract base class which allows the user to interact with the actual N tuple implementation.
Definition: NTuple.h:407
StatusCode findObject(boost::string_ref fullPath, DataObject *&pObject) override
Find object identified by its full path in the data store.
Definition: DataSvc.cpp:703

Member Data Documentation

std::map<std::string, Connection> NTupleSvc::m_connections
protected

Container of connection points.

Definition at line 119 of file NTupleSvc.h.

Gaudi::Property<DBaseEntries> NTupleSvc::m_input {this, "Input", {}, "input streams"}
protected

Definition at line 115 of file NTupleSvc.h.

Gaudi::Property<DBaseEntries> NTupleSvc::m_output {this, "Output", {}, "output streams"}
protected

Definition at line 116 of file NTupleSvc.h.


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