CMS 3D CMS Logo

List of all members | Public Member Functions | Private Member Functions | Private Attributes
edm::XORGroupDescription Class Reference

#include <XORGroupDescription.h>

Inheritance diagram for edm::XORGroupDescription:
edm::ParameterDescriptionNode

Public Member Functions

ParameterDescriptionNodeclone () const override
 
 XORGroupDescription (ParameterDescriptionNode const &node_left, ParameterDescriptionNode const &node_right)
 
 XORGroupDescription (std::unique_ptr< ParameterDescriptionNode > node_left, ParameterDescriptionNode const &node_right)
 
 XORGroupDescription (ParameterDescriptionNode const &node_left, std::unique_ptr< ParameterDescriptionNode > node_right)
 
 XORGroupDescription (std::unique_ptr< ParameterDescriptionNode > node_left, std::unique_ptr< ParameterDescriptionNode > node_right)
 
- Public Member Functions inherited from edm::ParameterDescriptionNode
void checkAndGetLabelsAndTypes (std::set< std::string > &usedLabels, std::set< ParameterTypes > &parameterTypes, std::set< ParameterTypes > &wildcardTypes) const
 
std::string const & comment () const
 
bool exists (ParameterSet const &pset) const
 
bool hasNestedContent () const
 
int howManyXORSubNodesExist (ParameterSet const &pset) const
 
virtual bool isWildcard () const
 
 ParameterDescriptionNode ()
 
 ParameterDescriptionNode (Comment const &iComment)
 
bool partiallyExists (ParameterSet const &pset) const
 
void print (std::ostream &os, bool optional, bool writeToCfi, DocFormatHelper &dfh) const
 
void printNestedContent (std::ostream &os, bool optional, DocFormatHelper &dfh) const
 
void setComment (std::string const &value)
 
void setComment (char const *value)
 
void validate (ParameterSet &pset, std::set< std::string > &validatedLabels, bool optional) const
 
void writeCfi (std::ostream &os, bool optional, bool &startWithComma, int indentation, CfiOptions &options, bool &wroteSomething) const
 
virtual ~ParameterDescriptionNode ()
 

Private Member Functions

void checkAndGetLabelsAndTypes_ (std::set< std::string > &usedLabels, std::set< ParameterTypes > &parameterTypes, std::set< ParameterTypes > &wildcardTypes) const override
 
bool exists_ (ParameterSet const &pset) const override
 
bool hasNestedContent_ () const override
 
int howManyXORSubNodesExist_ (ParameterSet const &pset) const override
 
bool partiallyExists_ (ParameterSet const &pset) const override
 
void print_ (std::ostream &os, bool optional, bool writeToCfi, DocFormatHelper &dfh) const override
 
void printNestedContent_ (std::ostream &os, bool optional, DocFormatHelper &dfh) const override
 
void throwAfterValidation () const
 
void throwMoreThanOneParameter () const
 
void validate_ (ParameterSet &pset, std::set< std::string > &validatedLabels, bool optional) const override
 
void writeCfi_ (std::ostream &os, bool optional, bool &startWithComma, int indentation, CfiOptions &, bool &wroteSomething) const override
 

Private Attributes

edm::value_ptr< ParameterDescriptionNodenode_left_
 
edm::value_ptr< ParameterDescriptionNodenode_right_
 

Additional Inherited Members

- Static Public Member Functions inherited from edm::ParameterDescriptionNode
static void printSpaces (std::ostream &os, int n)
 
- Protected Attributes inherited from edm::ParameterDescriptionNode
std::string comment_
 

Detailed Description

Definition at line 18 of file XORGroupDescription.h.

Constructor & Destructor Documentation

◆ XORGroupDescription() [1/4]

edm::XORGroupDescription::XORGroupDescription ( ParameterDescriptionNode const &  node_left,
ParameterDescriptionNode const &  node_right 
)

Definition at line 11 of file XORGroupDescription.cc.

Referenced by clone().

13  : node_left_(node_left.clone()), node_right_(node_right.clone()) {}
edm::value_ptr< ParameterDescriptionNode > node_left_
edm::value_ptr< ParameterDescriptionNode > node_right_

◆ XORGroupDescription() [2/4]

edm::XORGroupDescription::XORGroupDescription ( std::unique_ptr< ParameterDescriptionNode node_left,
ParameterDescriptionNode const &  node_right 
)

Definition at line 15 of file XORGroupDescription.cc.

17  : node_left_(std::move(node_left)), node_right_(node_right.clone()) {}
edm::value_ptr< ParameterDescriptionNode > node_left_
def move(src, dest)
Definition: eostools.py:511
edm::value_ptr< ParameterDescriptionNode > node_right_

◆ XORGroupDescription() [3/4]

edm::XORGroupDescription::XORGroupDescription ( ParameterDescriptionNode const &  node_left,
std::unique_ptr< ParameterDescriptionNode node_right 
)

Definition at line 19 of file XORGroupDescription.cc.

21  : node_left_(node_left.clone()), node_right_(std::move(node_right)) {}
edm::value_ptr< ParameterDescriptionNode > node_left_
def move(src, dest)
Definition: eostools.py:511
edm::value_ptr< ParameterDescriptionNode > node_right_

◆ XORGroupDescription() [4/4]

edm::XORGroupDescription::XORGroupDescription ( std::unique_ptr< ParameterDescriptionNode node_left,
std::unique_ptr< ParameterDescriptionNode node_right 
)

Definition at line 23 of file XORGroupDescription.cc.

25  : node_left_(std::move(node_left)), node_right_(std::move(node_right)) {}
edm::value_ptr< ParameterDescriptionNode > node_left_
def move(src, dest)
Definition: eostools.py:511
edm::value_ptr< ParameterDescriptionNode > node_right_

Member Function Documentation

◆ checkAndGetLabelsAndTypes_()

void edm::XORGroupDescription::checkAndGetLabelsAndTypes_ ( std::set< std::string > &  usedLabels,
std::set< ParameterTypes > &  parameterTypes,
std::set< ParameterTypes > &  wildcardTypes 
) const
overrideprivatevirtual

Implements edm::ParameterDescriptionNode.

Definition at line 27 of file XORGroupDescription.cc.

References node_left_, and node_right_.

29  {
30  std::set<std::string> labelsLeft;
31  std::set<ParameterTypes> parameterTypesLeft;
32  std::set<ParameterTypes> wildcardTypesLeft;
33  node_left_->checkAndGetLabelsAndTypes(labelsLeft, parameterTypesLeft, wildcardTypesLeft);
34 
35  std::set<std::string> labelsRight;
36  std::set<ParameterTypes> parameterTypesRight;
37  std::set<ParameterTypes> wildcardTypesRight;
38  node_right_->checkAndGetLabelsAndTypes(labelsRight, parameterTypesRight, wildcardTypesRight);
39 
40  usedLabels.insert(labelsLeft.begin(), labelsLeft.end());
41  usedLabels.insert(labelsRight.begin(), labelsRight.end());
42 
43  parameterTypes.insert(parameterTypesRight.begin(), parameterTypesRight.end());
44  parameterTypes.insert(parameterTypesLeft.begin(), parameterTypesLeft.end());
45 
46  wildcardTypes.insert(wildcardTypesRight.begin(), wildcardTypesRight.end());
47  wildcardTypes.insert(wildcardTypesLeft.begin(), wildcardTypesLeft.end());
48  }
edm::value_ptr< ParameterDescriptionNode > node_left_
edm::value_ptr< ParameterDescriptionNode > node_right_

◆ clone()

ParameterDescriptionNode* edm::XORGroupDescription::clone ( void  ) const
inlineoverridevirtual

Implements edm::ParameterDescriptionNode.

Definition at line 31 of file XORGroupDescription.h.

References XORGroupDescription().

31 { return new XORGroupDescription(*this); }
XORGroupDescription(ParameterDescriptionNode const &node_left, ParameterDescriptionNode const &node_right)

◆ exists_()

bool edm::XORGroupDescription::exists_ ( ParameterSet const &  pset) const
overrideprivatevirtual

Implements edm::ParameterDescriptionNode.

Definition at line 185 of file XORGroupDescription.cc.

References node_left_, node_right_, and muonDTDigis_cfi::pset.

185  {
186  int nTotal = node_left_->howManyXORSubNodesExist(pset) + node_right_->howManyXORSubNodesExist(pset);
187  return nTotal == 1;
188  }
edm::value_ptr< ParameterDescriptionNode > node_left_
edm::value_ptr< ParameterDescriptionNode > node_right_

◆ hasNestedContent_()

bool edm::XORGroupDescription::hasNestedContent_ ( ) const
inlineoverrideprivatevirtual

Reimplemented from edm::ParameterDescriptionNode.

Definition at line 49 of file XORGroupDescription.h.

49 { return true; }

◆ howManyXORSubNodesExist_()

int edm::XORGroupDescription::howManyXORSubNodesExist_ ( ParameterSet const &  pset) const
overrideprivatevirtual

Implements edm::ParameterDescriptionNode.

Definition at line 192 of file XORGroupDescription.cc.

References node_left_, node_right_, and muonDTDigis_cfi::pset.

192  {
193  return node_left_->howManyXORSubNodesExist(pset) + node_right_->howManyXORSubNodesExist(pset);
194  }
edm::value_ptr< ParameterDescriptionNode > node_left_
edm::value_ptr< ParameterDescriptionNode > node_right_

◆ partiallyExists_()

bool edm::XORGroupDescription::partiallyExists_ ( ParameterSet const &  pset) const
overrideprivatevirtual

Implements edm::ParameterDescriptionNode.

Definition at line 190 of file XORGroupDescription.cc.

References edm::ParameterDescriptionNode::exists(), and muonDTDigis_cfi::pset.

190 { return exists(pset); }
bool exists(ParameterSet const &pset) const

◆ print_()

void edm::XORGroupDescription::print_ ( std::ostream &  os,
bool  optional,
bool  writeToCfi,
DocFormatHelper dfh 
) const
overrideprivatevirtual

Reimplemented from edm::ParameterDescriptionNode.

Definition at line 90 of file XORGroupDescription.cc.

References edm::DocFormatHelper::brief(), edm::ParameterDescriptionNode::comment(), edm::DocFormatHelper::commentWidth(), edm::DocFormatHelper::counter(), edm::DocFormatHelper::decrementCounter(), relativeConstraints::empty, edm::DocFormatHelper::indent(), edm::DocFormatHelper::indent2(), node_left_, node_right_, Types::optional, l1tGTMenu_BTagSeeds_cff::os, edm::DocFormatHelper::parent(), edm::DocFormatHelper::pass(), edm::DocFormatHelper::section(), edm::DocFormatHelper::startColumn2(), edm::DocFormatHelper::wrapAndPrintText(), and edm::DocFormatHelper::XOR.

90  {
91  if (dfh.parent() == DocFormatHelper::XOR) {
92  dfh.decrementCounter();
93  node_left_->print(os, false, true, dfh);
94  node_right_->print(os, false, true, dfh);
95  return;
96  }
97 
98  if (dfh.pass() == 1) {
99  dfh.indent(os);
100  os << "XOR group:";
101 
102  if (dfh.brief()) {
103  if (optional)
104  os << " optional";
105 
106  if (!writeToCfi)
107  os << " (do not write to cfi)";
108 
109  os << " see Section " << dfh.section() << "." << dfh.counter() << "\n";
110  }
111  // not brief
112  else {
113  os << "\n";
114  dfh.indent2(os);
115 
116  if (optional)
117  os << "optional";
118  if (!writeToCfi)
119  os << " (do not write to cfi)";
120  if (optional || !writeToCfi) {
121  os << "\n";
122  dfh.indent2(os);
123  }
124 
125  os << "see Section " << dfh.section() << "." << dfh.counter() << "\n";
126 
127  if (!comment().empty()) {
128  DocFormatHelper::wrapAndPrintText(os, comment(), dfh.startColumn2(), dfh.commentWidth());
129  }
130  os << "\n";
131  }
132  }
133  }
static void wrapAndPrintText(std::ostream &os, std::string const &text, size_t indent, size_t suggestedWidth)
optional
Definition: Types.py:245
std::string const & comment() const
edm::value_ptr< ParameterDescriptionNode > node_left_
edm::value_ptr< ParameterDescriptionNode > node_right_

◆ printNestedContent_()

void edm::XORGroupDescription::printNestedContent_ ( std::ostream &  os,
bool  optional,
DocFormatHelper dfh 
) const
overrideprivatevirtual

Reimplemented from edm::ParameterDescriptionNode.

Definition at line 135 of file XORGroupDescription.cc.

References edm::DocFormatHelper::brief(), edm::DocFormatHelper::counter(), edm::DocFormatHelper::decrementCounter(), printContent_cfi::indentation, edm::DocFormatHelper::indentation(), edm::DocFormatHelper::init(), node_left_, node_right_, edm::DocFormatHelper::offsetSectionContent(), Types::optional, l1tGTMenu_BTagSeeds_cff::os, edm::DocFormatHelper::parent(), edm::ParameterDescriptionNode::printSpaces(), edm::DocFormatHelper::section(), edm::DocFormatHelper::setCounter(), edm::DocFormatHelper::setIndentation(), edm::DocFormatHelper::setParent(), edm::DocFormatHelper::setPass(), edm::DocFormatHelper::setSection(), contentValuesCheck::ss, AlCaHLTBitMon_QueryRunRegistry::string, edm::DocFormatHelper::TOP, and edm::DocFormatHelper::XOR.

135  {
136  if (dfh.parent() == DocFormatHelper::XOR) {
137  dfh.decrementCounter();
138  node_left_->printNestedContent(os, false, dfh);
139  node_right_->printNestedContent(os, false, dfh);
140  return;
141  }
142 
143  int indentation = dfh.indentation();
144  if (dfh.parent() != DocFormatHelper::TOP) {
146  }
147 
148  std::stringstream ss;
149  ss << dfh.section() << "." << dfh.counter();
150  std::string newSection = ss.str();
151 
153  os << "Section " << newSection << " XOR group description:\n";
155  if (optional) {
156  os << "This optional XOR group requires exactly one or none of the following to be in the PSet\n";
157  } else {
158  os << "This XOR group requires exactly one of the following to be in the PSet\n";
159  }
160  if (!dfh.brief())
161  os << "\n";
162 
163  DocFormatHelper new_dfh(dfh);
164  new_dfh.init();
165  new_dfh.setSection(newSection);
166  new_dfh.setIndentation(indentation + DocFormatHelper::offsetSectionContent());
167  new_dfh.setParent(DocFormatHelper::XOR);
168 
169  node_left_->print(os, false, true, new_dfh);
170  node_right_->print(os, false, true, new_dfh);
171 
172  new_dfh.setPass(1);
173  new_dfh.setCounter(0);
174 
175  node_left_->print(os, false, true, new_dfh);
176  node_right_->print(os, false, true, new_dfh);
177 
178  new_dfh.setPass(2);
179  new_dfh.setCounter(0);
180 
181  node_left_->printNestedContent(os, false, new_dfh);
182  node_right_->printNestedContent(os, false, new_dfh);
183  }
static int offsetSectionContent()
optional
Definition: Types.py:245
static void printSpaces(std::ostream &os, int n)
edm::value_ptr< ParameterDescriptionNode > node_left_
edm::value_ptr< ParameterDescriptionNode > node_right_

◆ throwAfterValidation()

void edm::XORGroupDescription::throwAfterValidation ( ) const
private

Definition at line 208 of file XORGroupDescription.cc.

References Exception, and edm::errors::LogicError.

Referenced by validate_().

208  {
209  // Need to expand this error message to print more information
210  // I guess I need to print out the entire node structure of
211  // of the xor node and all the nodes it contains.
213  << "Exactly one parameter can exist in a ParameterSet from a list of\n"
214  << "parameters described by an \"xor\" operator in a ParameterSetDescription.\n"
215  << "This rule also applies in a more general sense to the other types\n"
216  << "of nodes that can appear within a ParameterSetDescription. Only one\n"
217  << "can pass validation as \"existing\". This error has occurred after an\n"
218  << "attempt to insert missing parameters to fix the problem.\n";
219  }

◆ throwMoreThanOneParameter()

void edm::XORGroupDescription::throwMoreThanOneParameter ( ) const
private

Definition at line 196 of file XORGroupDescription.cc.

References Exception, and edm::errors::LogicError.

Referenced by validate_().

196  {
197  // Need to expand this error message to print more information
198  // I guess I need to print out the entire node structure of
199  // of the xor node and all the nodes it contains.
201  << "Exactly one parameter can exist in a ParameterSet from a list of\n"
202  << "parameters described by an \"xor\" operator in a ParameterSetDescription.\n"
203  << "This rule also applies in a more general sense to the other types\n"
204  << "of nodes that can appear within a ParameterSetDescription. Only one\n"
205  << "can pass validation as \"existing\".\n";
206  }

◆ validate_()

void edm::XORGroupDescription::validate_ ( ParameterSet pset,
std::set< std::string > &  validatedLabels,
bool  optional 
) const
overrideprivatevirtual

Implements edm::ParameterDescriptionNode.

Definition at line 50 of file XORGroupDescription.cc.

References node_left_, node_right_, Types::optional, muonDTDigis_cfi::pset, throwAfterValidation(), and throwMoreThanOneParameter().

50  {
51  int nExistLeft = node_left_->howManyXORSubNodesExist(pset);
52  int nExistRight = node_right_->howManyXORSubNodesExist(pset);
53  int nTotal = nExistLeft + nExistRight;
54 
55  if (nTotal == 0 && optional)
56  return;
57 
58  if (nTotal > 1) {
60  }
61 
62  if (nExistLeft == 1) {
63  node_left_->validate(pset, validatedLabels, false);
64  } else if (nExistRight == 1) {
65  node_right_->validate(pset, validatedLabels, false);
66  } else if (nTotal == 0) {
67  node_left_->validate(pset, validatedLabels, false);
68 
69  // When missing parameters get inserted, both nodes could
70  // be affected so we have to recheck both nodes.
71  nExistLeft = node_left_->howManyXORSubNodesExist(pset);
72  nExistRight = node_right_->howManyXORSubNodesExist(pset);
73  nTotal = nExistLeft + nExistRight;
74 
75  if (nTotal != 1) {
77  }
78  }
79  }
optional
Definition: Types.py:245
edm::value_ptr< ParameterDescriptionNode > node_left_
edm::value_ptr< ParameterDescriptionNode > node_right_

◆ writeCfi_()

void edm::XORGroupDescription::writeCfi_ ( std::ostream &  os,
bool  optional,
bool &  startWithComma,
int  indentation,
CfiOptions options,
bool &  wroteSomething 
) const
overrideprivatevirtual

Implements edm::ParameterDescriptionNode.

Definition at line 81 of file XORGroupDescription.cc.

References printContent_cfi::indentation, node_left_, Types::optional, and l1tGTMenu_BTagSeeds_cff::os.

86  {
87  node_left_->writeCfi(os, optional, startWithComma, indentation, options, wroteSomething);
88  }
optional
Definition: Types.py:245
edm::value_ptr< ParameterDescriptionNode > node_left_

Member Data Documentation

◆ node_left_

edm::value_ptr<ParameterDescriptionNode> edm::XORGroupDescription::node_left_
private

◆ node_right_

edm::value_ptr<ParameterDescriptionNode> edm::XORGroupDescription::node_right_
private