/*============================================================================= Copyright (c) 2001-2006 Joel de Guzman 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) ==============================================================================*/ #include #include #include #include #include #include #include #include #include #include #include #include #include #include int main() { using namespace boost::fusion; std::cout << tuple_open('['); std::cout << tuple_close(']'); std::cout << tuple_delimiter(", "); /// Testing the reverse_view { typedef boost::mpl::range_c mpl_list1; mpl_list1 l; reverse_view rev(l); std::cout << rev << std::endl; BOOST_TEST((rev == make_vector(8, 7, 6, 5))); } { char const* s = "Hi Kim"; typedef vector vector_type; vector_type t(123, 'x', 123456789, s); typedef reverse_view view_type; view_type rev(t); std::cout << rev << std::endl; BOOST_TEST((rev == make_vector(s, 123456789, 'x', 123))); typedef result_of::begin::type first_type; first_type first_it(begin(rev)); typedef result_of::next::type second_type; second_type second_it(next(first_it)); BOOST_TEST((*second_it == 123456789)); BOOST_TEST((*prior(second_it) == s)); BOOST_TEST((*advance_c<2>(first_it) == 'x')); BOOST_TEST((distance(first_it, second_it) == 1)); } return boost::report_errors(); }