DDTestCompactView

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 43 44 45 46 47
#include "FWCore/Framework/interface/one/EDAnalyzer.h"
#include "FWCore/Framework/interface/MakerMacros.h"
#include "FWCore/Framework/interface/ESTransientHandle.h"
#include "FWCore/Framework/interface/EventSetup.h"
#include "FWCore/MessageLogger/interface/MessageLogger.h"
#include "Geometry/Records/interface/IdealGeometryRecord.h"
#include "DetectorDescription/DDCMS/interface/DDCompactView.h"

#include <iostream>

using namespace std;
using namespace cms;
using namespace edm;

class DDTestCompactView : public one::EDAnalyzer<> {
public:
  explicit DDTestCompactView(const ParameterSet& iConfig)
      : m_tag(iConfig.getParameter<ESInputTag>("DDDetector")), m_token(esConsumes(m_tag)) {}

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

private:
  const ESInputTag m_tag;
  const ESGetToken<DDCompactView, IdealGeometryRecord> m_token;
};

void DDTestCompactView::analyze(const Event&, const EventSetup& iEventSetup) {
  LogVerbatim("Geometry") << "DDTestCompactView::analyze: " << m_tag;
  ESTransientHandle<DDCompactView> cpv = iEventSetup.getTransientHandle(m_token);

  std::cout << "Get trackerParameters:detIdShifts:\n";
  auto const& vec = cpv->getVector<int>("detIdShifts");
  for (const auto& i : vec)
    std::cout << i << ", ";
  std::cout << ";\ndone\n";

  auto const& v = cpv->detector()->vectors().at("trackerParameters:detIdShifts");
  for (const auto& i : v)
    std::cout << i << ", ";
  std::cout << ";\ndone\n";

  LogVerbatim("Geometry") << "DDTestCompactView::analyze done.";
}

DEFINE_FWK_MODULE(DDTestCompactView);