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 48 49 50 51 52 53 54 55 56 57 58 59 60 61
#include "DQM/EcalCommon/interface/EcalMEFormatter.h"

#include "DQM/EcalCommon/interface/MESetDet2D.h"

#include "DQMServices/Core/interface/DQMStore.h"
#include "FWCore/ServiceRegistry/interface/Service.h"

#include "FWCore/Framework/interface/MakerMacros.h"

#include <limits>

EcalMEFormatter::EcalMEFormatter(edm::ParameterSet const &_ps) : DQMEDHarvester(), ecaldqm::DQWorker() {
  initialize("EcalMEFormatter", _ps);
  edm::ConsumesCollector collector(consumesCollector());
  setTokens(collector);
  setME(_ps.getUntrackedParameterSet("MEs"));
  verbosity_ = _ps.getUntrackedParameter<int>("verbosity", 0);
}

/*static*/
void EcalMEFormatter::fillDescriptions(edm::ConfigurationDescriptions &_descs) {
  edm::ParameterSetDescription desc;
  ecaldqm::DQWorker::fillDescriptions(desc);
  desc.addUntracked<int>("verbosity", 0);

  _descs.addDefault(desc);
}

void EcalMEFormatter::dqmEndLuminosityBlock(DQMStore::IBooker &,
                                            DQMStore::IGetter &_igetter,
                                            edm::LuminosityBlock const &,
                                            edm::EventSetup const &_es) {
  setSetupObjectsEndLumi(_es);
  format_(_igetter, true);
}

void EcalMEFormatter::dqmEndJob(DQMStore::IBooker &, DQMStore::IGetter &_igetter) { format_(_igetter, false); }

void EcalMEFormatter::format_(DQMStore::IGetter &_igetter, bool _checkLumi) {
  std::string failedPath;

  for (auto &mItr : MEs_) {
    if (_checkLumi && !mItr.second->getLumiFlag())
      continue;
    mItr.second->clear();
    if (!mItr.second->retrieve(GetElectronicsMap(), _igetter, &failedPath)) {
      if (verbosity_ > 0)
        edm::LogWarning("EcalDQM") << "Could not find ME " << mItr.first << "@" << failedPath;
      continue;
    }
    if (verbosity_ > 1)
      edm::LogInfo("EcalDQM") << "Retrieved " << mItr.first << " from DQMStore";

    if (dynamic_cast<ecaldqm::MESetDet2D *>(mItr.second.get()))
      formatDet2D_(*mItr.second);
  }
}

void EcalMEFormatter::formatDet2D_(ecaldqm::MESet &_meSet) { return; }

DEFINE_FWK_MODULE(EcalMEFormatter);