EZArrayFL

Macros

Line Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77
#ifndef GEOMETRY_CALOGEOMETRY_EZArrayFL_H
#define GEOMETRY_CALOGEOMETRY_EZArrayFL_H 1

#include "Geometry/CaloGeometry/interface/EZMgrFL.h"

/** \class EZArrayFL<T>

  stl-vector-LIKE Class designed to allow many small fixed-length
  containers to have a common memory managed by a single higher-level object.

  It has the usual common iterators (begin, end) and functions (size, capacity, etc)
  but is NOT actually an STL-vector.

  It practices 'on-demand', or 'lazy evaluation', only allocating
  memory when requested.

*/

template <class T>
class EZArrayFL {
public:
  typedef EZMgrFL<T> MgrType;
  typedef typename MgrType::iterator iterator;
  typedef typename MgrType::const_iterator const_iterator;
  typedef typename MgrType::reference reference;
  typedef typename MgrType::const_reference const_reference;
  typedef typename MgrType::size_type size_type;
  typedef typename MgrType::value_type value_type;

  EZArrayFL() : m_begin(), m_mgr() {}

  EZArrayFL(MgrType* mgr) : m_begin(), m_mgr(mgr) {}

  EZArrayFL(MgrType* mgr, const_iterator start, const_iterator finis)
      : m_begin(0 == finis - start ? iterator() : mgr->assign()), m_mgr(mgr) {
    assert((finis - start) == m_mgr->subSize());
    iterator i(begin());
    for (const_iterator ic(start); ic != finis; ++ic) {
      (*i) = (*ic);
    }
  }

  void resize() { assign(); }

  void assign(const T& t = T()) {
    assert(iterator() == m_begin);
    m_begin = m_mgr->assign(t);
  }

  const_iterator begin() const { return m_begin; }
  const_iterator end() const { return m_begin + m_mgr->subSize(); }

  reference operator[](const unsigned int i) {
    if (iterator() == m_begin)
      assign();
    return *(m_begin + i);
  }

  const_reference operator[](const unsigned int i) const { return *(m_begin + i); }

  bool uninitialized() const { return (iterator() == m_begin); }

  bool empty() const { return (0 == size()); }

  size_type size() const { return m_mgr->subSize(); }

  size_type capacity() const { return size(); }

protected:
private:
  //EZArrayFL( const EZArrayFL& ) ; //stop
  //EZArrayFL& operator=( const EZArrayFL& ) ; //stop
  iterator m_begin;
  MgrType* m_mgr;
};

#endif