1 #ifndef FWCore_ParameterSet_ParameterDescriptionNode_h 2 #define FWCore_ParameterSet_ParameterDescriptionNode_h 22 class ParameterDescriptionCases;
23 class DocFormatHelper;
73 explicit Comment(
char const* iComment);
92 void setComment(
char const* value);
101 validate_(pset, validatedLabels, optional);
114 void writeCfi(std::ostream& os,
bool& startWithComma,
int indentation,
bool& wroteSomething)
const {
115 writeCfi_(os, startWithComma, indentation, wroteSomething);
123 void printNestedContent(std::ostream& os,
bool optional,
DocFormatHelper& dfh)
const;
206 std::set<ParameterTypes>& parameterTypes,
207 std::set<ParameterTypes>& wildcardTypes)
const {
208 checkAndGetLabelsAndTypes_(usedLabels, parameterTypes, wildcardTypes);
211 static void printSpaces(std::ostream& os,
int n);
214 virtual void checkAndGetLabelsAndTypes_(std::set<std::string>& usedLabels,
215 std::set<ParameterTypes>& parameterTypes,
216 std::set<ParameterTypes>& wildcardTypes)
const = 0;
218 virtual void validate_(
ParameterSet&
pset, std::set<std::string>& validatedLabels,
bool optional)
const = 0;
220 virtual void writeCfi_(std::ostream& os,
bool& startWithComma,
int indentation,
bool& wroteSomething)
const = 0;
228 virtual bool exists_(
ParameterSet const& pset)
const = 0;
230 virtual bool partiallyExists_(
ParameterSet const& pset)
const = 0;
232 virtual int howManyXORSubNodesExist_(
ParameterSet const& pset)
const = 0;
252 std::unique_ptr<ParameterDescriptionCases<std::string> >
operator>>(
char const* caseValue,
255 std::unique_ptr<ParameterDescriptionCases<bool> >
operator>>(
bool caseValue,
256 std::unique_ptr<ParameterDescriptionNode> node);
258 std::unique_ptr<ParameterDescriptionCases<int> >
operator>>(
int caseValue,
259 std::unique_ptr<ParameterDescriptionNode> node);
262 std::unique_ptr<ParameterDescriptionNode> node);
264 std::unique_ptr<ParameterDescriptionCases<std::string> >
operator>>(
char const* caseValue,
265 std::unique_ptr<ParameterDescriptionNode> node);
272 std::unique_ptr<ParameterDescriptionNode>
operator&&(std::unique_ptr<ParameterDescriptionNode> node_left,
276 std::unique_ptr<ParameterDescriptionNode> node_right);
278 std::unique_ptr<ParameterDescriptionNode>
operator&&(std::unique_ptr<ParameterDescriptionNode> node_left,
279 std::unique_ptr<ParameterDescriptionNode> node_right);
286 std::unique_ptr<ParameterDescriptionNode>
operator||(std::unique_ptr<ParameterDescriptionNode> node_left,
290 std::unique_ptr<ParameterDescriptionNode> node_right);
292 std::unique_ptr<ParameterDescriptionNode>
operator||(std::unique_ptr<ParameterDescriptionNode> node_left,
293 std::unique_ptr<ParameterDescriptionNode> node_right);
300 std::unique_ptr<ParameterDescriptionNode>
operator^(std::unique_ptr<ParameterDescriptionNode> node_left,
304 std::unique_ptr<ParameterDescriptionNode> node_right);
306 std::unique_ptr<ParameterDescriptionNode>
operator^(std::unique_ptr<ParameterDescriptionNode> node_left,
307 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()
static void destroy(ParameterDescriptionNode *p)
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