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
#include "DQM/EcalMonitorTasks/interface/DQWorkerTask.h"

#include "FWCore/Utilities/interface/Exception.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include "FWCore/ParameterSet/interface/ParameterSetDescription.h"

namespace ecaldqm {
  DQWorkerTask::DQWorkerTask() : DQWorker() {}

  /*static*/
  void DQWorkerTask::fillDescriptions(edm::ParameterSetDescription& _desc) { DQWorker::fillDescriptions(_desc); }

  void DQWorkerTask::setME(edm::ParameterSet const& _ps) {
    DQWorker::setME(_ps);

    for (MESetCollection::iterator mItr(MEs_.begin()); mItr != MEs_.end(); ++mItr) {
      if (willConvertToEDM_)
        mItr->second->setBatchMode();
    }
  }

  void DependencySet::formSequenceFragment_(Dependency const& _d,
                                            std::vector<Collections>& _sequence,
                                            std::vector<Collections>::iterator _maxPos) const {
    Collections col(_d.dependant);
    std::vector<Collections>::iterator pos(std::find(_sequence.begin(), _sequence.end(), col));
    if (pos == _sequence.end())
      _sequence.insert(_maxPos, col);
    else if (pos < _maxPos)
      return;
    else
      throw cms::Exception("InvalidConfiguration") << "Circular dependency of collections";

    for (std::set<Collections>::const_iterator rItr(_d.requisite.begin()); rItr != _d.requisite.end(); ++rItr) {
      for (std::vector<Dependency>::const_iterator dItr(set_.begin()); dItr != set_.end(); ++dItr) {
        if (dItr->dependant != *rItr)
          continue;
        pos = std::find(_sequence.begin(), _sequence.end(), col);
        formSequenceFragment_(*dItr, _sequence, pos);
        break;
      }
    }
  }

}  // namespace ecaldqm