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
#include "EcalElectronicsMappingBuilder.h"
#include "DataFormats/EcalDetId/interface/EEDetId.h"
#include "DataFormats/EcalDetId/interface/EcalElectronicsId.h"
#include "DataFormats/EcalDetId/interface/EcalTriggerElectronicsId.h"

#include "FWCore/Framework/interface/EventSetup.h"
#include "CondFormats/DataRecord/interface/EcalMappingElectronicsRcd.h"

EcalElectronicsMappingBuilder::EcalElectronicsMappingBuilder(const edm::ParameterSet&)
    : eeToken_{
          setWhatProduced(this).consumesFrom<EcalMappingElectronics, EcalMappingElectronicsRcd>(edm::ESInputTag{})} {}

// ------------ method called to produce the data  ------------
EcalElectronicsMappingBuilder::ReturnType EcalElectronicsMappingBuilder::produce(const EcalMappingRcd& iRecord) {
  auto prod = std::make_unique<EcalElectronicsMapping>();

  const auto& item = iRecord.get(eeToken_);

  const std::vector<EcalMappingElement>& ee = item.endcapItems();
  FillFromDatabase(ee, *prod);
  return prod;
}

void EcalElectronicsMappingBuilder::FillFromDatabase(const std::vector<EcalMappingElement>& ee,
                                                     EcalElectronicsMapping& theMap) {
  for (unsigned int i = 0; i < ee.size(); i++) {
    if (ee[i].electronicsid == 0)
      continue;
    if (ee[i].triggerid == 0)
      continue;
    theMap.assign(EEDetId::unhashIndex(i).rawId(), ee[i].electronicsid, ee[i].triggerid);
  }
  return;
}