1 // Copyright (c) 2001-2011 Hartmut Kaiser 2 // Copyright (c) 2001-2011 Joel de Guzman 3 // Copyright (c) 2009 Carl Barron 4 // 5 // Distributed under the Boost Software License, Version 1.0. (See accompanying 6 // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) 7 8 #if !defined(BOOST_PP_IS_ITERATING) 9 10 #if !defined(BOOST_SPIRIT_LEXER_PARSE_ATTR_MAY_27_2009_0926AM) 11 #define BOOST_SPIRIT_LEXER_PARSE_ATTR_MAY_27_2009_0926AM 12 13 #include <boost/spirit/home/lex/tokenize_and_parse.hpp> 14 15 #include <boost/fusion/include/vector.hpp> 16 #include <boost/preprocessor/cat.hpp> 17 #include <boost/preprocessor/iterate.hpp> 18 #include <boost/preprocessor/repetition/enum.hpp> 19 #include <boost/preprocessor/repetition/enum_params.hpp> 20 #include <boost/preprocessor/repetition/enum_binary_params.hpp> 21 22 #define BOOST_PP_FILENAME_1 <boost/spirit/home/lex/tokenize_and_parse_attr.hpp> 23 #define BOOST_PP_ITERATION_LIMITS (2, SPIRIT_ARGUMENTS_LIMIT) 24 #include BOOST_PP_ITERATE() 25 26 #endif 27 28 /////////////////////////////////////////////////////////////////////////////// 29 // 30 // Preprocessor vertical repetition code 31 // 32 /////////////////////////////////////////////////////////////////////////////// 33 #else // defined(BOOST_PP_IS_ITERATING) 34 35 #define N BOOST_PP_ITERATION() 36 #define BOOST_SPIRIT_QI_ATTRIBUTE_REFERENCE(z, n, A) BOOST_PP_CAT(A, n)& 37 38 namespace boost { namespace spirit { namespace lex 39 { 40 template <typename Iterator, typename Lexer, typename ParserExpr 41 , BOOST_PP_ENUM_PARAMS(N, typename A)> 42 inline bool tokenize_and_parse(Iterator & first,Iterator last,Lexer const & lex,ParserExpr const & expr,BOOST_PP_ENUM_BINARY_PARAMS (N,A,& attr))43 tokenize_and_parse(Iterator& first, Iterator last, Lexer const& lex 44 , ParserExpr const& expr, BOOST_PP_ENUM_BINARY_PARAMS(N, A, & attr)) 45 { 46 // Report invalid expression error as early as possible. 47 // If you got an error_invalid_expression error message here, 48 // then the expression (expr) is not a valid spirit qi expression. 49 BOOST_SPIRIT_ASSERT_MATCH(qi::domain, ParserExpr); 50 51 typedef fusion::vector< 52 BOOST_PP_ENUM(N, BOOST_SPIRIT_QI_ATTRIBUTE_REFERENCE, A) 53 > vector_type; 54 55 vector_type attr (BOOST_PP_ENUM_PARAMS(N, attr)); 56 typename Lexer::iterator_type iter = lex.begin(first, last); 57 return compile<qi::domain>(expr).parse( 58 iter, lex.end(), unused, unused, attr); 59 } 60 }}} 61 62 #undef BOOST_SPIRIT_QI_ATTRIBUTE_REFERENCE 63 #undef N 64 65 #endif 66 67