EcalCondHandler

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

#include "CondCore/PopCon/interface/PopConSourceHandler.h"
#include "CondTools/Ecal/interface/EcalCondHeader.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include <string>

template <typename Payload, typename XMLTranslator>
class EcalCondHandler : public popcon::PopConSourceHandler<Payload> {
public:
  EcalCondHandler(const edm::ParameterSet& ps)
      : xmlFileSource_(ps.getUntrackedParameter<std::string>("xmlFile")),
        since_(ps.getUntrackedParameter<long long>("since")) {}

  void getNewObjects() override {
    EcalCondHeader header;
    Payload* payload = new Payload;
    XMLTranslator::readXML(xmlFileSource_, header, *payload);
    popcon::PopConSourceHandler<Payload>::m_to_transfer.push_back(std::make_pair(payload, since_));
  }

  std::string id() const override { return std::string("dummy"); }

private:
  std::string xmlFileSource_;
  long long since_;
};

#endif

// Configure (x)emacs for this file ...
// Local Variables:
// mode:c++
// compile-command: "scram b"
// End