ToRM

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

#include "DataFormats/Common/interface/DetSetVectorNew.h"
#include "DataFormats/Common/interface/RangeMap.h"
// #include "DataFormats/Common/interface/DetSetAlgorithm.h"

#include <algorithm>

//FIXME remove New when ready
namespace edmNew {

  namespace dstvdetails {
    // copy from DS to RM
    template <typename B>
    struct ToRM {
      ToRM(edm::RangeMap<det_id_type, edm::OwnVector<B> >& irm) : rm(&irm) {}
      edm::RangeMap<det_id_type, edm::OwnVector<B> >* rm;
      template <typename T>
      void operator()(edmNew::DetSet<T> const& ds) {
        // make it easy
        // std::vector<T const *> v(ds.size());
        //std::transform(ds.begin(),ds.end(),v.begin(),dstvdetails::Pointer());
        if (!ds.empty())
          rm->put(ds.id(), ds.begin(), ds.end());
      }
    };
  }  // namespace dstvdetails

  // copy from DSTV to RangeMap
  template <typename T, typename B>
  void copy(DetSetVector<T> const& dstv, edm::RangeMap<det_id_type, edm::OwnVector<B> >& rm) {
    dstvdetails::ToRM<B> torm(rm);
    std::for_each(dstv.begin(), dstv.end(), torm);
  }

}  // namespace edmNew

#endif  // DataFormats_Common_DetSet2RangeMap_h