MuonGeometryConstantsTester

Line Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42
#include <iostream>
#include <map>

#include "FWCore/Framework/interface/Event.h"
#include "FWCore/Framework/interface/EventSetup.h"
#include "FWCore/Framework/interface/MakerMacros.h"
#include "FWCore/Framework/interface/one/EDAnalyzer.h"
#include "FWCore/MessageLogger/interface/MessageLogger.h"
#include "Geometry/MuonNumbering/interface/MuonGeometryConstants.h"
#include "Geometry/Records/interface/IdealGeometryRecord.h"

class MuonGeometryConstantsTester : public edm::one::EDAnalyzer<> {
public:
  explicit MuonGeometryConstantsTester(const edm::ParameterSet&);

  void beginJob() override {}
  void analyze(edm::Event const& iEvent, edm::EventSetup const&) override;
  void endJob() override {}

private:
  edm::ESGetToken<MuonGeometryConstants, IdealGeometryRecord> token_;
};

MuonGeometryConstantsTester::MuonGeometryConstantsTester(const edm::ParameterSet&) {
  token_ = esConsumes<MuonGeometryConstants, IdealGeometryRecord>(edm::ESInputTag{});
}

void MuonGeometryConstantsTester::analyze(const edm::Event&, const edm::EventSetup& iS) {
  const auto& par = iS.getData(token_);
  const MuonGeometryConstants* parMuon = &par;
  if (parMuon != nullptr) {
    edm::LogVerbatim("MuonNumbering") << "\n\nMuonDDDConstants found with " << parMuon->size() << " contents";
    for (unsigned int k = 0; k < parMuon->size(); ++k) {
      auto entry = parMuon->getEntry(k);
      edm::LogVerbatim("MuonNumbering") << " [" << k << "] " << entry.first << " = " << entry.second;
    }
  } else {
    edm::LogVerbatim("MuonNumbering") << "\n\nMuonDDDConstants not found in Event Setup";
  }
}

DEFINE_FWK_MODULE(MuonGeometryConstantsTester);