CMS 3D CMS Logo

ParameterSwitch.h
Go to the documentation of this file.
1 #ifndef FWCore_ParameterSet_ParameterSwitch_h
2 #define FWCore_ParameterSet_ParameterSwitch_h
3 
12 
13 #include <map>
14 #include <memory>
15 #include <set>
16 #include <string>
17 #include <utility>
18 #include <sstream>
19 #include <ostream>
20 #include <iomanip>
21 
22 namespace edm {
23 
24  template <class T>
26  public:
27  typedef std::map<T, edm::value_ptr<ParameterDescriptionNode> > CaseMap;
28  typedef typename std::map<T, edm::value_ptr<ParameterDescriptionNode> >::const_iterator CaseMapConstIter;
29 
30  ParameterSwitch(ParameterDescription<T> const& switchParameter,
32  : switch_(switchParameter), cases_(*cases->caseMap()) {
33  if (cases->duplicateCaseValues()) {
34  throwDuplicateCaseValues(switchParameter.label());
35  }
36  }
37 
38  ParameterDescriptionNode* clone() const override { return new ParameterSwitch(*this); }
39 
40  private:
41  void checkAndGetLabelsAndTypes_(std::set<std::string>& usedLabels,
42  std::set<ParameterTypes>& parameterTypes,
43  std::set<ParameterTypes>& wildcardTypes) const override {
44  std::set<std::string> caseLabels;
45  std::set<ParameterTypes> caseParameterTypes;
46  std::set<ParameterTypes> caseWildcardTypes;
49  std::placeholders::_1,
50  std::ref(caseLabels),
51  std::ref(caseParameterTypes),
52  std::ref(caseWildcardTypes)));
53 
54  insertAndCheckLabels(switch_.label(), usedLabels, caseLabels);
55 
56  insertAndCheckTypes(switch_.type(), caseParameterTypes, caseWildcardTypes, parameterTypes, wildcardTypes);
57 
58  if (cases_.find(switch_.getDefaultValue()) == cases_.end()) {
60  }
61  }
62 
63  void validate_(ParameterSet& pset, std::set<std::string>& validatedLabels, bool optional) const override {
64  switch_.validate(pset, validatedLabels, optional);
65  if (switch_.exists(pset)) {
66  T switchValue;
67  if (switch_.isTracked()) {
68  switchValue = pset.getParameter<T>(switch_.label());
69  } else {
70  switchValue = pset.getUntrackedParameter<T>(switch_.label());
71  }
72  typename CaseMap::const_iterator selectedCase = cases_.find(switchValue);
73  if (selectedCase != cases_.end()) {
74  selectedCase->second->validate(pset, validatedLabels, false);
75  } else {
76  std::stringstream ss;
77  ss << "The switch parameter with label \"" << switch_.label() << "\" has been assigned an illegal value.\n"
78  << "The value from the configuration is \"" << switchValue << "\".\n"
79  << "The allowed values are:\n";
80 
81  for (CaseMapConstIter iter = cases_.begin(), iEnd = cases_.end(); iter != iEnd; ++iter) {
82  ss << " " << iter->first << "\n";
83  }
85  }
86  }
87  }
88 
89  void writeCfi_(std::ostream& os,
90  bool optional,
91  bool& startWithComma,
92  int indentation,
94  bool& wroteSomething) const override {
95  switch_.writeCfi(os, optional, startWithComma, indentation, options, wroteSomething);
96 
97  if (std::holds_alternative<cfi::ClassFile>(options)) {
98  std::set<std::string> labels;
99  std::set<ParameterTypes> parameterTypes;
100  std::set<ParameterTypes> wildcardTypes;
101  for (auto const& n : cases_) {
102  n.second->checkAndGetLabelsAndTypes(labels, parameterTypes, wildcardTypes);
103  }
104  for (auto const& l : labels) {
106  }
107  }
108 
109  typename CaseMap::const_iterator selectedCase = cases_.find(switch_.getDefaultValue());
110  if (selectedCase != cases_.end()) {
111  selectedCase->second->writeCfi(os, optional, startWithComma, indentation, options, wroteSomething);
112  }
113  }
114 
115  void print_(std::ostream& os, bool optional, bool writeToCfi, DocFormatHelper& dfh) const override {
116  printBase(os,
117  optional,
118  writeToCfi,
119  dfh,
120  switch_.label(),
121  switch_.isTracked(),
123  }
124 
125  void printNestedContent_(std::ostream& os, bool optional, DocFormatHelper& dfh) const override {
126  DocFormatHelper new_dfh(dfh);
127  printNestedContentBase(os, dfh, new_dfh, switch_.label());
128 
129  switch_.print(os, optional, true, new_dfh);
130  for_all(cases_,
131  std::bind(&ParameterSwitchBase::printCaseT<T>,
132  std::placeholders::_1,
133  std::ref(os),
134  optional,
135  std::ref(new_dfh),
136  std::cref(switch_.label())));
137 
138  new_dfh.setPass(1);
139  new_dfh.setCounter(0);
140 
141  new_dfh.indent(os);
142  os << "switch:\n";
143  switch_.print(os, optional, true, new_dfh);
144  for_all(cases_,
145  std::bind(&ParameterSwitchBase::printCaseT<T>,
146  std::placeholders::_1,
147  std::ref(os),
148  optional,
149  std::ref(new_dfh),
150  std::cref(switch_.label())));
151 
152  new_dfh.setPass(2);
153  new_dfh.setCounter(0);
154 
155  switch_.printNestedContent(os, optional, new_dfh);
156  for_all(cases_,
157  std::bind(&ParameterSwitchBase::printCaseT<T>,
158  std::placeholders::_1,
159  std::ref(os),
160  optional,
161  std::ref(new_dfh),
162  std::cref(switch_.label())));
163  }
164 
165  bool exists_(ParameterSet const& pset) const override { return switch_.exists(pset); }
166 
167  static void checkCaseLabels(std::pair<T, edm::value_ptr<ParameterDescriptionNode> > const& thePair,
168  std::set<std::string>& labels,
169  std::set<ParameterTypes>& parameterTypes,
170  std::set<ParameterTypes>& wildcardTypes) {
171  thePair.second->checkAndGetLabelsAndTypes(labels, parameterTypes, wildcardTypes);
172  }
173 
176  };
177 } // namespace edm
178 #endif
std::string const & label() const
void insertAndCheckTypes(ParameterTypes switchType, std::set< ParameterTypes > const &caseParameterTypes, std::set< ParameterTypes > const &caseWildcardTypes, std::set< ParameterTypes > &parameterTypes, std::set< ParameterTypes > &wildcardTypes) const
static void checkCaseLabels(std::pair< T, edm::value_ptr< ParameterDescriptionNode > > const &thePair, std::set< std::string > &labels, std::set< ParameterTypes > &parameterTypes, std::set< ParameterTypes > &wildcardTypes)
std::unique_ptr< T, impl::DeviceDeleter > unique_ptr
void validate_(ParameterSet &pset, std::set< std::string > &validatedLabels, bool optional) const override
std::string parameterTypeEnumToString(ParameterTypes iType)
void setCounter(int value)
Func for_all(ForwardSequence &s, Func f)
wrapper for std::for_each
Definition: Algorithms.h:14
void throwDuplicateCaseValues(std::string const &switchLabel) const
void parameterMustBeTyped(CfiOptions &iOps) noexcept
void printBase(std::ostream &os, bool optional, bool writeToCfi, DocFormatHelper &dfh, std::string const &switchLabel, bool isTracked, std::string const &typeString) const
optional
Definition: Types.py:245
void setPass(int value)
std::map< T, edm::value_ptr< ParameterDescriptionNode > >::const_iterator CaseMapConstIter
void checkAndGetLabelsAndTypes_(std::set< std::string > &usedLabels, std::set< ParameterTypes > &parameterTypes, std::set< ParameterTypes > &wildcardTypes) const override
void throwNoCaseForDefault(std::string const &switchLabel) const
std::map< T, edm::value_ptr< ParameterDescriptionNode > > CaseMap
void insertAndCheckLabels(std::string const &switchLabel, std::set< std::string > &usedLabels, std::set< std::string > &labels) const
HLT enums.
ParameterDescription< T > switch_
ParameterSwitch(ParameterDescription< T > const &switchParameter, std::unique_ptr< ParameterDescriptionCases< T > > cases)
bool exists_(ParameterSet const &pset) const override
void printNestedContent_(std::ostream &os, bool optional, DocFormatHelper &dfh) const override
ParameterDescriptionNode * clone() const override
void print_(std::ostream &os, bool optional, bool writeToCfi, DocFormatHelper &dfh) const override
void printNestedContentBase(std::ostream &os, DocFormatHelper &dfh, DocFormatHelper &new_dfh, std::string const &switchLabel) const
long double T
void throwNoCaseForSwitchValue(std::string const &message) const
void indent(std::ostream &os) const
void writeCfi_(std::ostream &os, bool optional, bool &startWithComma, int indentation, CfiOptions &options, bool &wroteSomething) const override
cfi::CfiOptions CfiOptions