![]() |
The Gaudi Framework
master (d98a2936)
|
#include <GaudiKernel/ObjectVector.h>
Public Types | |
typedef TYPE | contained_type |
typedef std::vector< TYPE * >::value_type | value_type |
typedef std::vector< TYPE * >::reference | reference |
typedef std::vector< TYPE * >::const_reference | const_reference |
typedef std::vector< TYPE * >::iterator | iterator |
typedef std::vector< TYPE * >::const_iterator | const_iterator |
typedef std::vector< TYPE * >::reverse_iterator | reverse_iterator |
typedef std::vector< TYPE * >::const_reverse_iterator | const_reverse_iterator |
typedef std::vector< TYPE * >::pointer | pointer |
typedef std::vector< TYPE * >::const_pointer | const_pointer |
Public Member Functions | |
ObjectVector ()=default | |
ObjectVector (const ObjectVector< TYPE > &)=delete | |
ObjectVector & | operator= (const ObjectVector< TYPE > &)=delete |
ObjectVector (ObjectVector &&rhs) | |
~ObjectVector () override | |
const CLID & | clID () const override |
Retrieve class ID. More... | |
ObjectVector< TYPE >::iterator | begin () |
Return an iterator pointing to the beginning of the container. More... | |
ObjectVector< TYPE >::const_iterator | begin () const |
Return a const_iterator pointing to the beginning of the container. More... | |
ObjectVector< TYPE >::iterator | end () |
Return an iterator pointing to the end of the container. More... | |
ObjectVector< TYPE >::const_iterator | end () const |
Return a const_iterator pointing to the end of the container. More... | |
ObjectVector< TYPE >::reverse_iterator | rbegin () |
Return a reverse_iterator pointing to the beginning of the reversed container. More... | |
ObjectVector< TYPE >::const_reverse_iterator | rbegin () const |
Return a const_reverse_iterator pointing to the beginning of the reversed container. More... | |
ObjectVector< TYPE >::reverse_iterator | rend () |
Return a reverse_iterator pointing to the end of the reversed container. More... | |
ObjectVector< TYPE >::const_reverse_iterator | rend () const |
Return a const_reverse_iterator pointing to the end of the reversed container. More... | |
ObjectVector< TYPE >::size_type | size () const |
Return the size of the container. More... | |
ObjectVector< TYPE >::size_type | numberOfObjects () const override |
The same as size(), return number of objects in the container. More... | |
ObjectVector< TYPE >::size_type | max_size () const |
Return the largest possible size of the container. More... | |
ObjectVector< TYPE >::size_type | capacity () const |
Return number of elements for which memory has been allocated It is always greater than or equal to size() More... | |
void | reserve (typename ObjectVector< TYPE >::size_type value) |
Reserve place for "value" objects in the container. More... | |
bool | empty () const |
Return true if the size of the container is 0. More... | |
ObjectVector< TYPE >::reference | front () |
Return reference to the first element. More... | |
ObjectVector< TYPE >::const_reference | front () const |
Return const_reference to the first element. More... | |
ObjectVector< TYPE >::reference | back () |
Return reference to the last element. More... | |
ObjectVector< TYPE >::const_reference | back () const |
Return const_reference to the last element. More... | |
void | push_back (typename ObjectVector< TYPE >::const_reference value) |
push_back = append = insert a new element at the end of the container More... | |
long | add (ContainedObject *pObject) override |
Add an object to the container. More... | |
void | pop_back () |
pop_back = remove the last element from the container The removed object will be deleted (see the method release) More... | |
long | remove (ContainedObject *value) override |
Release object from the container (the poiter will be removed from the container, but the object itself will remain alive) (see the method pop_back) More... | |
ObjectVector< TYPE >::iterator | insert (typename ObjectVector< TYPE >::iterator position, typename ObjectVector< TYPE >::const_reference value) |
Insert "value" before "position". More... | |
void | erase (typename ObjectVector< TYPE >::iterator position) |
Erase the object at "position" from the container. The removed object will be deleted. More... | |
void | erase (typename ObjectVector< TYPE >::iterator first, typename ObjectVector< TYPE >::iterator last) |
Erase the range [first, last) from the container. The removed object will be deleted. More... | |
void | clear () |
Clear the entire content of the container and delete all contained objects. More... | |
ObjectVector< TYPE >::reference | operator[] (typename ObjectVector< TYPE >::size_type n) |
Return the reference to the n'th object in the container. More... | |
ObjectVector< TYPE >::const_reference | operator[] (typename ObjectVector< TYPE >::size_type n) const |
Return the const_reference to the n'th object in the container. More... | |
long | index (const ContainedObject *obj) const override |
Return distance of a given object from the beginning of its container It correcponds to the "index" ( from 0 to size()-1 ) If "obj" not fount, return -1. More... | |
ContainedObject const * | containedObject (long dist) const override |
Return const pointer to an object of a given distance (index) More... | |
ContainedObject * | containedObject (long dist) override |
std::ostream & | fillStream (std::ostream &s) const override |
Fill the output stream (ASCII) More... | |
Static Public Member Functions | |
static const CLID & | classID () |
Retrieve class ID. More... | |
Private Attributes | |
std::vector< TYPE * > | m_vector |
ObjectVector is one of the basic Gaudi container classes capable of being registered in Data Stores. It is based on Standard Library (STL) std::vector (see STL Programmer's Guide) ObjectVector has all functions of the std::vector interface, and in addition a number of Gaudi specific functions.
Each object is allowed to belong into a single container only. After inserting the object into the container, it takes over all responsibilities for the object. E.g. erasing the object from its container causes removing the object's pointer from the container and deleting the object itself.
Definition at line 19 of file ContainedObject.h.
typedef std::vector<TYPE*>::const_iterator ObjectVector::const_iterator |
Definition at line 53 of file ObjectVector.h.
typedef std::vector<TYPE*>::const_pointer ObjectVector::const_pointer |
Definition at line 59 of file ObjectVector.h.
typedef std::vector<TYPE*>::const_reference ObjectVector::const_reference |
Definition at line 50 of file ObjectVector.h.
typedef std::vector<TYPE*>::const_reverse_iterator ObjectVector::const_reverse_iterator |
Definition at line 56 of file ObjectVector.h.
typedef TYPE ObjectVector::contained_type |
Definition at line 46 of file ObjectVector.h.
typedef std::vector<TYPE*>::iterator ObjectVector::iterator |
Definition at line 52 of file ObjectVector.h.
typedef std::vector<TYPE*>::pointer ObjectVector::pointer |
Definition at line 58 of file ObjectVector.h.
typedef std::vector<TYPE*>::reference ObjectVector::reference |
Definition at line 49 of file ObjectVector.h.
typedef std::vector<TYPE*>::reverse_iterator ObjectVector::reverse_iterator |
Definition at line 55 of file ObjectVector.h.
typedef std::vector<TYPE*>::value_type ObjectVector::value_type |
Definition at line 47 of file ObjectVector.h.
|
default |
|
delete |
|
inline |
Definition at line 65 of file ObjectVector.h.
|
inlineoverride |
Definition at line 69 of file ObjectVector.h.
|
inlineoverride |
|
inline |
|
inline |
|
inline |
Return an iterator pointing to the beginning of the container.
Definition at line 87 of file ObjectVector.h.
|
inline |
Return a const_iterator pointing to the beginning of the container.
Definition at line 90 of file ObjectVector.h.
|
inline |
Return number of elements for which memory has been allocated It is always greater than or equal to size()
Definition at line 125 of file ObjectVector.h.
|
inlinestatic |
Retrieve class ID.
Definition at line 81 of file ObjectVector.h.
|
inline |
Clear the entire content of the container and delete all contained objects.
Definition at line 232 of file ObjectVector.h.
|
inlineoverride |
|
inlineoverride |
Return const pointer to an object of a given distance (index)
Definition at line 251 of file ObjectVector.h.
|
inlineoverride |
Definition at line 252 of file ObjectVector.h.
|
inline |
|
inline |
Return an iterator pointing to the end of the container.
Definition at line 93 of file ObjectVector.h.
|
inline |
Return a const_iterator pointing to the end of the container.
Definition at line 96 of file ObjectVector.h.
|
inline |
Erase the range [first, last) from the container. The removed object will be deleted.
Definition at line 220 of file ObjectVector.h.
|
inline |
Erase the object at "position" from the container. The removed object will be deleted.
Definition at line 208 of file ObjectVector.h.
|
inlineoverride |
Fill the output stream (ASCII)
Definition at line 255 of file ObjectVector.h.
|
inline |
|
inline |
|
inlineoverride |
Return distance of a given object from the beginning of its container It correcponds to the "index" ( from 0 to size()-1 ) If "obj" not fount, return -1.
Definition at line 245 of file ObjectVector.h.
|
inline |
Insert "value" before "position".
Definition at line 201 of file ObjectVector.h.
|
inline |
|
inlineoverride |
The same as size(), return number of objects in the container.
Definition at line 118 of file ObjectVector.h.
|
delete |
|
inline |
Return the reference to the n'th object in the container.
Definition at line 235 of file ObjectVector.h.
|
inline |
Return the const_reference to the n'th object in the container.
Definition at line 238 of file ObjectVector.h.
|
inline |
pop_back = remove the last element from the container The removed object will be deleted (see the method release)
Definition at line 172 of file ObjectVector.h.
|
inline |
push_back = append = insert a new element at the end of the container
Definition at line 152 of file ObjectVector.h.
|
inline |
Return a reverse_iterator pointing to the beginning of the reversed container.
Definition at line 99 of file ObjectVector.h.
|
inline |
Return a const_reverse_iterator pointing to the beginning of the reversed container.
Definition at line 103 of file ObjectVector.h.
|
inlineoverride |
Release object from the container (the poiter will be removed from the container, but the object itself will remain alive) (see the method pop_back)
Definition at line 184 of file ObjectVector.h.
|
inline |
Return a reverse_iterator pointing to the end of the reversed container.
Definition at line 106 of file ObjectVector.h.
|
inline |
Return a const_reverse_iterator pointing to the end of the reversed container.
Definition at line 109 of file ObjectVector.h.
|
inline |
Reserve place for "value" objects in the container.
If "value" is less than or equal to capacity(), this call has no effect, otherwise, it is a request for allocation of additional memory. If the request is successful, then capacity() is >= n, otherwise, capacity() is unchanged. In either case, size() is unchanged
Definition at line 134 of file ObjectVector.h.
|
inline |
Return the size of the container.
Size means the number of objects stored in the container, independently on the amount of information stored in each object
Definition at line 115 of file ObjectVector.h.
|
private |
Definition at line 268 of file ObjectVector.h.