/*============================================================================= Copyright (c) 1998-2003 Joel de Guzman Copyright (c) 2001 Daniel Nuffer Copyright (c) 2002 Hartmut Kaiser http://spirit.sourceforge.net/ Use, modification and distribution is subject to the Boost Software License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) =============================================================================*/ #if !defined(BOOST_SPIRIT_KLEENE_STAR_HPP) #define BOOST_SPIRIT_KLEENE_STAR_HPP #include #include #include #include namespace boost { namespace spirit { /////////////////////////////////////////////////////////////////////////// // // kleene_star class // // Handles expressions of the form: // // *a // // where a is a parser. The expression returns a composite // parser that matches its subject zero (0) or more times. // /////////////////////////////////////////////////////////////////////////// struct kleene_star_parser_gen; template struct kleene_star : public unary > > { typedef kleene_star self_t; typedef unary_parser_category parser_category_t; typedef kleene_star_parser_gen parser_generator_t; typedef unary > base_t; kleene_star(S const& a) : base_t(a) {} template typename parser_result::type parse(ScannerT const& scan) const { typedef typename parser_result::type result_t; typedef typename ScannerT::iterator_t iterator_t; result_t hit = scan.empty_match(); for (;;) { iterator_t save = scan.first; if (result_t next = this->subject().parse(scan)) { scan.concat_match(hit, next); } else { scan.first = save; return hit; } } } }; struct kleene_star_parser_gen { template struct result { typedef kleene_star type; }; template static kleene_star generate(parser const& a) { return kleene_star(a.derived()); } }; ////////////////////////////////// template kleene_star operator*(parser const& a); }} // namespace boost::spirit #endif #include