XMLIdealGeometryESSource

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

#include "FWCore/Framework/interface/ESProducer.h"
#include "FWCore/Framework/interface/EventSetupRecordIntervalFinder.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"

#include "DetectorDescription/Core/interface/DDCompactView.h"
#include "GeometryReaders/XMLIdealGeometryESSource/interface/GeometryConfiguration.h"
#include "Geometry/Records/interface/IdealGeometryRecord.h"
#include "MagneticField/Records/interface/IdealMagneticFieldRecord.h"

#include <memory>
#include <string>

class XMLIdealGeometryESSource : public edm::ESProducer, public edm::EventSetupRecordIntervalFinder {
public:
  XMLIdealGeometryESSource(const edm::ParameterSet &p);
  XMLIdealGeometryESSource(const XMLIdealGeometryESSource &) = delete;
  const XMLIdealGeometryESSource &operator=(const XMLIdealGeometryESSource &) = delete;
  ~XMLIdealGeometryESSource() override;
  std::unique_ptr<DDCompactView> produceGeom(const IdealGeometryRecord &);
  std::unique_ptr<DDCompactView> produceMagField(const IdealMagneticFieldRecord &);
  std::unique_ptr<DDCompactView> produce();

protected:
  void setIntervalFor(const edm::eventsetup::EventSetupRecordKey &,
                      const edm::IOVSyncValue &,
                      edm::ValidityInterval &) override;

private:
  std::string rootNodeName_;
  bool userNS_;
  GeometryConfiguration geoConfig_;
};

#endif