/*============================================================================= Copyright (c) 2001-2006 Joel de Guzman 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 #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)); BOOST_TEST((at_c<0>(rev)==s)); BOOST_TEST((at_c<1>(rev)==123456789)); BOOST_TEST((at_c<2>(rev)=='x')); BOOST_TEST((at_c<3>(rev)==123)); BOOST_MPL_ASSERT(( boost::is_same::type,char const*> )); BOOST_MPL_ASSERT(( boost::is_same::type,long> )); BOOST_MPL_ASSERT(( boost::is_same::type,char> )); BOOST_MPL_ASSERT(( boost::is_same::type,int> )); } return boost::report_errors(); }