X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FUtils%2FConsole%2FParse.ih;h=fffaec286a94c94e1e77594f1bf8919e3a406087;hb=ecb47e13433d59c79a74a4641a2e68648f142723;hp=8bfb8f8b28acdbc57224c770d736859eab14d3f6;hpb=9cb871b939efe93e35dd96808d25089399acfc46;p=senf.git diff --git a/senf/Utils/Console/Parse.ih b/senf/Utils/Console/Parse.ih index 8bfb8f8..fffaec2 100644 --- a/senf/Utils/Console/Parse.ih +++ b/senf/Utils/Console/Parse.ih @@ -29,10 +29,19 @@ // Custom includes #include #include -#include -#include -#include -#include + +#if HAVE_BOOST_SPIRIT_INCLUDE_CLASSIC_HPP +# include +# include +# include +# include +#else +# include +# include +# include +# include +#endif + #include ///////////////////////////////ih.p//////////////////////////////////////// @@ -41,21 +50,27 @@ namespace senf { namespace console { namespace detail { +#if HAVE_BOOST_SPIRIT_INCLUDE_CLASSIC_HPP + namespace boost_spirit = ::boost::spirit::classic; +#else + namespace boost_spirit = ::boost::spirit; +#endif + #ifndef DOXYGEN struct FilePositionWithIndex - : public boost::spirit::file_position + : public boost_spirit::file_position { int index; FilePositionWithIndex(std::string const & file_ = std::string(), int line_ = 1, int column_ = 1, int index_ = 0) - : boost::spirit::file_position (file_, line_, column_), index (index_) + : boost_spirit::file_position (file_, line_, column_), index (index_) {} bool operator==(const FilePositionWithIndex & fp) const { - return boost::spirit::file_position::operator==(fp) && index == fp.index; + return boost_spirit::file_position::operator==(fp) && index == fp.index; } }; @@ -71,7 +86,7 @@ namespace detail { // Grammar template - struct CommandGrammar : boost::spirit::grammar > + struct CommandGrammar : boost_spirit::grammar > { /////////////////////////////////////////////////////////////////////////// // Start rules @@ -106,12 +121,12 @@ namespace detail { ////////////////////////////////////////////////////////////////////////// // charachter sets - static boost::spirit::chset<> special_p; - static boost::spirit::chset<> punctuation_p; - static boost::spirit::chset<> space_p; - static boost::spirit::chset<> invalid_p; - static boost::spirit::chset<> word_p; - static boost::spirit::distinct_parser<> keyword_p; + static boost_spirit::chset<> special_p; + static boost_spirit::chset<> punctuation_p; + static boost_spirit::chset<> space_p; + static boost_spirit::chset<> invalid_p; + static boost_spirit::chset<> word_p; + static boost_spirit::distinct_parser<> keyword_p; /////////////////////////////////////////////////////////////////////////// // Errors @@ -130,19 +145,19 @@ namespace detail { template struct definition - : public boost::spirit::grammar_def< boost::spirit::rule, - boost::spirit::rule, - boost::spirit::rule, - boost::spirit::rule > + : public boost_spirit::grammar_def< boost_spirit::rule, + boost_spirit::rule, + boost_spirit::rule, + boost_spirit::rule > { - boost::spirit::rule command, path, argument, word, string, hexstring, token, - punctuation, hexbyte, balanced_tokens, simple_argument, complex_argument, builtin, - skip, statement, relpath, abspath, arguments, group_start, group_close, - statement_end, opt_path; + boost_spirit::rule command, path, argument, word, string, hexstring, + word_or_string, token, punctuation, hexbyte, balanced_tokens, simple_argument, + complex_argument, builtin, skip, statement, relpath, abspath, arguments, + group_start, group_close, statement_end, opt_path; definition(CommandGrammar const & self) { - using namespace boost::spirit; + using namespace boost_spirit; using namespace ::phoenix; using namespace senf::phoenix; typedef ParseDispatcher PD; @@ -292,7 +307,7 @@ namespace detail { ; relpath - = ( word [ push_back(path_, token_) ] + = ( word_or_string [ push_back(path_, token_) ] % +ch_p('/') ) >> ( ! (+ch_p('/') ) [ push_back(path_, construct_()) ] ) ; @@ -360,6 +375,11 @@ namespace detail { pos_) ] ; + word_or_string + = word + | string + ; + hexbyte = uint_parser() [ push_back(str_, arg1) ] @@ -410,18 +430,18 @@ namespace detail { }; }; - template boost::spirit::chset<> CommandGrammar::special_p ( + template boost_spirit::chset<> CommandGrammar::special_p ( "/(){};\""); - template boost::spirit::chset<> CommandGrammar::punctuation_p ( + template boost_spirit::chset<> CommandGrammar::punctuation_p ( ",="); - template boost::spirit::chset<> CommandGrammar::space_p ( + template boost_spirit::chset<> CommandGrammar::space_p ( " \t\n\r"); - template boost::spirit::chset<> CommandGrammar::invalid_p ( - (boost::spirit::chset<>('\0') | boost::spirit::chset<>("\x01-\x20")) - space_p ); - template boost::spirit::chset<> CommandGrammar::word_p ( - boost::spirit::anychar_p - special_p - punctuation_p - space_p - invalid_p); - template boost::spirit::distinct_parser<> CommandGrammar::keyword_p ( - word_p | boost::spirit::ch_p('/')); + template boost_spirit::chset<> CommandGrammar::invalid_p ( + (boost_spirit::chset<>('\0') | boost_spirit::chset<>("\x01-\x20")) - space_p ); + template boost_spirit::chset<> CommandGrammar::word_p ( + boost_spirit::anychar_p - special_p - punctuation_p - space_p - invalid_p); + template boost_spirit::distinct_parser<> CommandGrammar::keyword_p ( + word_p | boost_spirit::ch_p('/')); #endif