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

/*----------------------------------------------------------------------

Toy EDAnalyzer for testing purposes only.
It gets a compact map from the EventSetup and dumps it as a full map.

----------------------------------------------------------------------*/

#include <stdexcept>
#include <string>
#include <iostream>
#include <map>
#include "FWCore/Framework/interface/ESHandle.h"
#include "FWCore/Framework/interface/MakerMacros.h"

#include "CondFormats/DTObjects/test/stubs/DTFullMapPrint.h"

namespace edmtest {

  DTFullMapPrint::DTFullMapPrint(edm::ParameterSet const& p) : es_token(esConsumes()) {}

  DTFullMapPrint::DTFullMapPrint(int i) {}

  void DTFullMapPrint::analyze(const edm::Event& e, const edm::EventSetup& context) {
    using namespace edm::eventsetup;
    // Context is not used.
    std::cout << " I AM IN RUN NUMBER " << e.id().run() << std::endl;
    std::cout << " ---EVENT NUMBER " << e.id().event() << std::endl;
    const auto& dbMap = context.getData(es_token);
    const DTReadOutMapping* ro_map = dbMap.fullMap();
    std::cout << ro_map->mapCellTdc() << " - " << ro_map->mapRobRos() << std::endl;
    std::cout << std::distance(ro_map->begin(), ro_map->end()) << " connections in the map" << std::endl;
    DTReadOutMapping::const_iterator iter = ro_map->begin();
    DTReadOutMapping::const_iterator iend = ro_map->end();
    while (iter != iend) {
      const DTReadOutGeometryLink& link = *iter++;
      std::cout << link.dduId << " " << link.rosId << " " << link.robId << " " << link.tdcId << " " << link.channelId
                << " " << link.wheelId << " " << link.stationId << " " << link.sectorId << " " << link.slId << " "
                << link.layerId << " " << link.cellId << std::endl;
    }
  }
  DEFINE_FWK_MODULE(DTFullMapPrint);
}  // namespace edmtest