Belle II Software
release-08-01-10
|
This class is for convenience access and registration of objects, that are stored inside the StoreWrapper on the DataStore. More...
#include <StoreWrappedObjPtr.h>
Public Member Functions | |
StoreWrappedObjPtr (const std::string &name="", DataStore::EDurability durability=DataStore::c_Event) | |
Constructor to access an object in the DataStore. More... | |
bool | registerInDataStore (DataStore::EStoreFlags storeFlags=DataStore::c_DontWriteOut|DataStore::c_ErrorIfAlreadyRegistered) |
Register the object/array in the DataStore. More... | |
bool | registerInDataStore (const std::string &name, DataStore::EStoreFlags storeFlags=DataStore::c_DontWriteOut|DataStore::c_ErrorIfAlreadyRegistered) |
Register the object/array in the DataStore. More... | |
T & | operator* () const |
Dereference to the wrapped object. | |
T * | operator-> () const |
Forward pointer access to the wrapped object. | |
bool | isValid () const |
Check whether the object was created. More... | |
bool | construct (Args &&... params) |
Construct an object of type T in this StoreObjPtr, using the provided constructor arguments. More... | |
bool | constructAndReplace (Args &&... params) |
Construct an object of type T in this StoreObjPtr, using the provided constructor arguments. More... | |
operator bool () const | |
Imitate pointer functionality. | |
bool | isRequired (const std::string &name="") |
Ensure this array/object has been registered previously. More... | |
bool | isOptional (const std::string &name="") |
Tell the DataStore about an optional input. More... | |
bool | create (bool replace=false) |
Create a default object in the data store. More... | |
bool | assign (TObject *object, bool replace=false) |
Assign 'object' to this accessor. More... | |
virtual void | clear () |
Clear contents of this object. | |
const std::string & | getName () const |
Return name under which the object is saved in the DataStore. | |
DataStore::EDurability | getDurability () const |
Return durability with which the object is saved in the DataStore. | |
AccessorParams | getAccessorParams () const |
Return pair of name and durability under which stored object is saved. More... | |
virtual bool | operator== (const StoreAccessorBase &other) const |
Check if two store accessors point to the same object/array. | |
virtual bool | operator!= (const StoreAccessorBase &other) const |
Check if two store accessors point to a different object/array. | |
TClass * | getClass () const |
The underlying object's type. | |
bool | isArray () const |
Is this an accessor for an array? | |
bool | notWrittenOut () const |
Returns true if this object/array should not be saved by output modules. More... | |
std::string | readableName () const |
Convert this acessor into a readable string (for messages). More... | |
Static Public Member Functions | |
static std::vector< std::string > | getObjectList (DataStore::EDurability durability=DataStore::c_Event) |
Return list of object names with matching type. More... | |
Protected Attributes | |
std::string | m_name |
Store name under which this object/array is saved. | |
DataStore::EDurability | m_durability |
Store durability under which the object/array is saved. | |
TClass * | m_class |
The underlying object's type. | |
bool | m_isArray |
Is this an accessor for an array? | |
Private Member Functions | |
void | ensureAttached () const |
Ensure that this object is attached. | |
void | ensureValid () const |
if accesses to this object would crash, throw an std::runtime_error | |
Private Attributes | |
TObject ** | m_storeObjPtr |
Store of actual pointer. More... | |
This class is for convenience access and registration of objects, that are stored inside the StoreWrapper on the DataStore.
It limits the user to registrations of transient store objects only, since objects wrapped by the StoreWrapper are usually not intended for streaming.
Definition at line 30 of file StoreWrappedObjPtr.h.
|
inline |
Constructor to access an object in the DataStore.
name | Name under which the object is stored in the DataStore. If an empty string is supplied, the type name will be used. |
durability | Decides durability map used for getting the accessed object. |
Definition at line 39 of file StoreWrappedObjPtr.h.
|
inherited |
Assign 'object' to this accessor.
(takes ownership).
object | The object that should be put in the DataStore, should be of same type as the one used by this accessor. |
replace | Should an existing object be replaced? (if existing and supplied object are equal, this has no effect) |
Definition at line 33 of file StoreAccessorBase.cc.
|
inlineinherited |
Construct an object of type T in this StoreObjPtr, using the provided constructor arguments.
If this StoreObjPtr already contains an object, this function will fail.
Definition at line 119 of file StoreObjPtr.h.
|
inlineinherited |
Construct an object of type T in this StoreObjPtr, using the provided constructor arguments.
If this StoreObjPtr already contains an object, it will be replaced.
Definition at line 131 of file StoreObjPtr.h.
|
inlineinherited |
Create a default object in the data store.
This only works after registerInDataStore() has been called by this or another module.
replace | Should an existing object be replaced? |
Definition at line 107 of file StoreAccessorBase.h.
|
inlineinherited |
Return pair of name and durability under which stored object is saved.
Definition at line 134 of file StoreAccessorBase.h.
|
inlinestaticinherited |
|
inlineinherited |
Tell the DataStore about an optional input.
Mainly useful for creating diagrams of module inputs and outputs.
name | If not empty, set non-default name for this object/array. This is permanent, so that e.g. after using registerInDataStore("myName") in initialize(), this object will continue refer to 'myName' in event(). |
Definition at line 93 of file StoreAccessorBase.h.
|
inlineinherited |
Ensure this array/object has been registered previously.
Will cause an ERROR if it does not exist. This must be called in the initialization phase.
name | If not empty, set non-default name for this object/array. This is permanent, so that e.g. after using registerInDataStore("myName") in initialize(), this object will continue refer to 'myName' in event(). |
Definition at line 78 of file StoreAccessorBase.h.
|
inlineinherited |
Check whether the object was created.
Definition at line 111 of file StoreObjPtr.h.
|
inherited |
Returns true if this object/array should not be saved by output modules.
See DataStore::c_DontWriteOut. Can be changed by re-registering it with/without the flag.
Definition at line 53 of file StoreAccessorBase.cc.
|
inherited |
Convert this acessor into a readable string (for messages).
e.g. "object EventMetaData (durability: event)"
Definition at line 18 of file StoreAccessorBase.cc.
|
inline |
Register the object/array in the DataStore.
This must be called in the initialization phase.
name | If not empty, set non-default name for this object/array. This is permanent, so that e.g. after using registerInDataStore("myName") in initialize(), this object will continue refer to 'myName' in event(). |
storeFlags | ORed combination of DataStore::EStoreFlag flags. Defaults to c_DontWriteOut | DataStore::c_ErrorIfAlreadyRegistered. |
Definition at line 62 of file StoreWrappedObjPtr.h.
|
inline |
Register the object/array in the DataStore.
This must be called in the initialization phase.
storeFlags | ORed combination of DataStore::EStoreFlag flags. Defaults to c_DontWriteOut | c_ErrorIfAlreadyRegistered. |
Definition at line 50 of file StoreWrappedObjPtr.h.
|
privateinherited |
Store of actual pointer.
Don't make this a T** as this might cause problems with multiple inheritance objects
Definition at line 170 of file StoreObjPtr.h.