CMS 3D CMS Logo

List of all members | Public Member Functions
GlobalTrackingGeometryESProducer Class Reference

#include <GlobalTrackingGeometryESProducer.h>

Inheritance diagram for GlobalTrackingGeometryESProducer:
edm::ESProducer edm::ESProxyFactoryProducer edm::eventsetup::DataProxyProvider

Public Member Functions

 GlobalTrackingGeometryESProducer (const edm::ParameterSet &p)
 Constructor. More...
 
std::unique_ptr< GlobalTrackingGeometryproduce (const GlobalTrackingGeometryRecord &record)
 Produce GlobalTrackingGeometry. More...
 
 ~GlobalTrackingGeometryESProducer () override
 Destructor. More...
 
- Public Member Functions inherited from edm::ESProducer
 ESProducer ()
 
 ~ESProducer ()(false) override
 
- Public Member Functions inherited from edm::ESProxyFactoryProducer
 ESProxyFactoryProducer ()
 
void newInterval (const eventsetup::EventSetupRecordKey &iRecordType, const ValidityInterval &iInterval) override
 overrides DataProxyProvider method More...
 
 ~ESProxyFactoryProducer () noexcept(false) override
 
- Public Member Functions inherited from edm::eventsetup::DataProxyProvider
 DataProxyProvider ()
 
const ComponentDescriptiondescription () const
 
bool isUsingRecord (const EventSetupRecordKey &) const
 
const KeyedProxieskeyedProxies (const EventSetupRecordKey &iRecordKey) const
 
void resetProxies (const EventSetupRecordKey &iRecordType)
 
void resetProxiesIfTransient (const EventSetupRecordKey &iRecordType)
 
void setAppendToDataLabel (const edm::ParameterSet &)
 
void setDescription (const ComponentDescription &iDescription)
 
std::set< EventSetupRecordKeyusingRecords () const
 
virtual ~DataProxyProvider () noexcept(false)
 

Additional Inherited Members

- Public Types inherited from edm::eventsetup::DataProxyProvider
typedef std::vector< std::pair< DataKey, edm::propagate_const< std::shared_ptr< DataProxy > > > > KeyedProxies
 
typedef std::vector< EventSetupRecordKeyKeys
 
typedef std::map< EventSetupRecordKey, KeyedProxiesRecordProxies
 
- Static Public Member Functions inherited from edm::eventsetup::DataProxyProvider
static void prevalidate (ConfigurationDescriptions &)
 
- Protected Member Functions inherited from edm::ESProducer
 ESProducer (const ESProducer &)=delete
 
ESProducer const & operator= (const ESProducer &)=delete
 
template<typename T >
auto setWhatProduced (T *iThis, const es::Label &iLabel={})
 
template<typename T >
auto setWhatProduced (T *iThis, const char *iLabel)
 
template<typename T >
auto setWhatProduced (T *iThis, const std::string &iLabel)
 
template<typename T , typename TDecorator >
auto setWhatProduced (T *iThis, const TDecorator &iDec, const es::Label &iLabel={})
 
template<typename T , typename TReturn , typename TRecord >
auto setWhatProduced (T *iThis, TReturn(T::*iMethod)(const TRecord &), const es::Label &iLabel={})
 
template<typename T , typename TReturn , typename TRecord , typename TArg >
ESConsumesCollector setWhatProduced (T *iThis, TReturn(T::*iMethod)(const TRecord &), const TArg &iDec, const es::Label &iLabel={})
 
- Protected Member Functions inherited from edm::ESProxyFactoryProducer
template<class TFactory >
void registerFactory (std::unique_ptr< TFactory > iFactory, const std::string &iLabel=std::string())
 
virtual void registerFactoryWithKey (const eventsetup::EventSetupRecordKey &iRecord, std::unique_ptr< eventsetup::ProxyFactoryBase > iFactory, const std::string &iLabel=std::string())
 
void registerProxies (const eventsetup::EventSetupRecordKey &iRecord, KeyedProxies &aProxyList) override
 override DataProxyProvider method More...
 
- Protected Member Functions inherited from edm::eventsetup::DataProxyProvider
void eraseAll (const EventSetupRecordKey &iRecordKey)
 deletes all the Proxies in aStream More...
 
void invalidateProxies (const EventSetupRecordKey &iRecordKey)
 
template<class T >
void usingRecord ()
 
void usingRecordWithKey (const EventSetupRecordKey &)
 

Detailed Description

Definition at line 20 of file GlobalTrackingGeometryESProducer.h.

Constructor & Destructor Documentation

GlobalTrackingGeometryESProducer::GlobalTrackingGeometryESProducer ( const edm::ParameterSet p)

Constructor.

Definition at line 22 of file GlobalTrackingGeometryESProducer.cc.

22  {
23  setWhatProduced(this);
24 }
auto setWhatProduced(T *iThis, const es::Label &iLabel={})
Definition: ESProducer.h:116
GlobalTrackingGeometryESProducer::~GlobalTrackingGeometryESProducer ( )
override

Destructor.

Definition at line 26 of file GlobalTrackingGeometryESProducer.cc.

26 {}

Member Function Documentation

std::unique_ptr< GlobalTrackingGeometry > GlobalTrackingGeometryESProducer::produce ( const GlobalTrackingGeometryRecord record)

Produce GlobalTrackingGeometry.

Definition at line 29 of file GlobalTrackingGeometryESProducer.cc.

References GlobalTrackingGeometryBuilder::build(), DEFINE_FWK_EVENTSETUP_MODULE, dt, MillePedeFileConverter_cfg::e, edm::eventsetup::DependentRecordImplementation< RecordT, ListT >::getRecord(), edm::ESHandleBase::isValid(), mixOne_premix_on_sim_cfi::me0, edm::ESHandle< T >::product(), and omtf::DataWord64::rpc.

29  {
30 
31  TrackerGeometry const* tk = nullptr;
32  MTDGeometry const* mtd = nullptr;
33  DTGeometry const* dt = nullptr;
34  CSCGeometry const* csc = nullptr;
35  RPCGeometry const* rpc = nullptr;
36  GEMGeometry const* gem = nullptr;
37  ME0Geometry const* me0 = nullptr;
38 
39  try {
41  record.getRecord<TrackerDigiGeometryRecord>().get(tkH);
42  if(tkH.isValid()) {
43  tk = tkH.product();
44  } else {
45  LogWarning("GeometryGlobalTrackingGeometryBuilder") << "No Tracker geometry is available.";
46  }
48  LogWarning("GeometryGlobalTrackingGeometryBuilder") << "No TrackerDigiGeometryRecord is available.";
49  }
50 
51  try {
53  record.getRecord<MTDDigiGeometryRecord>().get(mtdH);
54  if(mtdH.isValid()) {
55  mtd = mtdH.product();
56  } else {
57  LogWarning("GeometryGlobalTrackingGeometryBuilder") << "No MTD geometry is available.";
58  }
60  LogWarning("GeometryGlobalTrackingGeometryBuilder") << "No MTDDigiGeometryRecord is available.";
61  }
62 
63 
64  try {
66  record.getRecord<MuonGeometryRecord>().get(dtH);
67  if(dtH.isValid()) {
68  dt = dtH.product();
69  } else {
70  LogWarning("GeometryGlobalTrackingGeometryBuilder") << "No DT geometry is available.";
71  }
72 
74  record.getRecord<MuonGeometryRecord>().get(cscH);
75  if(cscH.isValid()) {
76  csc = cscH.product();
77  } else {
78  LogWarning("GeometryGlobalTrackingGeometryBuilder") << "No CSC geometry is available.";
79  }
80 
82  record.getRecord<MuonGeometryRecord>().get(rpcH);
83  if(rpcH.isValid()) {
84  rpc = rpcH.product();
85  } else {
86  LogWarning("GeometryGlobalTrackingGeometryBuilder") << "No RPC geometry is available.";
87  }
88 
90  record.getRecord<MuonGeometryRecord>().get(gemH);
91  if(gemH.isValid()) {
92  gem = gemH.product();
93  } else {
94  LogInfo("GeometryGlobalTrackingGeometryBuilder") << "No GEM geometry is available.";
95  }
96 
98  record.getRecord<MuonGeometryRecord>().get(me0H);
99  if(me0H.isValid()) {
100  me0 = me0H.product();
101  } else {
102  LogInfo("GeometryGlobalTrackingGeometryBuilder") << "No ME0 geometry is available.";
103  }
104 
106  LogWarning("GeometryGlobalTrackingGeometryBuilder") << "No MuonGeometryRecord is available.";
107  }
108 
110  return std::unique_ptr<GlobalTrackingGeometry>(builder.build(tk, mtd, dt, csc, rpc, gem, me0));
111 }
float dt
Definition: AMPTWrapper.h:126
A class for AMC data.
Definition: AMC13Event.h:6
Definition: L1Track.h:19
GlobalTrackingGeometry * build(const TrackerGeometry *tk, const MTDGeometry *mtd, const DTGeometry *dt, const CSCGeometry *csc, const RPCGeometry *rpc, const GEMGeometry *gem, const ME0Geometry *me0)
Build the geometry.
bool isValid() const
Definition: ESHandle.h:45
T const * product() const
Definition: ESHandle.h:84