123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224 |
- /*=============================================================================
- Copyright (c) 2001-2011 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)
- ==============================================================================*/
- #if !defined(FUSION_BOOST_TUPLE_ITERATOR_09262006_1851)
- #define FUSION_BOOST_TUPLE_ITERATOR_09262006_1851
- #include <boost/fusion/support/config.hpp>
- #include <boost/fusion/iterator/iterator_facade.hpp>
- #include <boost/type_traits/is_const.hpp>
- #include <boost/type_traits/add_const.hpp>
- #include <boost/mpl/identity.hpp>
- #include <boost/mpl/if.hpp>
- #include <boost/mpl/eval_if.hpp>
- #include <boost/mpl/or.hpp>
- #include <boost/mpl/plus.hpp>
- #include <boost/mpl/int.hpp>
- #include <boost/mpl/apply.hpp>
- #include <boost/tuple/tuple.hpp>
- namespace boost { namespace fusion
- {
- struct forward_traversal_tag;
- namespace detail
- {
- template <typename T>
- struct boost_tuple_is_empty : mpl::false_ {};
- template <>
- struct boost_tuple_is_empty<tuples::null_type> : mpl::true_ {};
- template <>
- struct boost_tuple_is_empty<tuples::null_type const> : mpl::true_ {};
- template <>
- struct boost_tuple_is_empty<tuples::tuple<> > : mpl::true_ {};
- template <>
- struct boost_tuple_is_empty<tuples::tuple<> const> : mpl::true_ {};
- }
- template <typename Cons>
- struct boost_tuple_iterator_identity;
- #ifdef _MSC_VER
- # pragma warning(push)
- # pragma warning(disable: 4512) // assignment operator could not be generated.
- #endif
- template <typename Cons = tuples::null_type>
- struct boost_tuple_iterator
- : iterator_facade<boost_tuple_iterator<Cons>, forward_traversal_tag>
- {
- typedef Cons cons_type;
- typedef boost_tuple_iterator_identity<
- typename add_const<Cons>::type> identity;
- BOOST_FUSION_GPU_ENABLED
- explicit boost_tuple_iterator(Cons& in_cons)
- : cons(in_cons) {}
- Cons& cons;
- template <typename Iterator>
- struct value_of : mpl::identity<typename Iterator::cons_type::head_type> {};
- template <typename Iterator>
- struct deref
- {
- typedef typename value_of<Iterator>::type element;
- typedef typename
- mpl::if_<
- is_const<typename Iterator::cons_type>
- , typename tuples::access_traits<element>::const_type
- , typename tuples::access_traits<element>::non_const_type
- >::type
- type;
- BOOST_FUSION_GPU_ENABLED
- static type
- call(Iterator const& iter)
- {
- return iter.cons.get_head();
- }
- };
- template <typename Iterator>
- struct next
- {
- typedef typename Iterator::cons_type cons_type;
- typedef typename cons_type::tail_type tail_type;
- typedef boost_tuple_iterator<
- typename mpl::eval_if<
- is_const<cons_type>
- , add_const<tail_type>
- , mpl::identity<tail_type>
- >::type>
- type;
- BOOST_FUSION_GPU_ENABLED
- static type
- call(Iterator const& iter)
- {
- return type(iter.cons.get_tail());
- }
- };
- template <typename I1, typename I2>
- struct distance;
- // detail
- template <typename I1, typename I2>
- struct lazy_next_distance
- {
- typedef
- typename mpl::plus<
- mpl::int_<1>,
- typename distance<
- typename next<I1>::type,
- I2
- >::type
- >::type type;
- };
- template <typename I1, typename I2>
- struct distance
- {
- typedef typename mpl::eval_if<
- boost::is_same<I1, I2>,
- mpl::int_<0>,
- lazy_next_distance<I1, I2>
- >::type type;
- BOOST_FUSION_GPU_ENABLED
- static type
- call(I1 const&, I2 const&)
- {
- return type();
- }
- };
- template <typename I1, typename I2>
- struct equal_to
- : is_same<typename I1::identity, typename I2::identity>
- {};
- };
- #ifdef _MSC_VER
- # pragma warning(pop)
- #endif
- template <typename Null>
- struct boost_tuple_null_iterator
- : iterator_facade<boost_tuple_iterator<Null>, forward_traversal_tag>
- {
- typedef Null cons_type;
- typedef boost_tuple_iterator_identity<
- typename add_const<Null>::type> identity;
- template <typename I1, typename I2>
- struct equal_to
- : mpl::or_<
- is_same<I1, I2>
- , mpl::and_<
- detail::boost_tuple_is_empty<typename I1::cons_type>
- , detail::boost_tuple_is_empty<typename I2::cons_type>
- >
- >
- {};
- };
- template <>
- struct boost_tuple_iterator<tuples::null_type>
- : boost_tuple_null_iterator<tuples::null_type>
- {
- template <typename Cons>
- BOOST_FUSION_GPU_ENABLED
- explicit boost_tuple_iterator(Cons const&) {}
- };
- template <>
- struct boost_tuple_iterator<tuples::null_type const>
- : boost_tuple_null_iterator<tuples::null_type const>
- {
- template <typename Cons>
- BOOST_FUSION_GPU_ENABLED
- explicit boost_tuple_iterator(Cons const&) {}
- };
- template <>
- struct boost_tuple_iterator<tuples::tuple<> >
- : boost_tuple_null_iterator<tuples::tuple<> >
- {
- template <typename Cons>
- BOOST_FUSION_GPU_ENABLED
- explicit boost_tuple_iterator(Cons const&) {}
- };
- template <>
- struct boost_tuple_iterator<tuples::tuple<> const>
- : boost_tuple_null_iterator<tuples::tuple<> const>
- {
- template <typename Cons>
- BOOST_FUSION_GPU_ENABLED
- explicit boost_tuple_iterator(Cons const&) {}
- };
- }}
- #ifdef BOOST_FUSION_WORKAROUND_FOR_LWG_2408
- namespace std
- {
- template <typename Cons>
- struct iterator_traits< ::boost::fusion::boost_tuple_iterator<Cons> >
- { };
- }
- #endif
- #endif
|