CMS 3D CMS Logo

List of all members | Public Types | Public Member Functions | Static Public Member Functions | Private Attributes
HcalSimParametersESModule Class Reference
Inheritance diagram for HcalSimParametersESModule:
edm::ESProducer edm::ESProxyFactoryProducer edm::eventsetup::DataProxyProvider

Public Types

using ReturnType = std::unique_ptr< HcalSimulationParameters >
 

Public Member Functions

 HcalSimParametersESModule (const edm::ParameterSet &)
 
ReturnType produce (const HcalParametersRcd &)
 
- Public Member Functions inherited from edm::ESProducer
 ESProducer ()
 
 ESProducer (const ESProducer &)=delete
 
ESProxyIndex const * getTokenIndices (unsigned int iIndex) const
 
ESRecordIndex const * getTokenRecordIndices (unsigned int iIndex) const
 
bool hasMayConsumes () const noexcept
 
size_t numberOfTokenIndices (unsigned int iIndex) const
 
ESProducer const & operator= (const ESProducer &)=delete
 
SerialTaskQueueChainqueue ()
 
template<typename Record >
std::optional< std::vector< ESProxyIndex > > updateFromMayConsumes (unsigned int iIndex, const Record &iRecord) const
 
void updateLookup (eventsetup::ESRecordsToProxyIndices const &) final
 
 ~ESProducer () noexcept(false) override
 
- Public Member Functions inherited from edm::ESProxyFactoryProducer
 ESProxyFactoryProducer ()
 
 ESProxyFactoryProducer (const ESProxyFactoryProducer &)=delete
 
const ESProxyFactoryProduceroperator= (const ESProxyFactoryProducer &)=delete
 
 ~ESProxyFactoryProducer () noexcept(false) override
 
- Public Member Functions inherited from edm::eventsetup::DataProxyProvider
void createKeyedProxies (EventSetupRecordKey const &key, unsigned int nConcurrentIOVs)
 
 DataProxyProvider ()
 
 DataProxyProvider (const DataProxyProvider &)=delete
 
const ComponentDescriptiondescription () const
 
void fillRecordsNotAllowingConcurrentIOVs (std::set< EventSetupRecordKey > &recordsNotAllowingConcurrentIOVs) const
 
virtual void initConcurrentIOVs (EventSetupRecordKey const &key, unsigned int nConcurrentIOVs)
 
bool isUsingRecord (const EventSetupRecordKey &key) const
 
KeyedProxieskeyedProxies (const EventSetupRecordKey &iRecordKey, unsigned int iovIndex=0)
 
const DataProxyProvideroperator= (const DataProxyProvider &)=delete
 
void setAppendToDataLabel (const edm::ParameterSet &)
 
void setDescription (const ComponentDescription &iDescription)
 
std::set< EventSetupRecordKeyusingRecords () const
 
virtual ~DataProxyProvider () noexcept(false)
 

Static Public Member Functions

static void fillDescriptions (edm::ConfigurationDescriptions &)
 
- Static Public Member Functions inherited from edm::eventsetup::DataProxyProvider
static void prevalidate (ConfigurationDescriptions &)
 

Private Attributes

edm::ESGetToken< cms::DDCompactView, IdealGeometryRecordcpvTokenDD4hep_
 
edm::ESGetToken< DDCompactView, IdealGeometryRecordcpvTokenDDD_
 
bool fromDD4hep_
 

Additional Inherited Members

- Protected Types inherited from edm::ESProxyFactoryProducer
using EventSetupRecordKey = eventsetup::EventSetupRecordKey
 
- Protected Types inherited from edm::eventsetup::DataProxyProvider
using KeyedProxiesVector = std::vector< std::pair< DataKey, std::shared_ptr< DataProxy > >>
 
- Protected Member Functions inherited from edm::ESProducer
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 >
ESConsumesCollectorT< TRecord > setWhatProduced (T *iThis, TReturn(T ::*iMethod)(const TRecord &), const TArg &iDec, const es::Label &iLabel={})
 
void usesResources (std::vector< std::string > const &)
 
- 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 EventSetupRecordKey &iRecord, std::unique_ptr< eventsetup::ProxyFactoryBase > iFactory, const std::string &iLabel=std::string())
 
KeyedProxiesVector registerProxies (const EventSetupRecordKey &, unsigned int iovIndex) override
 
- Protected Member Functions inherited from edm::eventsetup::DataProxyProvider
template<class T >
void usingRecord ()
 
void usingRecordWithKey (const EventSetupRecordKey &key)
 

Detailed Description

Definition at line 17 of file HcalSimParametersESModule.cc.

Member Typedef Documentation

◆ ReturnType

Definition at line 21 of file HcalSimParametersESModule.cc.

Constructor & Destructor Documentation

◆ HcalSimParametersESModule()

HcalSimParametersESModule::HcalSimParametersESModule ( const edm::ParameterSet ps)

Definition at line 33 of file HcalSimParametersESModule.cc.

References cpvTokenDD4hep_, cpvTokenDDD_, fromDD4hep_, edm::ParameterSet::getParameter(), and edm::ESProducer::setWhatProduced().

33  {
34  fromDD4hep_ = ps.getParameter<bool>("fromDD4hep");
35  auto cc = setWhatProduced(this);
36  if (fromDD4hep_)
38  else
40 
41 #ifdef EDM_ML_DEBUG
42  edm::LogVerbatim("HCalGeom") << "HcalSimParametersESModule::HcalSimParametersESModule called with dd4hep: "
43  << fromDD4hep_;
44 #endif
45 }
Log< level::Info, true > LogVerbatim
auto setWhatProduced(T *iThis, const es::Label &iLabel={})
Definition: ESProducer.h:163
T getParameter(std::string const &) const
Definition: ParameterSet.h:303
edm::ESGetToken< DDCompactView, IdealGeometryRecord > cpvTokenDDD_
Compact representation of the geometrical detector hierarchy.
Definition: DDCompactView.h:81
edm::ESGetToken< cms::DDCompactView, IdealGeometryRecord > cpvTokenDD4hep_

Member Function Documentation

◆ fillDescriptions()

void HcalSimParametersESModule::fillDescriptions ( edm::ConfigurationDescriptions descriptions)
static

Definition at line 47 of file HcalSimParametersESModule.cc.

References edm::ConfigurationDescriptions::add(), and submitPVResolutionJobs::desc.

47  {
49  desc.add<bool>("fromDD4hep", false);
50  descriptions.add("hcalSimulationParameters", desc);
51 }
void add(std::string const &label, ParameterSetDescription const &psetDescription)

◆ produce()

HcalSimParametersESModule::ReturnType HcalSimParametersESModule::produce ( const HcalParametersRcd iRecord)

Definition at line 53 of file HcalSimParametersESModule.cc.

References cpvTokenDD4hep_, cpvTokenDDD_, fromDD4hep_, and edm::eventsetup::DependentRecordImplementation< RecordT, ListT >::getTransientHandle().

53  {
54 #ifdef EDM_ML_DEBUG
55  edm::LogInfo("HCalGeom") << "HcalSimParametersESModule::produce(const HcalParametersRcd& iRecord)";
56 #endif
57 
58  auto ptp = std::make_unique<HcalSimulationParameters>();
60 
61  if (fromDD4hep_) {
62 #ifdef EDM_ML_DEBUG
63  edm::LogVerbatim("HCalGeom") << "HcalSimParametersESModule::Try to access cms::DDCompactView";
64 #endif
66  builder.build(*cpv, *ptp);
67  } else {
69  builder.build(&(*cpv), *ptp);
70  }
71  return ptp;
72 }
ESTransientHandle< ProductT > getTransientHandle(ESGetToken< ProductT, DepRecordT > const &iToken) const
Log< level::Info, true > LogVerbatim
edm::ESGetToken< DDCompactView, IdealGeometryRecord > cpvTokenDDD_
edm::ESGetToken< cms::DDCompactView, IdealGeometryRecord > cpvTokenDD4hep_
Log< level::Info, false > LogInfo

Member Data Documentation

◆ cpvTokenDD4hep_

edm::ESGetToken<cms::DDCompactView, IdealGeometryRecord> HcalSimParametersESModule::cpvTokenDD4hep_
private

Definition at line 29 of file HcalSimParametersESModule.cc.

Referenced by HcalSimParametersESModule(), and produce().

◆ cpvTokenDDD_

edm::ESGetToken<DDCompactView, IdealGeometryRecord> HcalSimParametersESModule::cpvTokenDDD_
private

Definition at line 28 of file HcalSimParametersESModule.cc.

Referenced by HcalSimParametersESModule(), and produce().

◆ fromDD4hep_

bool HcalSimParametersESModule::fromDD4hep_
private

Definition at line 30 of file HcalSimParametersESModule.cc.

Referenced by HcalSimParametersESModule(), and produce().