array.cpp 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. /*=============================================================================
  2. Copyright (c) 2010 Christopher Schmidt
  3. Distributed under the Boost Software License, Version 1.0. (See accompanying
  4. file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
  5. ==============================================================================*/
  6. #include <boost/detail/lightweight_test.hpp>
  7. #include <boost/fusion/adapted/array.hpp>
  8. #include <boost/fusion/sequence/intrinsic.hpp>
  9. #include <boost/fusion/iterator.hpp>
  10. #include <boost/fusion/support/is_sequence.hpp>
  11. #include <boost/fusion/support/is_view.hpp>
  12. #include <boost/mpl/assert.hpp>
  13. int main()
  14. {
  15. using namespace boost::fusion;
  16. typedef int array_type[3];
  17. BOOST_MPL_ASSERT((traits::is_sequence<array_type>));
  18. BOOST_MPL_ASSERT_NOT((traits::is_view<array_type>));
  19. BOOST_STATIC_ASSERT(traits::is_sequence<array_type>::value);
  20. BOOST_STATIC_ASSERT(!traits::is_view<array_type>::value);
  21. array_type arr = {1,2,3};
  22. BOOST_TEST(*begin(arr) == 1);
  23. BOOST_TEST(*next(begin(arr)) == 2);
  24. BOOST_TEST(*advance_c<2>(begin(arr)) == 3);
  25. BOOST_TEST(prior(next(begin(arr))) == begin(arr));
  26. BOOST_TEST(*prior(end(arr)) == 3);
  27. BOOST_TEST(at_c<2>(arr) == 3);
  28. BOOST_TEST(size(arr) == 3);
  29. BOOST_TEST(distance(begin(arr), end(arr)) == 3);
  30. return boost::report_errors();
  31. }