// Copyright (c) 2001-2010 Hartmut Kaiser // // Distributed under 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) #include #include #include #include #include #include #include #include #include #include #include #include #include "test.hpp" using namespace spirit_test; /////////////////////////////////////////////////////////////////////////////// int main() { using namespace boost; using namespace boost::spirit; using namespace boost::spirit::ascii; typedef spirit_test::output_iterator::type outiter_type; // test rule parameter propagation { using boost::phoenix::at_c; karma::rule()> start; fusion::vector vec('a', 10, 12.4); start %= char_ << int_ << double_; BOOST_TEST(test("a1012.4", start, vec)); karma::rule a; karma::rule b; karma::rule c; a %= char_ << eps; b %= int_; c %= double_; start = a[_1 = at_c<0>(_r0)] << b[_1 = at_c<1>(_r0)] << c[_1 = at_c<2>(_r0)]; BOOST_TEST(test("a1012.4", start, vec)); start = (a << b << c)[(_1 = at_c<0>(_r0), _2 = at_c<1>(_r0), _3 = at_c<2>(_r0))]; BOOST_TEST(test("a1012.4", start, vec)); start = a << b << c; BOOST_TEST(test("a1012.4", start, vec)); start %= a << b << c; BOOST_TEST(test("a1012.4", start, vec)); } { using boost::phoenix::at_c; karma::rule()> start; fusion::vector vec('a', 10, 12.4); start %= char_ << int_ << double_; BOOST_TEST(test_delimited("a 10 12.4 ", start, vec, space)); karma::rule a; karma::rule b; karma::rule c; a %= char_ << eps; b %= int_; c %= double_; start = a[_1 = at_c<0>(_r0)] << b[_1 = at_c<1>(_r0)] << c[_1 = at_c<2>(_r0)]; BOOST_TEST(test_delimited("a 10 12.4 ", start, vec, space)); start = (a << b << c)[(_1 = at_c<0>(_r0), _2 = at_c<1>(_r0), _3 = at_c<2>(_r0))]; BOOST_TEST(test_delimited("a 10 12.4 ", start, vec, space)); start = a << b << c; BOOST_TEST(test_delimited("a 10 12.4 ", start, vec, space)); start %= a << b << c; BOOST_TEST(test_delimited("a 10 12.4 ", start, vec, space)); } // test direct initialization { using boost::phoenix::at_c; fusion::vector vec('a', 10, 12.4); karma::rule()> start = char_ << int_ << double_;; BOOST_TEST(test_delimited("a 10 12.4 ", start, vec, space)); karma::rule a = char_ << eps; karma::rule b = int_; karma::rule c = double_; start = a[_1 = at_c<0>(_r0)] << b[_1 = at_c<1>(_r0)] << c[_1 = at_c<2>(_r0)]; BOOST_TEST(test_delimited("a 10 12.4 ", start, vec, space)); } return boost::report_errors(); }