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
#include "FWCore/MessageLogger/interface/MessageLogger.h"
#include "EventFilter/SiStripRawToDigi/plugins/WarningSummary.h"

#include <algorithm>

void sistrip::WarningSummary::add(const std::string& message, const std::string& details) {
  const auto wIt = m_warnings.find(message);
  if (wIt == m_warnings.end()) {
    m_warnings.emplace(message, 1);
    edm::LogWarning(m_category) << message << ": " << details
                                << (m_debug ? ""
                                            : "\nNote: further warnings of this type will be suppressed (this can be "
                                              "changed by enabling debugging printout)");
  } else {
    ++(wIt->second);
    if (m_debug) {
      edm::LogWarning(m_category) << message << ": " << details;
    }
  }
}

void sistrip::WarningSummary::printSummary() const {
  if (!m_warnings.empty()) {
    std::stringstream message;
    message << m_name << " warnings:";
    for (const auto& warnAndCount : m_warnings) {
      message << std::endl << warnAndCount.first << " (" << warnAndCount.second << ")";
    }
    edm::LogWarning(m_category) << message.str();
  }
}