/*============================================================================= Copyright (c) 2009 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 struct test { int int_; std::string string_; double double_; }; BOOST_FUSION_ADAPT_STRUCT( test, (int, int_) (std::string, string_) (double, double_) ) namespace fusion = boost::fusion; template bool check_size(Sequence const& s, int seqsize) { return fusion::size(s) == seqsize; } template bool check_deref_begin(Sequence const& s, T val) { return fusion::deref(fusion::begin(s)) == val; } template bool check_deref_next(Sequence const& s, T val) { return fusion::deref(fusion::next(fusion::begin(s))) == val; } template bool check_deref_advance(Sequence const& s, T val) { return fusion::deref(fusion::advance_c(fusion::begin(s))) == val; } template bool check_deref_prior(Sequence const& s, T val) { return fusion::deref(fusion::prior(fusion::end(s))) == val; } template bool check_at(Sequence const& s, T val) { return fusion::at_c(s) == val; } template bool check_distance(Sequence const& s, int val) { return fusion::distance(fusion::begin(s), fusion::end(s)) == val; } int main() { test t; t.int_ = 1; t.string_ = "test"; t.double_ = 2.0; using fusion::as_nview; // check size() { BOOST_TEST(check_size(as_nview<0>(t), 1)); BOOST_TEST(check_size(as_nview<2, 1>(t), 2)); BOOST_TEST(check_size(as_nview<2, 1, 0>(t), 3)); BOOST_TEST(check_size(as_nview<2, 1, 0, 2, 0>(t), 5)); } // check deref/begin { BOOST_TEST(check_deref_begin(as_nview<0>(t), 1)); BOOST_TEST(check_deref_begin(as_nview<2, 1>(t), 2.0)); BOOST_TEST(check_deref_begin(as_nview<1, 2, 0>(t), "test")); BOOST_TEST(check_deref_begin(as_nview<2, 1, 0, 2, 0>(t), 2.0)); } // check deref/next { BOOST_TEST(check_deref_next(as_nview<2, 1>(t), "test")); BOOST_TEST(check_deref_next(as_nview<1, 2, 0>(t), 2.0)); BOOST_TEST(check_deref_next(as_nview<2, 0, 1, 2, 0>(t), 1)); } // check deref/advance { BOOST_TEST(check_deref_advance<0>(as_nview<2, 1>(t), 2.0)); BOOST_TEST(check_deref_advance<2>(as_nview<1, 2, 0>(t), 1)); BOOST_TEST(check_deref_advance<4>(as_nview<2, 0, 1, 2, 0>(t), 1)); } // check deref/prior { BOOST_TEST(check_deref_prior(as_nview<2, 1>(t), "test")); BOOST_TEST(check_deref_prior(as_nview<1, 2, 0>(t), 1)); BOOST_TEST(check_deref_prior(as_nview<2, 0, 1, 2, 0>(t), 1)); } // check at { BOOST_TEST(check_at<0>(as_nview<0>(t), 1)); BOOST_TEST(check_at<1>(as_nview<2, 1>(t), "test")); BOOST_TEST(check_at<2>(as_nview<1, 2, 0>(t), 1)); BOOST_TEST(check_at<4>(as_nview<2, 1, 0, 2, 0>(t), 1)); } // check distance { BOOST_TEST(check_distance(as_nview<0>(t), 1)); BOOST_TEST(check_distance(as_nview<2, 1>(t), 2)); BOOST_TEST(check_distance(as_nview<1, 2, 0>(t), 3)); BOOST_TEST(check_distance(as_nview<2, 1, 0, 2, 0>(t), 5)); } return boost::report_errors(); }