The Gaudi Framework  v33r0 (d5ea422b)
ObjectVector.h
Go to the documentation of this file.
1 /***********************************************************************************\
2 * (c) Copyright 1998-2019 CERN for the benefit of the LHCb and ATLAS collaborations *
3 * *
4 * This software is distributed under the terms of the Apache version 2 licence, *
5 * copied verbatim in the file "LICENSE". *
6 * *
7 * In applying this licence, CERN does not waive the privileges and immunities *
8 * granted to it by virtue of its status as an Intergovernmental Organization *
9 * or submit itself to any jurisdiction. *
10 \***********************************************************************************/
11 #ifndef GAUDIKERNEL_OBJECTVECTOR_H
12 #define GAUDIKERNEL_OBJECTVECTOR_H
13 
14 // Include files
15 #include "GaudiKernel/ClassID.h"
16 #include "GaudiKernel/Kernel.h"
19 
20 #include <iomanip>
21 #include <vector>
22 
23 // Definition of the CLID for this class defined in ClassID.h
24 // static const CLID CLID_ObjectList = (1<<17); // ObjectVector (bit 17 set)
25 
45 template <class TYPE>
46 class ObjectVector : public ObjectContainerBase {
47 
48 public:
49  typedef TYPE contained_type;
51 
54 
57 
60 #ifdef _WIN32
61  typedef typename std::vector<TYPE*>::_Tptr pointer;
63 #else
66 #endif
67 
68 public:
70  ObjectVector() = default;
71  ObjectVector( const ObjectVector<TYPE>& ) = delete;
72  ObjectVector& operator=( const ObjectVector<TYPE>& ) = delete;
73  ObjectVector( ObjectVector&& rhs ) : ObjectContainerBase( std::move( rhs ) ), m_vector{std::move( rhs.m_vector )} {
74  std::for_each( begin(), end(), [this]( TYPE* obj ) { obj->setParent( this ); } );
75  }
76 
78  ~ObjectVector() override {
79  for ( auto& i : m_vector ) {
80  // Set the back pointer to 0 to avoid repetitional searching
81  // for the object in the container, and deleting the object
82  i->setParent( nullptr );
83  delete i;
84  }
85  }
86 
88  const CLID& clID() const override { return ObjectVector<TYPE>::classID(); }
90  static const CLID& classID() {
91  static const CLID clid = TYPE::classID() + CLID_ObjectVector;
92  return clid;
93  }
94 
97 
99  typename ObjectVector<TYPE>::const_iterator begin() const { return m_vector.begin(); }
100 
102  typename ObjectVector<TYPE>::iterator end() { return m_vector.end(); }
103 
105  typename ObjectVector<TYPE>::const_iterator end() const { return m_vector.end(); }
106 
109 
113 
116 
119 
124  typename ObjectVector<TYPE>::size_type size() const { return m_vector.size(); }
125 
127  typename ObjectVector<TYPE>::size_type numberOfObjects() const override { return m_vector.size(); }
128 
131 
135 
143  void reserve( typename ObjectVector<TYPE>::size_type value ) { m_vector.reserve( value ); }
144 
146  bool empty() const { return m_vector.empty(); }
147 
150 
153 
156 
158  typename ObjectVector<TYPE>::const_reference back() const { return m_vector.back(); }
159 
162  if ( value->parent() ) { const_cast<ObjectContainerBase*>( value->parent() )->remove( value ); }
163  value->setParent( this );
164  m_vector.push_back( value );
165  }
166 
168  long add( ContainedObject* pObject ) override {
169  try {
170  auto ptr = dynamic_cast<typename ObjectVector<TYPE>::value_type>( pObject );
171  if ( ptr ) {
172  push_back( ptr );
173  return m_vector.size() - 1;
174  }
175  } catch ( ... ) {}
176  return -1;
177  }
178 
181  void pop_back() {
182  auto position = m_vector.back();
183  // Set the back pointer to 0 to avoid repetitional searching
184  // for the object in the container, and deleting the object
185  position->setParent( nullptr );
186  delete position;
187  // Removing from the container itself
188  m_vector.pop_back();
189  }
190 
193  long remove( ContainedObject* value ) override {
194  // Find the object of the value value
195  auto i = std::find_if( begin(), end(), [&]( const ContainedObject* j ) { return j == value; } );
196  if ( i == end() ) {
197  // Object cannot be released from the conatiner,
198  // as it is not contained in it
199  return 0;
200  }
201  long idx = std::distance( begin(), i );
202  // Set the back pointer to 0 to avoid repetitional searching
203  // for the object in the container and deleting the object
204  ( *i )->setParent( nullptr );
205  erase( i );
206  return idx;
207  }
208 
211  typename ObjectVector<TYPE>::const_reference value ) {
212  value->setParent( this );
213  return m_vector.insert( position, value );
214  }
215 
217  void erase( typename ObjectVector<TYPE>::iterator position ) {
218  if ( ( *position )->parent() ) {
219  // Set the back pointer to 0 to avoid repetitional searching
220  // for the object in the container, and deleting the object
221  ( *position )->setParent( nullptr );
222  delete *position;
223  }
224  // Removing from the container itself
225  m_vector.erase( position );
226  }
227 
229  void erase( typename ObjectVector<TYPE>::iterator first, typename ObjectVector<TYPE>::iterator last ) {
230  for ( auto i = first; i != last; i++ ) {
231  // Set the back pointer to 0 to avoid repetitional searching
232  // for the object in the container, and deleting the object
233  ( *i )->setParent( nullptr );
234  delete *i;
235  }
236  // Removing from the container itself
237  m_vector.erase( first, last );
238  }
239 
241  void clear() { erase( begin(), end() ); }
242 
245 
248  return m_vector[n];
249  }
250 
254  long index( const ContainedObject* obj ) const override {
255  auto i = std::find_if( begin(), end(), [&]( const ContainedObject* o ) { return o == obj; } );
256  return i != end() ? std::distance( begin(), i ) : -1;
257  }
258 
260  ContainedObject const* containedObject( long dist ) const override { return m_vector[dist]; }
261  ContainedObject* containedObject( long dist ) override { return m_vector[dist]; }
262 
264  std::ostream& fillStream( std::ostream& s ) const override {
265  s << "class ObjectVector : size = " << std::setw( 12 ) << size() << "\n";
266  // Output the base class
267  // ObjectContainerBase::fillStream(s);
268  if ( !empty() ) {
269  s << "\nContents of the STL vector :";
270  long count = 0;
271  for ( const auto& i : m_vector ) { s << "\nIndex " << std::setw( 12 ) << count++ << " of object of type " << *i; }
272  }
273  return s;
274  }
275 
276 private:
279 };
280 
281 #endif // GAUDIKERNEL_OBJECTVECTOR_H
ObjectVector< TYPE >::iterator end()
Return an iterator pointing to the end of the container.
Definition: ObjectVector.h:102
void clear()
Clear the entire content of the container and delete all contained objects.
Definition: ObjectVector.h:241
T empty(T... args)
T distance(T... args)
long add(ContainedObject *pObject) override
Add an object to the container.
Definition: ObjectVector.h:168
ObjectVector< TYPE >::const_iterator end() const
Return a const_iterator pointing to the end of the container.
Definition: ObjectVector.h:105
size_t size_type
size_type, to conform the STL container interface
ObjectVector< TYPE >::reference back()
Return reference to the last element.
Definition: ObjectVector.h:155
ObjectVector< TYPE >::iterator begin()
Return an iterator pointing to the beginning of the container.
Definition: ObjectVector.h:96
T rend(T... args)
T front(T... args)
void erase(typename ObjectVector< TYPE >::iterator position)
Erase the object at "position" from the container. The removed object will be deleted.
Definition: ObjectVector.h:217
ObjectVector< TYPE >::reverse_iterator rbegin()
Return a reverse_iterator pointing to the beginning of the reversed container.
Definition: ObjectVector.h:108
std::vector< TYPE * >::const_iterator const_iterator
Definition: ObjectVector.h:56
std::vector< TYPE * > m_vector
The STL vector itself.
Definition: ObjectVector.h:278
void push_back(typename ObjectVector< TYPE >::const_reference value)
push_back = append = insert a new element at the end of the container
Definition: ObjectVector.h:161
ObjectVector is one of the basic Gaudi container classes capable of being registered in Data Stores.
ObjectVector< TYPE >::size_type capacity() const
Return number of elements for which memory has been allocated It is always greater than or equal to s...
Definition: ObjectVector.h:134
STL namespace.
ObjectVector< TYPE >::const_reverse_iterator rbegin() const
Return a const_reverse_iterator pointing to the beginning of the reversed container.
Definition: ObjectVector.h:112
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.
Definition: ObjectVector.h:229
std::vector< TYPE * >::const_reference const_reference
Definition: ObjectVector.h:53
T end(T... args)
std::vector< TYPE * >::const_pointer const_pointer
Definition: ObjectVector.h:65
long remove(ContainedObject *value) override
Release object from the container (the poiter will be removed from the container, but the object itse...
Definition: ObjectVector.h:193
ObjectVector< TYPE >::const_iterator begin() const
Return a const_iterator pointing to the beginning of the container.
Definition: ObjectVector.h:99
T setw(T... args)
ObjectVector(ObjectVector &&rhs)
Definition: ObjectVector.h:73
ObjectVector< TYPE >::size_type size() const
Return the size of the container.
Definition: ObjectVector.h:124
std::vector< TYPE * >::const_reverse_iterator const_reverse_iterator
Definition: ObjectVector.h:59
ObjectVector< TYPE >::reference front()
Return reference to the first element.
Definition: ObjectVector.h:149
ObjectVector & operator=(const ObjectVector< TYPE > &)=delete
T push_back(T... args)
bool empty() const
Return true if the size of the container is 0.
Definition: ObjectVector.h:146
std::vector< TYPE * >::reverse_iterator reverse_iterator
Definition: ObjectVector.h:58
ObjectVector< TYPE >::reference operator[](typename ObjectVector< TYPE >::size_type n)
Return the reference to the n'th object in the container.
Definition: ObjectVector.h:244
std::ostream & fillStream(std::ostream &s) const override
Fill the output stream (ASCII)
Definition: ObjectVector.h:264
ObjectVector()=default
Constructors.
T erase(T... args)
T pop_back(T... args)
T capacity(T... args)
std::vector< TYPE * >::iterator iterator
Definition: ObjectVector.h:55
ObjectVector< TYPE >::const_reference operator[](typename ObjectVector< TYPE >::size_type n) const
Return the const_reference to the n'th object in the container.
Definition: ObjectVector.h:247
ObjectVector< TYPE >::const_reference front() const
Return const_reference to the first element.
Definition: ObjectVector.h:152
~ObjectVector() override
Destructor.
Definition: ObjectVector.h:78
unsigned int CLID
Class ID definition.
Definition: ClassID.h:18
ObjectVector< TYPE >::const_reverse_iterator rend() const
Return a const_reverse_iterator pointing to the end of the reversed container.
Definition: ObjectVector.h:118
void reserve(typename ObjectVector< TYPE >::size_type value)
Reserve place for "value" objects in the container.
Definition: ObjectVector.h:143
T move(T... args)
ObjectVector< TYPE >::size_type numberOfObjects() const override
The same as size(), return number of objects in the container.
Definition: ObjectVector.h:127
std::vector< TYPE * >::reference reference
Definition: ObjectVector.h:52
ObjectVector< TYPE >::iterator insert(typename ObjectVector< TYPE >::iterator position, typename ObjectVector< TYPE >::const_reference value)
Insert "value" before "position".
Definition: ObjectVector.h:210
T insert(T... args)
All classes that their objects may be contained in an LHCb ObjectContainer (e.g.
T find_if(T... args)
T size(T... args)
ObjectVector< TYPE >::size_type max_size() const
Return the largest possible size of the container.
Definition: ObjectVector.h:130
STL class.
std::vector< TYPE * >::value_type value_type
Definition: ObjectVector.h:50
T begin(T... args)
ContainedObject const * containedObject(long dist) const override
Return const pointer to an object of a given distance (index)
Definition: ObjectVector.h:260
std::vector< TYPE * >::pointer pointer
Definition: ObjectVector.h:64
T max_size(T... args)
long index(const ContainedObject *obj) const override
Return distance of a given object from the beginning of its container It correcponds to the "index" (...
Definition: ObjectVector.h:254
T back(T... args)
string s
Definition: gaudirun.py:328
TYPE contained_type
Definition: ObjectVector.h:49
ObjectContainerBase is the base class for Gaudi container classes.
ObjectVector< TYPE >::reverse_iterator rend()
Return a reverse_iterator pointing to the end of the reversed container.
Definition: ObjectVector.h:115
ObjectVector< TYPE >::const_reference back() const
Return const_reference to the last element.
Definition: ObjectVector.h:158
ContainedObject * containedObject(long dist) override
Definition: ObjectVector.h:261
const CLID & clID() const override
Retrieve class ID.
Definition: ObjectVector.h:88
T for_each(T... args)
STL class.
static const CLID & classID()
Retrieve class ID.
Definition: ObjectVector.h:90
void pop_back()
pop_back = remove the last element from the container The removed object will be deleted (see the met...
Definition: ObjectVector.h:181
T reserve(T... args)
T rbegin(T... args)