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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
|
// -*- C++ -*-
//
// Package: DetectorDescription/Core
// Class: DDCompactViewMFESProducer
//
/**\class DDCompactViewMFESProducer
Description: Produce DDCompactView
Implementation:
Allow users view a DDDetector as a legacy compact view
*/
//
// Original Author: Ianna Osborne
//
//
#include <memory>
#include "FWCore/Framework/interface/ModuleFactory.h"
#include "FWCore/Framework/interface/ESProducer.h"
#include "FWCore/Framework/interface/ESHandle.h"
#include "FWCore/ParameterSet/interface/ConfigurationDescriptions.h"
#include "FWCore/ParameterSet/interface/ParameterSetDescription.h"
#include "DetectorDescription/DDCMS/interface/DDCompactView.h"
#include "Geometry/Records/interface/IdealGeometryRecord.h"
#include "DetectorDescription/DDCMS/interface/DDDetector.h"
#include "MagneticField/Records/interface/IdealMagneticFieldRecord.h"
#include "DD4hep/Detector.h"
using namespace std;
using namespace cms;
class DDCompactViewMFESProducer : public edm::ESProducer, public edm::EventSetupRecordIntervalFinder {
public:
DDCompactViewMFESProducer(const edm::ParameterSet &);
~DDCompactViewMFESProducer() override;
using ReturnType = unique_ptr<DDCompactView>;
static void fillDescriptions(edm::ConfigurationDescriptions &);
ReturnType produce(const IdealMagneticFieldRecord &);
protected:
void setIntervalFor(const edm::eventsetup::EventSetupRecordKey &,
const edm::IOVSyncValue &,
edm::ValidityInterval &) override;
private:
const edm::ESGetToken<DDDetector, IdealMagneticFieldRecord> m_detToken;
};
DDCompactViewMFESProducer::DDCompactViewMFESProducer(const edm::ParameterSet &iConfig)
: m_detToken(setWhatProduced(this).consumes<DDDetector>(
edm::ESInputTag("", iConfig.getParameter<std::string>("appendToDataLabel")))) {
findingRecord<IdealMagneticFieldRecord>();
}
DDCompactViewMFESProducer::~DDCompactViewMFESProducer() {}
void DDCompactViewMFESProducer::fillDescriptions(edm::ConfigurationDescriptions &descriptions) {
edm::ParameterSetDescription desc;
descriptions.addDefault(desc);
}
DDCompactViewMFESProducer::ReturnType DDCompactViewMFESProducer::produce(const IdealMagneticFieldRecord &iRecord) {
auto product = std::make_unique<DDCompactView>(iRecord.get(m_detToken));
return product;
}
void DDCompactViewMFESProducer::setIntervalFor(const edm::eventsetup::EventSetupRecordKey &,
const edm::IOVSyncValue &iosv,
edm::ValidityInterval &oValidity) {
edm::ValidityInterval infinity(iosv.beginOfTime(), iosv.endOfTime());
oValidity = infinity;
}
DEFINE_FWK_EVENTSETUP_MODULE(DDCompactViewMFESProducer);
|