CMS 3D CMS Logo

HistoryAppender.cc
Go to the documentation of this file.
5 
6 #include <string>
7 #include <cassert>
8 
9 namespace {
10  edm::ProcessHistory initializeEmpty() {
12  tmp.setProcessHistoryID();
13  return tmp;
14  }
15 } // namespace
16 static const edm::ProcessHistory s_emptyHistory = initializeEmpty();
17 
18 namespace edm {
19 
21 
22  std::shared_ptr<ProcessHistory const> HistoryAppender::appendToProcessHistory(
23  ProcessHistoryID const& inputPHID, ProcessHistory const* iInputProcessHistory, ProcessConfiguration const& pc) {
24  assert((iInputProcessHistory) == nullptr or (inputPHID == iInputProcessHistory->id()));
25  if (m_cachedHistory.get() != nullptr and inputPHID == m_cachedInputPHID) {
26  return m_cachedHistory;
27  }
28 
29  ProcessHistory const* inputProcessHistory = iInputProcessHistory ? iInputProcessHistory : &s_emptyHistory;
30 
31  if (inputPHID.isValid()) {
32  if (iInputProcessHistory == nullptr) {
33  throw Exception(errors::LogicError) << "HistoryAppender::appendToProcessHistory\n"
34  << "Input ProcessHistory has valid ID but is nullptr\n"
35  << "Contact a Framework developer\n";
36  }
37  }
38 
39  auto newProcessHistory = std::make_shared<ProcessHistory>();
40  *newProcessHistory = *inputProcessHistory;
41  checkProcessHistory(*newProcessHistory, pc);
42  newProcessHistory->push_back(pc);
43  //force it to create the ID
44  newProcessHistory->setProcessHistoryID();
45  m_cachedInputPHID = inputPHID;
46  m_cachedHistory = newProcessHistory;
47  return m_cachedHistory;
48  }
49 
51  std::string const& processName = pc.processName();
52  for (auto const& process : ph) {
53  if (processName == process.processName()) {
54  throw edm::Exception(errors::Configuration, "Duplicate Process.")
55  << "The process name " << processName << " was already in the ProcessHistory.\n"
56  << "Please modify the configuration file to use a distinct process name.\n";
57  }
58  }
59  }
60 } // namespace edm
std::shared_ptr< ProcessHistory const > appendToProcessHistory(ProcessHistoryID const &inputPHID, ProcessHistory const *inputProcessHistory, ProcessConfiguration const &pc)
std::string const & processName() const
ProcessHistoryID m_cachedInputPHID
The Signals That Services Can Subscribe To This is based on ActivityRegistry and is current per Services can connect to the signals distributed by the ActivityRegistry in order to monitor the activity of the application Each possible callback has some defined which we here list in angle e< void, edm::EventID const &, edm::Timestamp const & > We also list in braces which AR_WATCH_USING_METHOD_ is used for those or
Definition: Activities.doc:12
static const edm::ProcessHistory s_emptyHistory
void checkProcessHistory(ProcessHistory const &ph, ProcessConfiguration const &pc) const
std::vector< std::vector< double > > tmp
Definition: MVATrainer.cc:100
HLT enums.
ProcessHistoryID id() const
std::shared_ptr< ProcessHistory const > m_cachedHistory