1 #ifndef JOBOPTIONSVC_GRAMMAR_H_ 2 #define JOBOPTIONSVC_GRAMMAR_H_ 14 #include <boost/spirit/include/phoenix_core.hpp> 15 #include <boost/spirit/include/phoenix_fusion.hpp> 16 #include <boost/spirit/include/phoenix_operator.hpp> 17 #include <boost/spirit/include/phoenix_stl.hpp> 18 #include <boost/spirit/include/qi.hpp> 19 #include <boost/spirit/repository/include/qi_confix.hpp> 20 #include <boost/spirit/repository/include/qi_iter_pos.hpp> 33 namespace ph = boost::phoenix;
34 namespace qi = sp::qi;
35 namespace enc = sp::ascii;
36 namespace rep = sp::repository;
40 template <
typename Iterator>
43 comments = enc::space | rep::confix(
"/*",
"*/" )[*( qi::char_ -
"*/" )] |
44 rep::confix(
"//", ( sp::eol | sp::eoi ) )[*( qi::char_ - ( sp::eol | sp::eoi ) )];
49 template <
typename Iterator,
typename Skipper>
50 struct StringGrammar : qi::grammar<Iterator, std::string(), qi::locals<char>, Skipper> {
55 begin_quote = enc::char_(
"\"'" );
56 quote = enc::char_( qi::_r1 );
58 str = qi::lexeme[begin_quote[qi::_a = qi::_1] >>
59 *( ( enc::char_(
'\\' ) >> quote( qi::_a ) )[qi::_val += qi::_a] |
60 ( enc::char_[qi::_val += qi::_1] - quote( qi::_a ) ) ) >>
64 qi::rule<Iterator, std::string(), qi::locals<char>,
Skipper>
str;
66 qi::rule<Iterator, void( char )>
quote;
70 template <
typename Iterator,
typename Skipper>
77 rep::qi::iter_pos[op( qi::_val, qi::_1 )] >> str[op( qi::_val, qi::_1 )][op( qi::_val,
Node::kIdentifier )];
78 str = -qi::lit(
"::" )[qi::_val +=
"::"] >> inner[qi::_val += qi::_1] >>
79 *( qi::lit(
"::" ) >> inner[qi::_val += (
"::" + qi::_1 )] );
80 inner = qi::alpha >> *( qi::alnum | qi::char_(
'_' ) );
83 qi::rule<Iterator, Node(), Skipper>
ident;
84 qi::rule<Iterator, std::string(), Skipper>
str;
85 qi::rule<Iterator, std::string()>
inner;
86 ph::function<NodeOperations>
op;
89 template <
typename Iterator,
typename Skipper>
95 boolean = enc::no_case[qi::lit(
"true" )[qi::_val =
true] | qi::lit(
"false" )[qi::_val =
false]];
98 qi::rule<Iterator, bool(), Skipper>
boolean;
101 template <
typename Iterator,
typename Skipper>
107 real = qi::raw[qi::double_][op( qi::_val, qi::_1 )][op( qi::_val,
Node::kReal )] >> -qi::char_(
'L' ) >>
108 -( -qi::char_(
'*' ) >> gunit[op( qi::_val, qi::_1 )] );
111 qi::rule<Iterator, Node(), Skipper>
real;
113 ph::function<NodeOperations>
op;
116 template <
typename Iterator,
typename Skipper>
120 units = *unit[op( qi::_val, qi::_1 )];
121 unit = rep::qi::iter_pos[op( qi::_val, qi::_1 )] >> val[op( qi::_val, qi::_1 )] >> -qi::lit(
'*' ) >>
122 gunit[op( qi::_val, qi::_1 )] >> qi::lit(
'=' ) >>
123 val[op( qi::_val, qi::_1 )][op( qi::_val,
Node::kUnit )];
125 val = qi::raw[qi::double_][op( qi::_val, qi::_1 )][op( qi::_val,
Node::kReal )];
128 qi::rule<Iterator, Node(), Skipper> units, unit,
val;
130 ph::function<NodeOperations>
op;
133 template <
typename Iterator,
typename Skipper>
136 file = -shell[op( qi::_val, qi::_1 )] >> *( statement[op( qi::_val, qi::_1 )] )[op( qi::_val,
Node::kRoot )];
139 qi::eol )[*( qi::char_[qi::_a += qi::_1] - qi::eol )][op( qi::_val,
Node::kShell )][op( qi::_val, qi::_a )];
140 statement = rep::qi::iter_pos[qi::_a = qi::_1] >> ( include | assign | units | print_options | pragma |
141 condition )[qi::_val = qi::_1][op( qi::_val, qi::_a )];
144 property[op( qi::_val, qi::_1 )] >> ( *statement[op( qi::_a, qi::_1 )] )[op( qi::_val, qi::_a )] >>
145 -( qi::lit(
"#else" )[op( qi::_b,
Node::kElse )] >>
146 *statement[op( qi::_b, qi::_1 )] )[op( qi::_val, qi::_b )] >>
148 include = qi::lit(
"#include" ) >> gstring[op( qi::_val, qi::_1 )][op( qi::_val,
Node::kInclude )];
149 units = qi::lit(
"#units" ) >> gstring[op( qi::_val, qi::_1 )][op( qi::_val,
Node::kUnits )];
150 print_options = qi::lit(
"#printOptions" ) >> qi::lit(
"full" )[op( qi::_val,
Node::kPrintOptions )];
151 pragma = qi::lit(
"#pragma" ) >> ( pragma_print | pragma_tree | pragma_dump_file );
152 pragma_print = qi::lit(
"print" ) >> enc::no_case[qi::lit(
"on" )[op( qi::_val,
Node::kPrintOn )] |
154 pragma_tree = enc::no_case[qi::lit(
"printtree" )[op( qi::_val,
Node::kPrintTree )]];
155 pragma_dump_file = qi::lit(
"dumpfile" ) >> gstring[op( qi::_val, qi::_1 )][op( qi::_val,
Node::kDumpFile )];
156 assign =
property[op( qi::_val, qi::_1 )][op( qi::_val,
Node::kAssign )] >> oper[op( qi::_val, qi::_1 )] >>
157 value[op( qi::_val, qi::_1 )] >>
';';
158 property = rep::qi::iter_pos[op( qi::_val, qi::_1 )] >>
159 ( gidentifier[op( qi::_val, qi::_1 )] %
'.' )[op( qi::_val,
Node::kProperty )];
161 oper = rep::qi::iter_pos[op( qi::_val, qi::_1 )] >>
164 value = rep::qi::iter_pos[qi::_a = qi::_1] >> ( map_value | vector_value | simple_value |
property |
165 property_ref )[qi::_val = qi::_1][op( qi::_val, qi::_a )];
167 enc::char_(
'(' )[qi::_val =
')'] | enc::char_(
'[' )[qi::_val =
']'] | enc::char_(
'{' )[qi::_val =
'}'];
168 end_vector = qi::char_( qi::_r1 );
169 vector_value = ( begin_vector[qi::_a = qi::_1] >> -( value[op( qi::_val, qi::_1 )] %
',' ) >>
171 map_value = ( enc::char_(
'{' ) >> -( pair[op( qi::_val, qi::_1 )] %
',' ) >>
172 enc::char_(
'}' ) )[op( qi::_val,
Node::kMap )];
174 simple_value[op( qi::_val, qi::_1 )] >>
':' >> value[op( qi::_val, qi::_1 )][op( qi::_val,
Node::kPair )];
175 simple_value = ( gstring[op( qi::_val, qi::_1 )][op( qi::_val,
Node::kString )] ) |
176 ( gbool[op( qi::_val, qi::_1 )][op( qi::_val,
Node::kBool )] ) | ( greal[qi::_val = qi::_1] );
178 qi::rule<Iterator, Node(), Skipper> file, include, assign,
property, property_ref, oper, map_value, pair_value,
179 simple_value, pair,
units, print_options, pragma, pragma_print, pragma_tree, pragma_dump_file;
180 qi::rule<Iterator, Node(), qi::locals<std::string>>
shell;
181 qi::rule<Iterator, Node(), qi::locals<Iterator>,
Skipper> statement,
value;
190 ph::function<NodeOperations>
op;
196 #endif // JOBOPTIONSVC_GRAMMAR_H_
qi::rule< Iterator, Node(), qi::locals< std::string > > shell
qi::rule< Iterator, void(char)> end_vector
qi::rule< Iterator, Node(), qi::locals< Node, Node >, Skipper > condition
qi::rule< Iterator > comments
qi::rule< Iterator, std::string(), Skipper > str
IdentifierGrammar< Iterator, Skipper > gidentifier
Gaudi::Details::PropertyBase * property(const std::string &name) const
RealGrammar< Iterator, Skipper > greal
qi::rule< Iterator, void(char)> quote
IdentifierGrammar< Iterator, Skipper > gunit
qi::rule< Iterator, Node(), qi::locals< Iterator >, Skipper > value
ph::function< NodeOperations > op
qi::rule< Iterator, Node(), Skipper > real
BoolGrammar< Iterator, Skipper > gbool
qi::rule< Iterator, Node(), Skipper > val
ph::function< NodeOperations > op
qi::rule< Iterator, char()> begin_vector
qi::rule< Iterator, Node(), qi::locals< char >, Skipper > vector_value
qi::rule< Iterator, Node(), Skipper > units
qi::rule< Iterator, Node(), Skipper > ident
IdentifierGrammar< Iterator, Skipper > gunit
qi::rule< Iterator, std::string()> inner
qi::rule< Iterator, bool(), Skipper > boolean
qi::rule< Iterator, std::string(), qi::locals< char >, Skipper > str
StringGrammar< Iterator, Skipper > gstring
ph::function< NodeOperations > op
ph::function< NodeOperations > op
Helper functions to set/get the application return code.
qi::rule< Iterator, char()> begin_quote