SimG4CMS
ShowerLibraryProducer
plugins
HFChamberSensitiveDetectorBuilder.cc
Go to the documentation of this file.
1
// system include files
2
3
// user include files
4
#include "
SimG4Core/SensitiveDetector/interface/SensitiveDetectorMakerBase.h
"
5
#include "
SimG4Core/Notification/interface/SimActivityRegistryEnroller.h
"
6
#include "
SimG4Core/SensitiveDetector/interface/SensitiveDetectorPluginFactory.h
"
7
8
#include "
SimG4CMS/ShowerLibraryProducer/interface/HFChamberSD.h
"
9
10
#include "
FWCore/Framework/interface/EventSetup.h
"
11
#include "
FWCore/Framework/interface/ConsumesCollector.h
"
12
#include "
FWCore/Utilities/interface/ESGetToken.h
"
13
#include "
FWCore/PluginManager/interface/ModuleDef.h
"
14
#include "
FWCore/ParameterSet/interface/ParameterSet.h
"
15
16
class
HFChamberSensitiveDetectorBuilder
:
public
SensitiveDetectorMakerBase
{
17
public
:
18
explicit
HFChamberSensitiveDetectorBuilder
(
edm::ParameterSet
const
&
p
,
edm::ConsumesCollector
cc) {}
19
20
void
beginRun
(
const
edm::EventSetup
& es)
final
{}
21
std::unique_ptr<SensitiveDetector>
make
(
const
std::string
& iname,
22
const
SensitiveDetectorCatalog
& clg,
23
const
edm::ParameterSet
&
p
,
24
const
SimTrackManager
* man,
25
SimActivityRegistry
& reg)
const
final
{
26
auto
sd = std::make_unique<HFChamberSD>(iname, clg, man);
27
SimActivityRegistryEnroller::enroll
(reg, sd.get());
28
return
sd;
29
}
30
};
31
32
typedef
HFChamberSD
HFChamberSensitiveDetector
;
33
DEFINE_SENSITIVEDETECTORBUILDER
(
HFChamberSensitiveDetectorBuilder
,
HFChamberSensitiveDetector
);
HFChamberSensitiveDetectorBuilder
Definition:
HFChamberSensitiveDetectorBuilder.cc:16
EventSetup.h
SensitiveDetectorMakerBase
Definition:
SensitiveDetectorMakerBase.h:28
AlCaHLTBitMon_QueryRunRegistry.string
string string
Definition:
AlCaHLTBitMon_QueryRunRegistry.py:256
ParameterSet.h
SimActivityRegistryEnroller::enroll
static void enroll(SimActivityRegistry &iReg, T *iObj)
Definition:
SimActivityRegistryEnroller.h:50
DEFINE_SENSITIVEDETECTORBUILDER
#define DEFINE_SENSITIVEDETECTORBUILDER(type, name)
Definition:
SensitiveDetectorPluginFactory.h:21
HFChamberSensitiveDetectorBuilder::beginRun
void beginRun(const edm::EventSetup &es) final
Definition:
HFChamberSensitiveDetectorBuilder.cc:20
SensitiveDetectorPluginFactory.h
edm::EventSetup
Definition:
EventSetup.h:59
SensitiveDetectorCatalog
Definition:
SensitiveDetectorCatalog.h:10
HFChamberSD.h
HFChamberSensitiveDetectorBuilder::HFChamberSensitiveDetectorBuilder
HFChamberSensitiveDetectorBuilder(edm::ParameterSet const &p, edm::ConsumesCollector cc)
Definition:
HFChamberSensitiveDetectorBuilder.cc:18
SimActivityRegistryEnroller.h
HFChamberSensitiveDetector
HFChamberSD HFChamberSensitiveDetector
Definition:
HFChamberSensitiveDetectorBuilder.cc:32
edm::ParameterSet
Definition:
ParameterSet.h:47
SimActivityRegistry
Definition:
SimActivityRegistry.h:39
HFChamberSD
Definition:
HFChamberSD.h:21
HFChamberSensitiveDetectorBuilder::make
std::unique_ptr< SensitiveDetector > make(const std::string &iname, const SensitiveDetectorCatalog &clg, const edm::ParameterSet &p, const SimTrackManager *man, SimActivityRegistry ®) const final
Definition:
HFChamberSensitiveDetectorBuilder.cc:21
ModuleDef.h
ConsumesCollector.h
ESGetToken.h
SensitiveDetectorMakerBase.h
AlCaHLTBitMon_ParallelJobs.p
def p
Definition:
AlCaHLTBitMon_ParallelJobs.py:153
edm::ConsumesCollector
Definition:
ConsumesCollector.h:45
SimTrackManager
Definition:
SimTrackManager.h:35
Generated for CMSSW Reference Manual by
1.8.14