writeBlobComplex

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
#include "FWCore/ServiceRegistry/interface/Service.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include "FWCore/Framework/interface/Event.h"
#include "CondCore/DBOutputService/interface/PoolDBOutputService.h"
#include "CondFormats/Calibration/interface/BlobComplex.h"
#include "FWCore/Framework/interface/one/EDAnalyzer.h"

#include <iostream>
#include <string>

namespace edm {
  class ParameterSet;
  class Event;
  class EventSetup;
}  // namespace edm

// class decleration
class writeBlobComplex : public edm::one::EDAnalyzer<> {
public:
  explicit writeBlobComplex(const edm::ParameterSet& iConfig);
  ~writeBlobComplex();
  virtual void analyze(const edm::Event&, const edm::EventSetup&);
  virtual void endJob() {}

private:
  std::string m_RecordName;
};

writeBlobComplex::writeBlobComplex(const edm::ParameterSet& iConfig) : m_RecordName("BlobComplexRcd") {}

writeBlobComplex::~writeBlobComplex() { std::cout << "writeBlobComplex::writeBlobComplex" << std::endl; }

void writeBlobComplex::analyze(const edm::Event& evt, const edm::EventSetup& evtSetup) {
  std::cout << "writeBlobComplex::analyze " << std::endl;
  edm::Service<cond::service::PoolDBOutputService> mydbservice;
  if (!mydbservice.isAvailable()) {
    std::cout << "db service unavailable" << std::endl;
    return;
  }
  try {
    BlobComplex me;
    unsigned int serial = 123;
    me.fill(serial);
    std::cout << "writeBlobComplex::about to write " << std::endl;
    mydbservice->writeOneIOV(me, mydbservice->currentTime(), m_RecordName);
  } catch (const std::exception& er) {
    std::cout << "caught std::exception " << er.what() << std::endl;
    throw er;
  }
}
#include "FWCore/Framework/interface/MakerMacros.h"
DEFINE_FWK_MODULE(writeBlobComplex);