19 #define DATASVC_DATASVC_CPP 41 #include "boost/utility/string_ref.hpp" 52 s.append( sr.data(), sr.size() );
56 boost::string_ref::size_type find( boost::string_ref
s,
char c,
size_t o )
58 if ( !s.empty() ) s.remove_prefix( o );
60 return r == boost::string_ref::npos ? r : ( r + o );
63 std::string to_string( boost::string_ref sr ) {
return {sr.data(), sr.size()}; }
71 #define CAST_REGENTRY( x, y ) dynamic_cast<x>( y ) 75 #define ON_DEBUG if ( msgLevel( MSG::DEBUG ) ) 76 #define ON_VERBOSE if ( msgLevel( MSG::VERBOSE ) ) 78 #define DEBMSG ON_DEBUG debug() 79 #define VERMSG ON_VERBOSE verbose() 90 if ( !node_entry )
return Status::INVALID_OBJECT;
92 if ( !parent )
return Status::INVALID_PARENT;
93 parent->
remove( node_entry );
102 if ( !
checkRoot() )
return Status::INVALID_ROOT;
104 if ( !entry )
return Status::INVALID_OBJECT;
106 if ( !parent )
return Status::INVALID_PARENT;
114 if ( !
checkRoot() )
return Status::INVALID_ROOT;
133 if ( !
checkRoot() )
return Status::INVALID_ROOT;
135 if ( !entry )
return Status::INVALID_OBJECT;
142 if ( !
checkRoot() )
return Status::INVALID_ROOT;
209 if ( !pObject )
return Status::INVALID_OBJECT;
215 if ( !
checkRoot() )
return Status::INVALID_ROOT;
217 if ( !node_entry )
return Status::INVALID_OBJECT;
218 refpParent = node_entry->
parent();
225 if ( !pObject )
return Status::INVALID_OBJECT;
234 if ( !
checkRoot() )
return Status::INVALID_ROOT;
236 if ( !node_entry )
return Status::INVALID_OBJECT;
237 leaves = node_entry->
leaves();
244 if ( fullPath.empty() )
return Status::INVALID_OBJ_PATH;
258 if ( !
checkRoot() )
return Status::INVALID_ROOT;
259 if ( objPath.empty() )
return Status::INVALID_OBJ_PATH;
265 auto sep = find( objPath,
SEPARATOR, 1 );
266 if ( sep == boost::string_ref::npos || objPath.substr( 0, sep ) !=
m_rootName.value() ) {
267 return Status::INVALID_PARENT;
275 if ( !par_entry )
return Status::INVALID_PARENT;
278 if ( sep > 0 && sep != boost::string_ref::npos ) {
279 auto p_path = objPath.substr( 0, sep );
280 auto o_path = objPath.substr( sep );
288 p_entry = par_entry->
findLeaf( p_path );
290 if ( !p_entry )
return Status::INVALID_PARENT;
293 StatusCode status = par_entry->
add( to_string( objPath ), pAddress );
294 return status.
isSuccess() ? status : Status::DOUBL_OBJ_PATH;
300 if ( fullPath.empty() )
return Status::INVALID_OBJ_PATH;
313 if ( !
checkRoot() )
return Status::INVALID_ROOT;
314 if ( objPath.empty() )
return Status::INVALID_OBJ_PATH;
318 auto sep = find( objPath,
SEPARATOR, 1 );
319 if ( sep != boost::string_ref::npos && objPath.substr( 0, sep ) ==
m_rootName ) {
322 return Status::INVALID_PARENT;
332 if ( sep > 0 && sep != boost::string_ref::npos ) {
336 if ( status.isSuccess() )
return status;
339 return Status::INVALID_PARENT;
376 if ( !
checkRoot() )
return Status::INVALID_ROOT;
379 if ( !objPath.empty() ) {
383 auto sep = find( objPath,
SEPARATOR, 1 );
384 if ( sep != boost::string_ref::npos ) {
385 return registerObject( objPath.substr( 0, sep ), objPath.substr( sep ), pObject );
388 return Status::INVALID_OBJ_PATH;
393 auto sep = find( objPath,
SEPARATOR, 1 );
394 if ( sep != boost::string_ref::npos ) {
395 auto p_path = objPath.substr( 0, sep );
396 auto o_path = objPath.substr( sep );
404 par_entry = node_entry->
findLeaf( p_path );
405 }
else if ( par_entry && !par_entry->
object() ) {
411 par_entry = node_entry->
findLeaf( p_path );
414 node_entry = par_entry;
422 status = node_entry->
add( to_string( objPath ), pObject );
427 error() <<
"registerObject: trying to register null DataObject" <<
endmsg;
435 status = Status::DOUBL_OBJ_PATH;
441 return Status::INVALID_PARENT;
451 if ( !pEntry )
return Status::INVALID_ROOT;
452 if ( !pEntry->
isEmpty() )
return Status::DIR_NOT_EMPTY;
454 if ( !pParent )
return Status::INVALID_PARENT;
455 if ( pObject ) pObject->
addRef();
456 pParent->
remove( pEntry );
477 if ( !
checkRoot() )
return Status::INVALID_ROOT;
479 if ( !entry )
return Status::INVALID_OBJECT;
481 if ( !parent )
return Status::INVALID_PARENT;
482 if ( !entry->
isEmpty() )
return Status::DIR_NOT_EMPTY;
484 if ( parent ) parent->
remove( entry );
504 return Status::DIR_NOT_EMPTY;
506 return Status::INVALID_OBJECT;
510 return Status::INVALID_PARENT;
512 return Status::INVALID_ROOT;
532 if ( pReg && path.empty() ) {
540 p.
append( path.data(), path.size() );
547 p.
append( path.data(), path.size() );
592 return Status::NO_ACCESS;
597 return Status::INVALID_OBJ_ADDR;
600 status = pLoader->
createObj( pAddress, pObject );
609 status = pLoader->
fillObjRefs( pAddress, pObject );
653 static const auto empty = boost::string_ref{};
661 }
else if ( path.front() !=
SEPARATOR ) {
663 }
else if ( sep != boost::string_ref::npos ) {
667 if ( !status.isSuccess() )
return status;
670 path = path.substr( sep );
672 return Status::INVALID_OBJ_PATH;
678 if ( sep != boost::string_ref::npos ) {
679 if ( !parentObj->
object() ) {
681 if ( !status.
isSuccess() )
return status;
683 auto p_path = path.substr( 0, sep );
689 root_entry = parentObj->
findLeaf( p_path );
696 if ( !status.
isSuccess() )
return status;
698 if ( root_entry->
isSoft() ) {
704 }
else if ( path.empty() ) {
707 if ( !parentObj->
object() ) {
709 if ( !status.
isSuccess() )
return status;
712 pEntry = parentObj->
findLeaf( path );
716 pEntry = ( path.empty() ? parentObj : parentObj->
findLeaf( path ) );
721 if ( !pEntry )
return Status::INVALID_OBJ_PATH;
787 if ( !path.empty() ) pReg = root_entry->
find( path );
788 if ( !pReg )
return Status::INVALID_OBJ_PATH;
791 return ( !pObject ) ? Status::OBJ_NOT_LOADED : Status::IDataProviderSvc_NO_ERROR;
798 if ( !
checkRoot() )
return Status::INVALID_ROOT;
799 if ( path.empty() || path ==
m_rootName.value() ) {
801 return !pObject ? Status::OBJ_NOT_LOADED : Status::IDataProviderSvc_NO_ERROR;
804 :
findObject( static_cast<IRegistry*>(
nullptr ),
path, pObject );
818 return findObject( parentPath, itemToPath( item ), pObject );
824 return findObject( parentObj, itemToPath( item ), pObject );
846 return Status::INVALID_OBJ_ADDR;
860 return Status::INVALID_OBJECT;
864 return Status::INVALID_OBJECT;
868 return Status::INVALID_OBJ_ADDR;
872 return Status::NO_DATA_LOADER;
877 return Status::NO_ACCESS;
881 status = pLoader->
updateObj( pAddress, toUpdate );
888 throw GaudiException(
"std::exception in updateObject() " + pRegistry->
name() +
": " +
916 if ( !
checkRoot() )
return Status::INVALID_ROOT;
922 if ( !to_entry )
return Status::INVALID_OBJECT;
924 if ( sep > 0 && sep != boost::string_ref::npos ) {
930 StatusCode status = from_entry->
add( to_string( objPath ), to,
true );
931 return status.
isSuccess() ? Status::IDataProviderSvc_NO_ERROR : Status::DOUBL_OBJ_PATH;
935 return Status::INVALID_PARENT;
941 if ( fullPath.empty() )
return Status::INVALID_OBJ_PATH;
946 return linkObject( fullPath.substr( 0, sep ), fullPath.substr( sep ), to );
966 return Status::INVALID_PARENT;
972 if ( !
checkRoot() )
return Status::INVALID_ROOT;
977 if ( sep > 0 && sep != boost::string_ref::npos ) {
983 if ( status.isSuccess() )
return status;
984 return Status::INVALID_OBJ_PATH;
988 return Status::INVALID_PARENT;
994 if ( fullPath.empty() )
return Status::INVALID_OBJ_PATH;
999 return unlinkObject( fullPath.substr( 0, sep ), fullPath.substr( sep ) );
1013 if ( !
checkRoot() )
return Status::INVALID_ROOT;
1056 if ( pObject && depth++ < load_depth ) {
1059 for (
const auto& i : *dir ) {
1062 if ( status.
isSuccess() && depth < load_depth ) {
1077 int load_depth = i.depth();
1078 if ( sc.
isSuccess() && load_depth > 1 ) {
1093 error() <<
"Failed to access incident service." <<
endmsg;
1109 error() <<
"Unable to reinitialize base class" <<
endmsg;
1115 error() <<
"Failed to access incident service." <<
endmsg;
StatusCode registerAddress(boost::string_ref fullPath, IOpaqueAddress *pAddress) override
IDataManagerSvc: Register object address with the data store.
StatusCode unregisterAddress(boost::string_ref fullPath) override
IDataManagerSvc: Unregister object address from the data store.
Gaudi::Property< CLID > m_rootCLID
StatusCode addPreLoadItem(const DataStoreItem &item) override
Add an item to the preload list.
StatusCode unregisterObject(boost::string_ref fullPath) override
Unregister object from the data store.
constexpr static const auto FAILURE
StatusCode initialize() override
StatusCode linkObject(IRegistry *from, boost::string_ref objPath, DataObject *to) override
Add a link to another object.
RegistryEntry * findLeaf(boost::string_ref path) const
Find identified leaf in this registry node.
~DataSvc() override
Standard Destructor.
Define general base for Gaudi exception.
DataObject * object() const override
Retrive object behind the link.
const std::string & name() const override
Retrieve name of the service.
StatusCode preLoad() override
load all preload items of the list
virtual StatusCode createObj(IOpaqueAddress *pAddress, DataObject *&refpObject)=0
Create the transient representation of an object.
StatusCode finalize() override
CLID rootCLID() const override
IDataManagerSvc: Accessor for root event CLID.
GAUDI_API const std::string typeinfoName(const std::type_info &)
Get platform independent information about the class type.
Gaudi::Property< std::string > m_accessName
StatusCode traverseTree(IDataStoreAgent *pAgent, int level=0)
traverse data tree
StatusCode setRoot(std::string root_name, DataObject *pRootObj) override
Initialize data store for new event by giving new event path and root object.
StatusCode setDataLoader(IConversionSvc *svc, IDataProviderSvc *dpsvc=nullptr) override
IDataManagerSvc: IDataManagerSvc: Pass a default data loader to the service and optionally a data pro...
MsgStream & verbose() const
shortcut for the method msgStream(MSG::VERBOSE)
Gaudi::Property< std::string > m_rootName
virtual StatusCode setDataProvider(IDataProviderSvc *pService)=0
Set Data provider service.
virtual StatusCode loadObject(IRegistry *pNode)
Invoke Persistency service to create transient object from its persistent representation.
LoadItems m_preLoads
Items to be pre-loaded.
Gaudi::Property< bool > m_forceLeaves
void setRegistry(IRegistry *pRegistry)
Set pointer to Registry.
unsigned long release() override
IInterface implementation: Reference the object.
Gaudi::Property< bool > m_enableFaultHdlr
virtual const name_type & name() const =0
Name of the directory (or key)
StatusCode traverseTree(IDataStoreAgent *pAgent) override
IDataManagerSvc: Analyze by traversing all data objects in the data store.
bool checkRoot()
Check if root path is valid.
DataObject * i_handleDataFault(IRegistry *pReg, boost::string_ref path=boost::string_ref{})
StatusCode retrieveEntry(DataSvcHelpers::RegistryEntry *pNode, boost::string_ref path, DataSvcHelpers::RegistryEntry *&pEntry)
Retrieve registry entry from store.
StatusCode removePreLoadItem(const DataStoreItem &item) override
Remove an item from the preload list.
const Store & leaves() const
Access the leaves of the object.
bool isSoft() const
Is the link soft or hard.
Data provider interface definition.
DataSvcHelpers::RegistryEntry * m_root
Pointer to root entry.
void setAddress(IOpaqueAddress *pAddress) override
Set/Update Opaque address.
Description of the DataStoreItem class.
StatusCode clearSubTree(boost::string_ref sub_tree_path) override
IDataManagerSvc: Remove all data objects below the sub tree identified by its full path name...
IRegistry * registry() const
Get pointer to Registry.
virtual StatusCode updateObj(IOpaqueAddress *pAddress, DataObject *refpObject)=0
Update the transient object from the other representation.
TYPE * get() const
Get interface pointer.
MsgStream & error() const
shortcut for the method msgStream(MSG::ERROR)
virtual unsigned long addRef()
Add reference to object.
virtual void fireIncident(const Incident &incident)=0
Fire an Incident.
void setObject(DataObject *obj)
Set/Update object address.
StatusCode i_retrieveEntry(DataSvcHelpers::RegistryEntry *parentObj, boost::string_ref path, DataSvcHelpers::RegistryEntry *&pEntry)
Gaudi::Property< std::string > m_faultName
virtual const id_type & identifier() const =0
Full identifier (or key)
This class is used for returning status codes from appropriate routines.
IRegistry * parent() const
Pointer to parent directory entry.
virtual StatusCode updateObjRefs(IOpaqueAddress *pAddress, DataObject *pObject)=0
Update the references of an updated transient object.
SmartIF< IIncidentSvc > m_incidentSvc
Pointer to incident service.
StatusCode unlinkObject(IRegistry *from, boost::string_ref objPath) override
Remove a link to another object.
StatusCode objectLeaves(const DataObject *pObject, std::vector< IRegistry * > &refLeaves) override
IDataManagerSvc: Explore the object store: retrieve all leaves attached to the object.
void setDataSvc(IDataProviderSvc *s)
Set the transient data store.
The IRegistry represents the entry door to the environment any data object residing in a transient da...
StatusCode finalize() override
Service initialization.
StatusCode reinitialize() override
unsigned int CLID
Class ID definition.
IOpaqueAddress * address() const override
Retrieve opaque storage address.
#define CAST_REGENTRY(x, y)
constexpr static const auto SUCCESS
virtual DataObject * object() const =0
Retrieve object behind the link.
Definition of an entry in the transient data store.
virtual unsigned long release()
release reference to object
Gaudi::Property< std::vector< std::string > > m_inhibitPathes
StatusCode registerObject(boost::string_ref fullPath, DataObject *pObject) override
Register object with the data store.
StatusCode add(std::string name, DataObject *pObject, bool is_soft=false)
Add entry to data store.
virtual StatusCode i_setRoot(std::string root_name, DataObject *pRootObj)
Initialize data store for new event by giving new event path and root object.
virtual StatusCode fillObjRefs(IOpaqueAddress *pAddress, DataObject *pObject)=0
Resolve the references of the created transient object.
StatusCode reinitialize() override
Service initialization.
SmartIF< IConversionSvc > m_dataLoader
Pointer to data loader service.
Generic data agent interface.
StatusCode initialize() override
Service initialization.
RegistryEntry * parentEntry()
Pointer to parent registry entry.
const StatusCode & ignore() const
Ignore/check StatusCode.
decltype(auto) operator+(const T &v, const Property< TP, V, H > &p)
implemantation of (value + property)
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 pat...
IRegistry * find(const IRegistry *obj) const
Try to find an object identified by its pointer.
Gaudi::Property< bool > m_enableAccessHdlr
const std::string & name() const
Retreive DataObject name. It is the name when registered in the store.
const std::string & rootName() const override
IDataManagerSvc: Accessor for root event name.
StatusCode objectParent(const DataObject *pObject, IRegistry *&refpParent) override
IDataManagerSvc: Explore the object store: retrieve the object's parent.
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.
const std::string & identifier() const override
Full identifier (or key)
void reset(TYPE *ptr=nullptr)
Set the internal pointer to the passed one disposing of the old one.
StatusCode remove(boost::string_ref name)
Remove an entry from the store.
bool isEmpty() const
Simple check if the Container is empty.
Data service incident class.
AttribStringParser::Iterator begin(const AttribStringParser &parser)
Opaque address interface definition.
StatusCode retrieveObject(IRegistry *pDirectory, boost::string_ref path, DataObject *&pObject) override
Retrieve object from data store.
virtual IConversionSvc * getDataLoader(IRegistry *pReg)
Retrieve customizable data loader according to registry entry to be retrieved.
virtual IOpaqueAddress * address() const =0
Retrieve opaque storage address.
StatusCode updateObject(IRegistry *pDirectory) override
Update object identified by its directory entry.
A DataObject is the base class of any identifiable object on any data store.
StatusCode resetPreLoad() override
Clear the preload list.
StatusCode findObject(boost::string_ref fullPath, DataObject *&pObject) override
Find object identified by its full path in the data store.
virtual DataObject * createDefaultObject() const
Create default objects in case forced creation of leaves is requested.
MsgStream & endmsg(MsgStream &s)
MsgStream Modifier: endmsg. Calls the output method of the MsgStream.
StatusCode clearStore() override
IDataManagerSvc: Remove all data objects in the data store.
DataSvcHelpers::RegistryEntry RegEntry
DataObject * handleDataFault(IRegistry *pReg, boost::string_ref path="")
Invoke data fault handling if enabled.
void makeHard(DataObject *pObject)
Initialize link as hard link.