95 : m_tag(iConfig.getParameter<
ESInputTag>(
"DDDetector")),
96 m_alignmentsLabel(iConfig.getParameter<
string>(
"alignmentsLabel")),
97 m_myLabel(iConfig.getParameter<
string>(
"appendToDataLabel")),
98 m_attribute(iConfig.getParameter<
string>(
"attribute")),
99 m_value(iConfig.getParameter<
string>(
"value")),
100 m_fromDDD(iConfig.getParameter<
bool>(
"fromDDD")) {
143 if (alignments.empty() && alignmentErrors.empty() && globalPosition.empty()) {
144 edm::LogInfo(
"Config") <<
"@SUB=DTGeometryRecord::produce" 145 <<
"Alignment and global position errors";
auto setWhatProduced(T *iThis, const es::Label &iLabel={})
T getParameter(std::string const &) const
edm::ESGetToken< MuonGeometryConstants, IdealGeometryRecord > m_mdcToken
Class to update a given geometry with a set of alignments.
dd4hep::SpecParRefs DDSpecParRefs
uint32_t cc[maxCellsPerHit]
edm::ESGetToken< AlignmentErrorsExtended, DTAlignmentErrorExtendedRcd > m_alignmentErrorsToken
const string m_alignmentsLabel
void build(DTGeometry &, const DDDetector *, const MuonGeometryConstants &, const dd4hep::SpecParRefs &)
ESProductHost< DTGeometry, MuonNumberingRecord, DTRecoGeometryRcd > HostType
dd4hep::Detector Detector
void applyAlignments(const C *geometry, const Alignments *alignments, const AlignmentErrorsExtended *alignmentErrors, const AlignTransform &globalCoordinates)
dd4hep::SpecParRegistry DDSpecParRegistry
shared_ptr< DTGeometry > ReturnType
edm::ESGetToken< Alignments, GlobalPositionRcd > m_globalPositionToken
ReusableObjectHolder< HostType > m_holder
#define DEFINE_FWK_EVENTSETUP_MODULE(type)
std::shared_ptr< T > makeOrGet(FM &&iMakeFunc)
Takes an object from the queue if one is available, or creates one using iMakeFunc.
Namespace of DDCMS conversion namespace.
Log< level::Info, false > LogInfo
ReturnType produce(const MuonGeometryRecord &record)
~DTGeometryESProducer() override
edm::ESGetToken< DDSpecParRegistry, DDSpecParRegistryRcd > m_registryToken
T const * product() const
void setupDBGeometry(DTRecoGeometryRcd const &, shared_ptr< HostType > &)
DTGeometryESProducer(const ParameterSet &)
static std::atomic< unsigned int > counter
void setupGeometry(MuonNumberingRecord const &, shared_ptr< HostType > &)
const AlignTransform & DetectorGlobalPosition(const Alignments &allGlobals, const DetId &id)
edm::ESGetToken< DDDetector, IdealGeometryRecord > m_cpvToken
edm::ESGetToken< Alignments, DTAlignmentRcd > m_alignmentsToken