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_(
90  std::ostream& os, bool optional, bool& startWithComma, int indentation, bool& wroteSomething) const override {
91  switch_.writeCfi(os, optional, startWithComma, indentation, wroteSomething);
92 
93  typename CaseMap::const_iterator selectedCase = cases_.find(switch_.getDefaultValue());
94  if (selectedCase != cases_.end()) {
95  selectedCase->second->writeCfi(os, optional, startWithComma, indentation, wroteSomething);
96  }
97  }
98 
99  void print_(std::ostream& os, bool optional, bool writeToCfi, DocFormatHelper& dfh) const override {
100  printBase(os,
101  optional,
102  writeToCfi,
103  dfh,
104  switch_.label(),
105  switch_.isTracked(),
107  }
108 
109  void printNestedContent_(std::ostream& os, bool optional, DocFormatHelper& dfh) const override {
110  DocFormatHelper new_dfh(dfh);
111  printNestedContentBase(os, dfh, new_dfh, switch_.label());
112 
113  switch_.print(os, optional, true, new_dfh);
114  for_all(cases_,
115  std::bind(&ParameterSwitchBase::printCaseT<T>,
116  std::placeholders::_1,
117  std::ref(os),
118  optional,
119  std::ref(new_dfh),
120  std::cref(switch_.label())));
121 
122  new_dfh.setPass(1);
123  new_dfh.setCounter(0);
124 
125  new_dfh.indent(os);
126  os << "switch:\n";
127  switch_.print(os, optional, true, new_dfh);
128  for_all(cases_,
129  std::bind(&ParameterSwitchBase::printCaseT<T>,
130  std::placeholders::_1,
131  std::ref(os),
132  optional,
133  std::ref(new_dfh),
134  std::cref(switch_.label())));
135 
136  new_dfh.setPass(2);
137  new_dfh.setCounter(0);
138 
139  switch_.printNestedContent(os, optional, new_dfh);
140  for_all(cases_,
141  std::bind(&ParameterSwitchBase::printCaseT<T>,
142  std::placeholders::_1,
143  std::ref(os),
144  optional,
145  std::ref(new_dfh),
146  std::cref(switch_.label())));
147  }
148 
149  bool exists_(ParameterSet const& pset) const override { return switch_.exists(pset); }
150 
151  static void checkCaseLabels(std::pair<T, edm::value_ptr<ParameterDescriptionNode> > const& thePair,
152  std::set<std::string>& labels,
153  std::set<ParameterTypes>& parameterTypes,
154  std::set<ParameterTypes>& wildcardTypes) {
155  thePair.second->checkAndGetLabelsAndTypes(labels, parameterTypes, wildcardTypes);
156  }
157 
160  };
161 } // namespace edm
162 #endif
void writeCfi_(std::ostream &os, bool optional, bool &startWithComma, int indentation, bool &wroteSomething) const override
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 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