zip_view.cpp 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. /*=============================================================================
  2. Copyright (c) 2001-2011 Joel de Guzman
  3. Copyright (c) 2006 Dan Marsden
  4. Distributed under the Boost Software License, Version 1.0. (See accompanying
  5. file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
  6. ==============================================================================*/
  7. #include <boost/detail/lightweight_test.hpp>
  8. #include <boost/fusion/support/category_of.hpp>
  9. #include <boost/fusion/view/zip_view.hpp>
  10. #include <boost/fusion/container/vector.hpp>
  11. #include <boost/fusion/container/list.hpp>
  12. #include <boost/fusion/sequence/intrinsic/size.hpp>
  13. #include <boost/fusion/sequence/intrinsic/at.hpp>
  14. #include <boost/fusion/sequence/intrinsic/front.hpp>
  15. #include <boost/fusion/sequence/intrinsic/back.hpp>
  16. #include <boost/fusion/iterator/next.hpp>
  17. #include <boost/fusion/iterator/prior.hpp>
  18. #include <boost/fusion/iterator/deref.hpp>
  19. #include <boost/fusion/iterator/advance.hpp>
  20. #include <boost/fusion/sequence/comparison/equal_to.hpp>
  21. #include <boost/fusion/container/generation/make_vector.hpp>
  22. #include <boost/fusion/adapted/mpl.hpp>
  23. #include <boost/mpl/assert.hpp>
  24. #include <boost/mpl/equal_to.hpp>
  25. #include <boost/mpl/vector_c.hpp>
  26. #include <boost/type_traits/is_reference.hpp>
  27. #include <boost/type_traits/is_same.hpp>
  28. #include <boost/static_assert.hpp>
  29. int main()
  30. {
  31. using namespace boost::fusion;
  32. {
  33. typedef vector2<int,int> int_vector;
  34. typedef vector2<char,char> char_vector;
  35. typedef vector<int_vector&, char_vector&> seqs_type;
  36. typedef zip_view<seqs_type> view;
  37. BOOST_MPL_ASSERT((boost::mpl::equal_to<boost::fusion::result_of::size<view>::type, boost::fusion::result_of::size<int_vector>::type>));
  38. BOOST_STATIC_ASSERT((boost::fusion::result_of::size<view>::value == 2));
  39. int_vector iv(1,2);
  40. char_vector cv('a', 'b');
  41. seqs_type seqs(iv, cv);
  42. view v(seqs);
  43. BOOST_TEST(at_c<0>(v) == make_vector(1, 'a'));
  44. BOOST_TEST(at_c<1>(v) == make_vector(2, 'b'));
  45. BOOST_TEST(front(v) == make_vector(1, 'a'));
  46. BOOST_TEST(back(v) == make_vector(2, 'b'));
  47. BOOST_TEST(*next(begin(v)) == make_vector(2, 'b'));
  48. BOOST_TEST(*prior(end(v)) == make_vector(2, 'b'));
  49. BOOST_TEST(advance_c<2>(begin(v)) == end(v));
  50. BOOST_TEST(advance_c<-2>(end(v)) == begin(v));
  51. BOOST_TEST(distance(begin(v), end(v)) == 2);
  52. BOOST_STATIC_ASSERT((boost::fusion::result_of::distance<boost::fusion::result_of::begin<view>::type, boost::fusion::result_of::end<view>::type>::value == 2));
  53. BOOST_MPL_ASSERT((boost::is_same<boost::fusion::result_of::value_at_c<view,0>::type, vector2<int,char> >));
  54. BOOST_MPL_ASSERT((boost::is_same<boost::fusion::result_of::value_of<boost::fusion::result_of::begin<view>::type>::type, vector2<int,char> >));
  55. }
  56. {
  57. using namespace boost;
  58. typedef mpl::vector2<int,bool> v1_type;
  59. typedef mpl::vector2<char,long> v2_type;
  60. typedef fusion::vector<v1_type&, v2_type&> seqs_type;
  61. typedef fusion::zip_view<seqs_type> view;
  62. v1_type v1;
  63. v2_type v2;
  64. seqs_type seqs(v1,v2);
  65. view v(seqs);
  66. BOOST_TEST((fusion::at_c<0>(v) == mpl::vector2<int,char>()));
  67. BOOST_TEST((fusion::at_c<1>(v) == mpl::vector2<bool,long>()));
  68. BOOST_TEST((fusion::front(v) == mpl::vector2<int,char>()));
  69. BOOST_TEST((fusion::back(v) == mpl::vector2<bool,long>()));
  70. BOOST_TEST((*fusion::next(fusion::begin(v)) == mpl::vector2<bool,long>()));
  71. BOOST_TEST((*fusion::prior(fusion::end(v)) == mpl::vector2<bool,long>()));
  72. BOOST_TEST(fusion::advance_c<2>(fusion::begin(v)) == fusion::end(v));
  73. BOOST_TEST(fusion::advance_c<-2>(fusion::end(v)) == fusion::begin(v));
  74. BOOST_TEST(fusion::distance(fusion::begin(v), fusion::end(v)) == 2);
  75. }
  76. return boost::report_errors();
  77. }