DataFrame

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
#ifndef DataFormats_Common_DataFrame_h
#define DataFormats_Common_DataFrame_h

class TestDataFrame;
namespace edm {

  class DataFrameContainer;

  /* a proxy to a fixed size array of 16bit words belonging to
   * a "channel" identified by an 32bit id
   *
   * FIXME interface to be finalized once use-cases fully identified
   * 
   */
  class DataFrame {
  public:
    typedef unsigned int size_type;  // for persistency
    typedef unsigned int id_type;
    typedef unsigned short data_type;
    typedef data_type *iterator;
    typedef data_type const *const_iterator;

    constexpr inline DataFrame() : m_id(0), m_data(nullptr), m_size(0) {}
    constexpr inline DataFrame(id_type i, data_type const *idata, size_type isize)
        : m_id(i), m_data(idata), m_size(isize) {}

    inline DataFrame(DataFrameContainer const &icont, size_type i);
    inline void set(DataFrameContainer const &icont, size_type i);
    constexpr inline data_type &operator[](size_type i) { return data()[i]; }

    constexpr inline data_type operator[](size_type i) const { return m_data[i]; }

    constexpr inline iterator begin() { return data(); }

    constexpr inline iterator end() { return data() + m_size; }

    constexpr inline const_iterator begin() const { return m_data; }

    constexpr inline const_iterator end() const { return m_data + m_size; }

    constexpr inline id_type id() const { return m_id; }

    constexpr inline size_type size() const { return m_size; }

  private:
    //for testing
    friend class ::TestDataFrame;

    constexpr data_type *data() { return const_cast<data_type *>(m_data); }

    id_type m_id;
    data_type const *m_data;
    size_type m_size;
  };
}  // namespace edm

#endif  // DataFormats_Common_DataFrame_h