CMS 3D CMS Logo

List of all members | Public Types | Public Member Functions | Private Attributes
CaloGeometryEP< T, D > Class Template Reference

#include <CaloGeometryEP.h>

Inheritance diagram for CaloGeometryEP< T, D >:
edm::ESProducer edm::ESProxyFactoryProducer edm::eventsetup::DataProxyProvider

Public Types

using LoaderType = CaloGeometryLoader< T >
 
using PtrType = typename LoaderType::PtrType
 

Public Member Functions

 CaloGeometryEP (const edm::ParameterSet &ps)
 
PtrType produceAligned (const typename T::AlignedRecord &iRecord)
 
 ~CaloGeometryEP () override
 
- Public Member Functions inherited from edm::ESProducer
 ESProducer ()
 
 ESProducer (const ESProducer &)=delete
 
ESProxyIndex const * getTokenIndices (unsigned int iIndex) const
 
ESProducer const & operator= (const ESProducer &)=delete
 
template<typename Record >
void updateFromMayConsumes (unsigned int iIndex, const Record &iRecord)
 
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)
 

Private Attributes

edm::ESGetToken< Alignments, typename T::AlignmentRecord > alignmentsToken_
 
bool applyAlignment_
 
edm::ESGetToken< D, IdealGeometryRecordcpvToken_
 
edm::ESGetToken< Alignments, GlobalPositionRcdglobalsToken_
 

Additional Inherited Members

- Static Public Member Functions inherited from edm::eventsetup::DataProxyProvider
static void prevalidate (ConfigurationDescriptions &)
 
- 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 char *iLabel)
 
template<typename T >
auto setWhatProduced (T *iThis, const es::Label &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={})
 
- 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

template<class T, class D>
class CaloGeometryEP< T, D >

Definition at line 16 of file CaloGeometryEP.h.

Member Typedef Documentation

◆ LoaderType

template<class T , class D >
using CaloGeometryEP< T, D >::LoaderType = CaloGeometryLoader<T>

Definition at line 18 of file CaloGeometryEP.h.

◆ PtrType

template<class T , class D >
using CaloGeometryEP< T, D >::PtrType = typename LoaderType::PtrType

Definition at line 19 of file CaloGeometryEP.h.

Constructor & Destructor Documentation

◆ CaloGeometryEP()

template<class T , class D >
CaloGeometryEP< T, D >::CaloGeometryEP ( const edm::ParameterSet ps)
inline

Definition at line 21 of file CaloGeometryEP.h.

21  : applyAlignment_(ps.getParameter<bool>("applyAlignment")) {
23 
24  if (applyAlignment_) {
25  alignmentsToken_ = cc.template consumesFrom<Alignments, typename T::AlignmentRecord>(edm::ESInputTag{});
26  globalsToken_ = cc.template consumesFrom<Alignments, GlobalPositionRcd>(edm::ESInputTag{});
27  }
28  cpvToken_ = cc.template consumesFrom<D, IdealGeometryRecord>(edm::ESInputTag{});
29  }

References CaloGeometryEP< T, D >::alignmentsToken_, CaloGeometryEP< T, D >::applyAlignment_, CaloGeometryEP< T, D >::cpvToken_, CaloGeometryEP< T, D >::globalsToken_, and edm::ESProducer::setWhatProduced().

◆ ~CaloGeometryEP()

template<class T , class D >
CaloGeometryEP< T, D >::~CaloGeometryEP ( )
inlineoverride

Definition at line 31 of file CaloGeometryEP.h.

31 {}

Member Function Documentation

◆ produceAligned()

template<class T , class D >
PtrType CaloGeometryEP< T, D >::produceAligned ( const typename T::AlignedRecord &  iRecord)
inline

Definition at line 32 of file CaloGeometryEP.h.

32  {
33  const Alignments* alignPtr(nullptr);
34  const Alignments* globalPtr(nullptr);
35  if (applyAlignment_) // get ptr if necessary
36  {
37  const auto& alignments = iRecord.get(alignmentsToken_);
38  // require expected size
39  assert(alignments.m_align.size() == T::numberOfAlignments());
40  alignPtr = &alignments;
41 
42  const auto& globals = iRecord.get(globalsToken_);
43  globalPtr = &globals;
44  }
45  edm::ESTransientHandle<D> cpv = iRecord.getTransientHandle(cpvToken_);
46 
48  return loader.load(cpv.product(), alignPtr, globalPtr);
49  }

References CaloGeometryEP< T, D >::alignmentsToken_, CaloGeometryEP< T, D >::applyAlignment_, cms::cuda::assert(), CaloGeometryEP< T, D >::cpvToken_, CaloGeometryEP< T, D >::globalsToken_, web.browse_db::loader, and edm::ESTransientHandle< T >::product().

Member Data Documentation

◆ alignmentsToken_

template<class T , class D >
edm::ESGetToken<Alignments, typename T::AlignmentRecord> CaloGeometryEP< T, D >::alignmentsToken_
private

◆ applyAlignment_

template<class T , class D >
bool CaloGeometryEP< T, D >::applyAlignment_
private

◆ cpvToken_

template<class T , class D >
edm::ESGetToken<D, IdealGeometryRecord> CaloGeometryEP< T, D >::cpvToken_
private

◆ globalsToken_

template<class T , class D >
edm::ESGetToken<Alignments, GlobalPositionRcd> CaloGeometryEP< T, D >::globalsToken_
private
CaloGeometryEP
Definition: CaloGeometryEP.h:16
edm::ESInputTag
Definition: ESInputTag.h:87
edm::ESTransientHandle::product
T const * product() const
Definition: ESTransientHandle.h:51
CaloGeometryEP::cpvToken_
edm::ESGetToken< D, IdealGeometryRecord > cpvToken_
Definition: CaloGeometryEP.h:54
edm::ESProducer::setWhatProduced
auto setWhatProduced(T *iThis, const es::Label &iLabel={})
Definition: ESProducer.h:138
CaloGeometryEP::alignmentsToken_
edm::ESGetToken< Alignments, typename T::AlignmentRecord > alignmentsToken_
Definition: CaloGeometryEP.h:52
cms::cuda::assert
assert(be >=bs)
edm::es::Label
Definition: es_Label.h:54
cc
CaloGeometryEP::globalsToken_
edm::ESGetToken< Alignments, GlobalPositionRcd > globalsToken_
Definition: CaloGeometryEP.h:53
CaloGeometryEP::LoaderType
CaloGeometryLoader< T > LoaderType
Definition: CaloGeometryEP.h:18
edm::ESTransientHandle
Definition: ESTransientHandle.h:41
CaloGeometryEP::applyAlignment_
bool applyAlignment_
Definition: CaloGeometryEP.h:55
edm::ParameterSet::getParameter
T getParameter(std::string const &) const
web.browse_db.loader
loader
Definition: browse_db.py:18
Alignments
Definition: Alignments.h:10