All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
RefTable1toN< FROM, TO > Class Template Reference

#include <GaudiKernel/RefTable.h>

Inheritance diagram for RefTable1toN< FROM, TO >:
Collaboration diagram for RefTable1toN< FROM, TO >:

Public Member Functions

 RefTable1toN (const CLID &clid, int len=16)
 Standard Constructor. More...
 
virtual ~RefTable1toN ()
 Standard Destructor. More...
 
virtual const CLIDclID () const
 Retrieve reference to class definition structure. More...
 
bool insert (const FROM *from, TO *to)
 Insert new Entry into Reference container. More...
 
bool insert (const FROM *from, const SmartRef< TO > &to)
 Insert new Entry into Reference container. More...
 
bool insert (const FROM *from, const EntryType &to)
 Insert new Entry into Reference container. More...
 
EntryTypereference (const FROM *from)
 Find Reference from it's source entry. More...
 
const EntryTypereference (const FROM *from) const
 Find Reference from it's source entry (CONST) More...
 
bool isReferenced (const FROM *from, const EntryType &to)
 Check if two entries are Referenced to each other. More...
 
bool isReferenced (const FROM *from, const TO *to)
 Check if two entries are Referenced to each other. More...
 
bool isReferenced (const FROM *from, const SmartRef< TO > &to)
 Check if two entries are Referenced to each other. More...
 
- Public Member Functions inherited from RefTableBase< FROM, SmartRefVector< TO > >
 RefTableBase (const CLID &clid, int len)
 Constructors. More...
 
virtual ~RefTableBase ()
 Destructor. More...
 
virtual void clear ()
 Clear Reference map. More...
 
iterator begin ()
 Start of direct access iterator. More...
 
const_iterator begin () const
 Start of direct access iterator (CONST) More...
 
iterator end ()
 End of direct access iterator. More...
 
const_iterator end () const
 End of direct access iterator (CONST) More...
 
long size () const
 Size of References. More...
 
void reserve (int len)
 Size of References. More...
 
virtual StreamBufferserialize (StreamBuffer &s) const
 Serialize the object for writing. More...
 
virtual StreamBufferserialize (StreamBuffer &s)
 Serialize the object for reading. More...
 
- Public Member Functions inherited from DataObject
 DataObject ()
 Standard Constructor. More...
 
 DataObject (const DataObject &)
 Copy Constructor. More...
 
virtual ~DataObject ()
 Standard Destructor. More...
 
virtual unsigned long addRef ()
 Add reference to object. More...
 
virtual unsigned long release ()
 release reference to object More...
 
const std::string & name () const
 Retreive DataObject name. It is the name when registered in the store. More...
 
virtual StatusCode update ()
 Provide empty placeholder for internal object reconfiguration callback. More...
 
void setRegistry (IRegistry *pRegistry)
 Set pointer to Registry. More...
 
IRegistryregistry () const
 Get pointer to Registry. More...
 
LinkManagerlinkMgr () const
 Retrieve Link manager. More...
 
unsigned char version () const
 Retrieve version number of this object representation. More...
 
void setVersion (unsigned char vsn)
 Set version number of this object representation. More...
 
unsigned long refCount () const
 Return the refcount. More...
 
virtual std::ostream & fillStream (std::ostream &s) const
 Fill the output stream (ASCII) More...
 

Additional Inherited Members

- Public Types inherited from RefTableBase< FROM, SmartRefVector< TO > >
typedef FROM KeyType
 
typedef SmartRefVector< TO > EntryType
 
typedef RefTableBase< FROM,
EntryType
BaseType
 
typedef GaudiUtils::HashMap
< const void *, EntryType
TableType
 Define Reference map. More...
 
typedef TableType::iterator iterator
 Definition of map iterator. More...
 
typedef TableType::const_iterator const_iterator
 Definition of map iterator (CONST) More...
 
- Static Public Member Functions inherited from DataObject
static const CLIDclassID ()
 Retrieve reference to class definition structure (static access) More...
 
- Public Attributes inherited from RefTableBase< FROM, SmartRefVector< TO > >
CLID m_clid
 Class id of the reference table. More...
 
- Protected Member Functions inherited from RefTableBase< FROM, SmartRefVector< TO > >
bool insertMapElement (const KeyType *from, EntryType &to)
 Insert new Entry into Reference container. More...
 
EntryTypei_reference (const KeyType *from)
 Find Reference from it's source entry. More...
 
const EntryTypei_reference (const KeyType *from) const
 Find Reference from it's source entry (CONST) More...
 

Detailed Description

template<class FROM, class TO>
class RefTable1toN< FROM, TO >

Definition at line 209 of file RefTable.h.

Constructor & Destructor Documentation

template<class FROM , class TO >
RefTable1toN< FROM, TO >::RefTable1toN ( const CLID clid,
int  len = 16 
)
inline

Standard Constructor.

Definition at line 213 of file RefTable.h.

215  }
template class RefTable
Definition: RefTable.h:46
template<class FROM , class TO >
virtual RefTable1toN< FROM, TO >::~RefTable1toN ( )
inlinevirtual

Standard Destructor.

Definition at line 217 of file RefTable.h.

217  {
218  }

Member Function Documentation

template<class FROM , class TO >
virtual const CLID& RefTable1toN< FROM, TO >::clID ( ) const
inlinevirtual

Retrieve reference to class definition structure.

Reimplemented from DataObject.

Definition at line 220 of file RefTable.h.

220  {
221  return m_clid;
222  }
CLID m_clid
Class id of the reference table.
Definition: RefTable.h:63
template<class FROM , class TO >
bool RefTable1toN< FROM, TO >::insert ( const FROM *  from,
TO *  to 
)
inline

Insert new Entry into Reference container.

Definition at line 224 of file RefTable.h.

224  {
225  EntryType* entry = i_reference(from);
226  if ( 0 == entry ) {
227  bool result = insertMapElement(from, EntryType());
228  EntryType* newEntry = i_reference(from);
229  if ( !( 0 == newEntry) ) {
230  newEntry->push_back( SmartRef<TO>(to) );
231  return true;
232  }
233  return false;
234  }
235  entry->push_back( SmartRef<TO>(to) );
236  return true;
237  }
Kernel objects: SmartRef.
Definition: SmartRef.h:62
EntryType * i_reference(const KeyType *from)
Find Reference from it's source entry.
Definition: RefTable.h:79
bool insertMapElement(const KeyType *from, EntryType &to)
Insert new Entry into Reference container.
Definition: RefTable.h:75
template<class FROM , class TO >
bool RefTable1toN< FROM, TO >::insert ( const FROM *  from,
const SmartRef< TO > &  to 
)
inline

Insert new Entry into Reference container.

Definition at line 239 of file RefTable.h.

239  {
240  EntryType* entry = i_reference(from);
241  if ( 0 == entry ) {
242  bool result = insertMapElement(from, EntryType());
243  EntryType* newEntry = i_reference(from);
244  if ( !(0 == newEntry) ) {
245  newEntry->push_back( to );
246  return true;
247  }
248  return false;
249  }
250  entry->push_back( to );
251  return true;
252  }
EntryType * i_reference(const KeyType *from)
Find Reference from it's source entry.
Definition: RefTable.h:79
bool insertMapElement(const KeyType *from, EntryType &to)
Insert new Entry into Reference container.
Definition: RefTable.h:75
template<class FROM , class TO >
bool RefTable1toN< FROM, TO >::insert ( const FROM *  from,
const EntryType to 
)
inline

Insert new Entry into Reference container.

Definition at line 254 of file RefTable.h.

254  {
255  return insertMapElement(from, const_cast<EntryType&>(to));
256  }
bool insertMapElement(const KeyType *from, EntryType &to)
Insert new Entry into Reference container.
Definition: RefTable.h:75
template<class FROM , class TO >
bool RefTable1toN< FROM, TO >::isReferenced ( const FROM *  from,
const EntryType to 
)
inline

Check if two entries are Referenced to each other.

Definition at line 270 of file RefTable.h.

270  {
271  const EntryType* e = i_reference(from);
272  return (0 == e) ? false : (*e == to);
273  }
EntryType * i_reference(const KeyType *from)
Find Reference from it's source entry.
Definition: RefTable.h:79
template<class FROM , class TO >
bool RefTable1toN< FROM, TO >::isReferenced ( const FROM *  from,
const TO *  to 
)
inline

Check if two entries are Referenced to each other.

Definition at line 275 of file RefTable.h.

275  {
276  return isReferenced(from, SmartRef<TO>(to));
277  }
Kernel objects: SmartRef.
Definition: SmartRef.h:62
bool isReferenced(const FROM *from, const EntryType &to)
Check if two entries are Referenced to each other.
Definition: RefTable.h:270
template<class FROM , class TO >
bool RefTable1toN< FROM, TO >::isReferenced ( const FROM *  from,
const SmartRef< TO > &  to 
)
inline

Check if two entries are Referenced to each other.

Definition at line 279 of file RefTable.h.

279  {
280  const EntryType* e = i_reference(from);
281  if ( 0 != assoc ) {
282  SmartRefVector<TO>::const_iterator i = std::find(e->begin(), e->end(), to);
283  return (i == e->end()) ? false : true;
284  }
285  return false;
286  }
Kernel objects: SmartRefVector.
EntryType * i_reference(const KeyType *from)
Find Reference from it's source entry.
Definition: RefTable.h:79
list i
Definition: ana.py:128
template<class FROM , class TO >
EntryType& RefTable1toN< FROM, TO >::reference ( const FROM *  from)
inline

Find Reference from it's source entry.

Definition at line 258 of file RefTable.h.

258  {
259  static EntryType empty;
260  EntryType* e = i_reference(from);
261  return (0 == e) ? empty : *e;
262  }
EntryType * i_reference(const KeyType *from)
Find Reference from it's source entry.
Definition: RefTable.h:79
template<class FROM , class TO >
const EntryType& RefTable1toN< FROM, TO >::reference ( const FROM *  from) const
inline

Find Reference from it's source entry (CONST)

Definition at line 264 of file RefTable.h.

264  {
265  static EntryType empty;
266  EntryType* e = i_reference(from);
267  return (0 == e) ? empty : (*e);
268  }
EntryType * i_reference(const KeyType *from)
Find Reference from it's source entry.
Definition: RefTable.h:79

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