Back to home page

Project CMSSW displayed by LXR

 
 

    


File indexing completed on 2024-04-06 12:29:58

0001 // system include files
0002 #include <string>
0003 
0004 // user include files
0005 #include "SimG4Core/SensitiveDetector/interface/SensitiveDetectorMakerBase.h"
0006 #include "SimG4Core/Notification/interface/SimActivityRegistryEnroller.h"
0007 #include "SimG4Core/SensitiveDetector/interface/SensitiveDetectorPluginFactory.h"
0008 
0009 #include "SimG4CMS/EcalTestBeam/interface/EcalTBH4BeamSD.h"
0010 
0011 #include "FWCore/Framework/interface/EventSetup.h"
0012 #include "FWCore/Framework/interface/ConsumesCollector.h"
0013 #include "FWCore/Utilities/interface/ESGetToken.h"
0014 #include "FWCore/PluginManager/interface/ModuleDef.h"
0015 #include "FWCore/ParameterSet/interface/ParameterSet.h"
0016 
0017 class EcalTBH4BeamDetectorBuilder : public SensitiveDetectorMakerBase {
0018 public:
0019   explicit EcalTBH4BeamDetectorBuilder(const edm::ParameterSet& p, edm::ConsumesCollector cc) {}
0020 
0021   std::unique_ptr<SensitiveDetector> make(const std::string& iname,
0022                                           const SensitiveDetectorCatalog& clg,
0023                                           const edm::ParameterSet& p,
0024                                           const SimTrackManager* man,
0025                                           SimActivityRegistry& reg) const final {
0026     auto sd = std::make_unique<EcalTBH4BeamSD>(iname, clg, p, man);
0027     SimActivityRegistryEnroller::enroll(reg, sd.get());
0028     return sd;
0029   }
0030 };
0031 
0032 typedef EcalTBH4BeamSD EcalTBH4BeamDetector;
0033 DEFINE_SENSITIVEDETECTORBUILDER(EcalTBH4BeamDetectorBuilder, EcalTBH4BeamDetector);