1 #ifndef FWCore_ParameterSet_ParameterDescriptionNode_h 2 #define FWCore_ParameterSet_ParameterDescriptionNode_h 21 template <
typename T>
class ParameterDescriptionCases;
22 class DocFormatHelper;
72 explicit Comment(
char const* iComment);
94 void setComment(
char const* value);
103 std::set<std::string>& validatedLabels,
104 bool optional)
const {
105 validate_(pset, validatedLabels, optional);
119 bool& startWithComma,
121 bool& wroteSomething)
const {
122 writeCfi_(os, startWithComma, indentation, wroteSomething);
126 void print(std::ostream& os,
132 return hasNestedContent_();
135 void printNestedContent(std::ostream& os,
147 return exists_(pset);
155 return partiallyExists_(pset);
170 return howManyXORSubNodesExist_(pset);
226 std::set<ParameterTypes>& parameterTypes,
227 std::set<ParameterTypes>& wildcardTypes)
const {
228 checkAndGetLabelsAndTypes_(usedLabels, parameterTypes, wildcardTypes);
231 static void printSpaces(std::ostream& os,
int n);
235 virtual void checkAndGetLabelsAndTypes_(std::set<std::string>& usedLabels,
236 std::set<ParameterTypes>& parameterTypes,
237 std::set<ParameterTypes>& wildcardTypes)
const = 0;
240 std::set<std::string>& validatedLabels,
241 bool optional)
const = 0;
243 virtual void writeCfi_(std::ostream& os,
244 bool& startWithComma,
246 bool& wroteSomething)
const = 0;
261 virtual bool exists_(
ParameterSet const& pset)
const = 0;
263 virtual bool partiallyExists_(
ParameterSet const& pset)
const = 0;
265 virtual int howManyXORSubNodesExist_(
ParameterSet const& pset)
const = 0;
277 std::unique_ptr<ParameterDescriptionCases<bool> >
281 std::unique_ptr<ParameterDescriptionCases<int> >
285 std::unique_ptr<ParameterDescriptionCases<std::string> >
289 std::unique_ptr<ParameterDescriptionCases<std::string> >
293 std::unique_ptr<ParameterDescriptionCases<bool> >
295 std::unique_ptr<ParameterDescriptionNode> node);
297 std::unique_ptr<ParameterDescriptionCases<int> >
299 std::unique_ptr<ParameterDescriptionNode> node);
301 std::unique_ptr<ParameterDescriptionCases<std::string> >
303 std::unique_ptr<ParameterDescriptionNode> node);
305 std::unique_ptr<ParameterDescriptionCases<std::string> >
307 std::unique_ptr<ParameterDescriptionNode> node);
311 std::unique_ptr<ParameterDescriptionNode>
315 std::unique_ptr<ParameterDescriptionNode>
316 operator&&(std::unique_ptr<ParameterDescriptionNode> node_left,
319 std::unique_ptr<ParameterDescriptionNode>
321 std::unique_ptr<ParameterDescriptionNode> node_right);
323 std::unique_ptr<ParameterDescriptionNode>
324 operator&&(std::unique_ptr<ParameterDescriptionNode> node_left,
325 std::unique_ptr<ParameterDescriptionNode> node_right);
329 std::unique_ptr<ParameterDescriptionNode>
333 std::unique_ptr<ParameterDescriptionNode>
334 operator||(std::unique_ptr<ParameterDescriptionNode> node_left,
337 std::unique_ptr<ParameterDescriptionNode>
339 std::unique_ptr<ParameterDescriptionNode> node_right);
341 std::unique_ptr<ParameterDescriptionNode>
342 operator||(std::unique_ptr<ParameterDescriptionNode> node_left,
343 std::unique_ptr<ParameterDescriptionNode> node_right);
347 std::unique_ptr<ParameterDescriptionNode>
351 std::unique_ptr<ParameterDescriptionNode>
352 operator^(std::unique_ptr<ParameterDescriptionNode> node_left,
355 std::unique_ptr<ParameterDescriptionNode>
357 std::unique_ptr<ParameterDescriptionNode> node_right);
359 std::unique_ptr<ParameterDescriptionNode>
360 operator^(std::unique_ptr<ParameterDescriptionNode> node_left,
361 std::unique_ptr<ParameterDescriptionNode> node_right);
void validate(ParameterSet &pset, std::set< std::string > &validatedLabels, bool optional) const
std::istream & operator>>(std::istream &is, FileInPath &fip)
int howManyXORSubNodesExist(ParameterSet const &pset) const
virtual bool hasNestedContent_() const
S & print(S &os, JobReport::InputFile const &f)
virtual void printNestedContent_(std::ostream &, bool, DocFormatHelper &) const
std::string parameterTypeEnumToString(ParameterTypes iType)
static ParameterDescriptionNode * clone(ParameterDescriptionNode const *p)
std::unique_ptr< ParameterDescriptionNode > operator&&(ParameterDescriptionNode const &node_left, ParameterDescriptionNode const &node_right)
std::string const & comment() const
bool exists(ParameterSet const &pset) const
bool partiallyExists(ParameterSet const &pset) const
std::unique_ptr< ParameterDescriptionCases< bool > > operator||(std::unique_ptr< ParameterDescriptionCases< bool > >, std::unique_ptr< ParameterDescriptionCases< bool > >)
bool hasNestedContent() const
TEveGeoShape * clone(const TEveElement *element, TEveElement *parent)
virtual ParameterDescriptionNode * clone() const =0
static ParameterTypes toEnum()
std::unique_ptr< ParameterDescriptionNode > operator^(ParameterDescriptionNode const &node_left, ParameterDescriptionNode const &node_right)
void checkAndGetLabelsAndTypes(std::set< std::string > &usedLabels, std::set< ParameterTypes > ¶meterTypes, std::set< ParameterTypes > &wildcardTypes) const
ParameterDescriptionNode()
void writeCfi(std::ostream &os, bool &startWithComma, int indentation, bool &wroteSomething) const
ParameterDescriptionNode(Comment const &iComment)
virtual void print_(std::ostream &, bool, bool, DocFormatHelper &) const