Example : match recursive braces
case 1 : ( () ) --> match
case 2 : ( --> unmatch
case 3 : (() ()) --> match
case 4 : ((((( ))))) --> match
case 5 : (((( ( )))) --> match
Following grammar can detect case1~case5
Following grammar can detect case1~case5
template<typename Iterator> struct recursiveBraces : qi::grammar<Iterator, qi::ascii::space_type> { recursiveBraces() : recursiveBraces::base_type(finalRules) { braces = "(" >> *expression >> ")"; expression = +braces; } qi::rule<Iterator, qi::ascii::space_type> braces; qi::rule<Iterator, qi::ascii::space_type> expression; };
braces call expression, expression call braces, so the form a recursive loop.If we do some enhancement, we could match more complicated pattern.
case 6 : (() ()) ((())) (()) --> match
case 7 : (() ()) ((( ( ))) (()) --> umatch
template<typename Iterator> struct recursiveBraces : qi::grammar<Iterator, qi::ascii::space_type> { recursiveBraces() : recursiveBraces::base_type(finalRules) { braces = "(" >> *expression >> ")"; expression = +braces; finalRules += expression; } qi::rule<Iterator, qi::ascii::space_type> braces; qi::rule<Iterator, qi::ascii::space_type> expression; qi::rule<Iterator, qi::ascii::space_type> finalRules; };
The grammar express by spirit are elegant and easy to read(you do need to invest your times to study the tutorial), the performance are very good too.It is worth to have some play with it.The full codes are available at github.
No comments:
Post a Comment