![]() |
The Gaudi Framework
v31r0 (aeb156f0)
|
Kernel objects: SmartRef. More...
#include <GaudiKernel/SmartRef.h>
Public Types | |
enum | { VALID = StreamBuffer::VALID, INVALID = StreamBuffer::INVALID } |
typedef TYPE | entry_type |
Entry type definition. More... | |
Public Member Functions | |
SmartRef () | |
Standard Constructor. More... | |
SmartRef (TYPE *pObject) | |
Standard Constructor with initialisation. More... | |
SmartRef (const TYPE *pObject) | |
Standard Constructor with initialisation from const object. More... | |
SmartRef (const SmartRef ©) | |
Copy Constructor. More... | |
SmartRef (long hint, long link, TYPE *obj=nullptr) | |
Constructor. More... | |
SmartRef (const ContainedObject *pObj, long hint, long link, TYPE *obj=nullptr) | |
Constructor for references to contained objects passing environment. More... | |
SmartRef (const DataObject *pObj, long hint, long link, TYPE *obj=nullptr) | |
Constructor for references to contained objects passing environment. More... | |
SmartRef (const DataObject *pObj, long hint, TYPE *obj=nullptr) | |
Constructor for references to DataObjects passing environment. More... | |
bool | shouldFollowLink (const DataObject *) const |
Standard destructor. More... | |
bool | shouldFollowLink (const ContainedObject *) const |
Check if link should be followed: link must be valid and object not yet loaded. More... | |
long | hintID () const |
Access hint id: More... | |
long | linkID () const |
Access link id: More... | |
void | set (DataObject *pObj, long hint_id, long link_id) |
Setup smart reference when reading. Must be allowed from external sources. More... | |
const std::type_info * | type () const |
Access to embedded type. More... | |
TYPE * | data () |
Access to raw data pointer. More... | |
const TYPE * | data () const |
const TYPE * | target () const |
Access to the object. More... | |
TYPE * | target () |
Access to the object. More... | |
const std::string & | path () const |
Return the path of the linked object inside the data store. More... | |
bool | operator== (const SmartRef< TYPE > &c) const |
Equality operator. More... | |
bool | operator!= (const SmartRef< TYPE > &c) const |
NON-Equality operator. More... | |
const SmartRef< TYPE > & | _setEnvironment (const DataObject *pObj, const ContainedObject *pContd) const |
Set the environment (CONST) More... | |
SmartRef< TYPE > & | _setEnvironment (const DataObject *pObj, const ContainedObject *pContd) |
Set the environment (CONST) More... | |
SmartRef< TYPE > & | operator() (ContainedObject *pObj) |
operator(): assigns parent object for serialisation More... | |
const SmartRef< TYPE > & | operator() (const ContainedObject *pObj) const |
operator() const: assigns parent object for serialisation More... | |
SmartRef< TYPE > & | operator() (DataObject *pObj) |
operator(): assigns parent object for serialisation More... | |
const SmartRef< TYPE > & | operator() (const DataObject *pObj) const |
operator() const: assigns parent object for serialisation More... | |
SmartRef< TYPE > & | operator= (const SmartRef< TYPE > &c) |
Assignment. More... | |
SmartRef< TYPE > & | operator= (TYPE *pObject) |
Assignment. More... | |
TYPE & | operator* () |
Dereference operator. More... | |
const TYPE & | operator* () const |
Dereference operator. More... | |
TYPE * | operator-> () |
Dereference operator. More... | |
const TYPE * | operator-> () const |
Dereference operator to const object. More... | |
operator const TYPE * () const | |
Implicit type conversion to const object. More... | |
operator TYPE * () | |
Implicit type conversion. More... | |
StreamBuffer & | writeRef (StreamBuffer &s) const |
Write the reference to the stream buffer (needed due to stupid G++ compiler) More... | |
StreamBuffer & | readRef (StreamBuffer &s) |
Read the reference from the stream buffer (needed due to stupid G++ compiler) More... | |
Protected Attributes | |
SmartRefBase | m_base |
const TYPE * | m_target = nullptr |
Pointer to target data object. More... | |
Friends | |
class | SmartRefArray< TYPE > |
The container must be a friend. More... | |
class | SmartRefList< TYPE > |
class | SmartRefMap< TYPE > |
StreamBuffer & | operator<< (StreamBuffer &_s, const SmartRef< TYPE > &ptr) |
Output Streamer operator. More... | |
StreamBuffer & | operator>> (StreamBuffer &_s, SmartRef< TYPE > &ptr) |
Input Streamer operator. More... | |
Kernel objects: SmartRef.
Description: The SmartRef class allows transparent handling of object links within the data store. Links are unloaded a priori and will only be loaded "on demand", i.e. when dereferenced.
SmartRefs should behave in the same way as normal pointers; The SmartRef object in fact is a smart pointer construct intercepting the dereference operators.
When loading, the executed code resides in the non templated base class. This ensures, that the templated code is minimized and code blow up is inhibited.
Using SmartRefs StreamBuffers are able to also save the references on data conversion requests.
Base Class: SmartRefBase
Dependencies:
History :
+---------+----------------------------------------------+--------+ | Date | Comment | Who | +---------+----------------------------------------------+--------+ | 21/04/99| Initial version. | MF | | 16/01/04| Move base class into aggregation. | MF | +---------+----------------------------------------------+--------+
Author: M.Frank Version: 1.0
Definition at line 66 of file SmartRef.h.
typedef TYPE SmartRef< TYPE >::entry_type |
Entry type definition.
Definition at line 75 of file SmartRef.h.
anonymous enum |
Enumerator | |
---|---|
VALID | |
INVALID |
Definition at line 73 of file SmartRef.h.
Standard Constructor.
Definition at line 84 of file SmartRef.h.
Standard Constructor with initialisation.
Definition at line 90 of file SmartRef.h.
Standard Constructor with initialisation from const object.
Definition at line 97 of file SmartRef.h.
Copy Constructor.
Definition at line 104 of file SmartRef.h.
|
inline |
Constructor.
Definition at line 111 of file SmartRef.h.
|
inline |
Constructor for references to contained objects passing environment.
Definition at line 118 of file SmartRef.h.
|
inline |
Constructor for references to contained objects passing environment.
Definition at line 126 of file SmartRef.h.
|
inline |
Constructor for references to DataObjects passing environment.
Definition at line 133 of file SmartRef.h.
|
inline |
Set the environment (CONST)
Definition at line 176 of file SmartRef.h.
|
inline |
Set the environment (CONST)
Definition at line 183 of file SmartRef.h.
|
inline |
|
inline |
Definition at line 158 of file SmartRef.h.
|
inline |
Access hint id:
Definition at line 149 of file SmartRef.h.
|
inline |
Access link id:
Definition at line 151 of file SmartRef.h.
|
inline |
|
inline |
NON-Equality operator.
Definition at line 174 of file SmartRef.h.
|
inline |
operator(): assigns parent object for serialisation
Definition at line 190 of file SmartRef.h.
|
inline |
operator() const: assigns parent object for serialisation
Definition at line 195 of file SmartRef.h.
|
inline |
operator(): assigns parent object for serialisation
Definition at line 200 of file SmartRef.h.
|
inline |
operator() const: assigns parent object for serialisation
Definition at line 202 of file SmartRef.h.
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
Assignment.
Definition at line 204 of file SmartRef.h.
Assignment.
Definition at line 211 of file SmartRef.h.
Equality operator.
Definition at line 166 of file SmartRef.h.
|
inline |
Return the path of the linked object inside the data store.
Definition at line 164 of file SmartRef.h.
|
inline |
Read the reference from the stream buffer (needed due to stupid G++ compiler)
Definition at line 273 of file SmartRef.h.
|
inline |
Setup smart reference when reading. Must be allowed from external sources.
Definition at line 153 of file SmartRef.h.
|
inline |
Standard destructor.
Check if link should be followed: link must be valid and object not yet loaded
Definition at line 143 of file SmartRef.h.
|
inline |
Check if link should be followed: link must be valid and object not yet loaded.
Definition at line 145 of file SmartRef.h.
|
inline |
Access to the object.
Access to the object (CONST)
Definition at line 259 of file SmartRef.h.
|
inline |
Access to the object.
Definition at line 252 of file SmartRef.h.
|
inline |
|
inline |
Write the reference to the stream buffer (needed due to stupid G++ compiler)
Definition at line 266 of file SmartRef.h.
|
friend |
Output Streamer operator.
Definition at line 235 of file SmartRef.h.
|
friend |
Input Streamer operator.
Definition at line 238 of file SmartRef.h.
|
friend |
The container must be a friend.
Definition at line 68 of file SmartRef.h.
|
friend |
Definition at line 69 of file SmartRef.h.
|
friend |
Definition at line 70 of file SmartRef.h.
|
protected |
Definition at line 78 of file SmartRef.h.
|
mutableprotected |
Pointer to target data object.
Definition at line 80 of file SmartRef.h.