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 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83
#include "DQMOffline/Trigger/interface/EgHLTTrigCodes.h"

#include "FWCore/MessageLogger/interface/MessageLogger.h"

const int egHLT::TrigCodes::maxNrBits_;

using namespace egHLT;

TrigCodes* TrigCodes::makeCodes(std::vector<std::string>& filterNames) {
  auto* p = new TrigCodes();

  for (size_t i = 0; i < filterNames.size(); i++) {
    p->setCode(filterNames[i].c_str(), i);
  }
  p->sort();

  return p;
}

void TrigCodes::setCode(const char* descript, int bitNr) {
  if (bitNr < maxNrBits_) {
    TrigBitSet code;
    code.set(bitNr);
    setCode(descript, code);
  } else {
    edm::LogWarning("TrigCodes::TrigBitSetMap")
        << " Warning, trying to store at bit " << bitNr << " but max nr bits is " << maxNrBits_;
  }
}

void TrigCodes::setCode(const char* descript, TrigBitSet code) {
  bool found = false;
  for (size_t i = 0; i < codeDefs_.size() && !found; i++) {
    if (codeDefs_[i].first == descript)
      found = true;
  }
  if (!found)
    codeDefs_.emplace_back(descript, code);
  //_codeDefs[descript] = code;
}

TrigCodes::TrigBitSet TrigCodes::getCode(const char* descript) const {
  TrigBitSet code;

  char const* const end = descript + strlen(descript);
  char const* codeKey = descript;
  char const* token = nullptr;
  do {
    token = std::find(codeKey, end, ':');

    for (auto const& c : codeDefs_) {
      if (0 == c.first.compare(0, std::string::npos, codeKey, token - codeKey)) {
        code |= c.second;
        break;
      }
    }
    codeKey = token + 1;
  } while (token != end);
  return code;
}

bool TrigCodes::keyComp(const std::pair<std::string, TrigBitSet>& lhs, const std::pair<std::string, TrigBitSet>& rhs) {
  return lhs.first < rhs.first;
}

void TrigCodes::getCodeName(TrigBitSet code, std::string& id) const {
  id.clear();
  for (auto const& codeDef : codeDefs_) {
    if ((code & codeDef.second) == codeDef.second) {
      if (!id.empty())
        id += ":";  //seperating entries by a ':'
      id += codeDef.first;
    }
  }
}

void TrigCodes::printCodes() {
  std::ostringstream msg;
  msg << " trig bits defined: " << std::endl;
  for (auto& codeDef : codeDefs_)
    msg << " key : " << codeDef.first << " bit " << codeDef.second << std::endl;
  edm::LogInfo("TrigCodes") << msg.str();
}