137 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
		
		
			
		
	
	
			137 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
|   | /*============================================================================= | ||
|  |     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_AT_IMPL_07172005_0726) | ||
|  | #define FUSION_AT_IMPL_07172005_0726 | ||
|  | 
 | ||
|  | #include <boost/fusion/support/config.hpp> | ||
|  | #include <boost/fusion/support/detail/access.hpp> | ||
|  | #include <boost/type_traits/is_const.hpp> | ||
|  | #include <boost/type_traits/add_const.hpp> | ||
|  | #include <boost/mpl/if.hpp> | ||
|  | #include <boost/mpl/bool.hpp> | ||
|  | 
 | ||
|  | namespace boost { namespace fusion | ||
|  | { | ||
|  |     namespace detail | ||
|  |     { | ||
|  |         template <typename Cons> | ||
|  |         struct cons_deref | ||
|  |         { | ||
|  |             typedef typename Cons::car_type type; | ||
|  |         }; | ||
|  | 
 | ||
|  |         template <typename Cons, int I> | ||
|  |         struct cons_advance | ||
|  |         { | ||
|  |             typedef typename | ||
|  |                 cons_advance<Cons, I-1>::type::cdr_type | ||
|  |             type; | ||
|  |         }; | ||
|  | 
 | ||
|  |         template <typename Cons> | ||
|  |         struct cons_advance<Cons, 0> | ||
|  |         { | ||
|  |             typedef Cons type; | ||
|  |         }; | ||
|  | 
 | ||
|  |         template <typename Cons> | ||
|  |         struct cons_advance<Cons, 1> | ||
|  |         { | ||
|  |             typedef typename Cons::cdr_type type; | ||
|  |         }; | ||
|  | 
 | ||
|  |         template <typename Cons> | ||
|  |         struct cons_advance<Cons, 2> | ||
|  |         { | ||
|  | #if BOOST_WORKAROUND(BOOST_MSVC, > 1400) // VC8 and above | ||
|  |             typedef typename Cons::cdr_type::cdr_type type; | ||
|  | #else | ||
|  |             typedef typename Cons::cdr_type _a; | ||
|  |             typedef typename _a::cdr_type type; | ||
|  | #endif | ||
|  |         }; | ||
|  | 
 | ||
|  |         template <typename Cons> | ||
|  |         struct cons_advance<Cons, 3> | ||
|  |         { | ||
|  | #if BOOST_WORKAROUND(BOOST_MSVC, > 1400) // VC8 and above | ||
|  |             typedef typename Cons::cdr_type::cdr_type::cdr_type type; | ||
|  | #else | ||
|  |             typedef typename Cons::cdr_type _a; | ||
|  |             typedef typename _a::cdr_type _b; | ||
|  |             typedef typename _b::cdr_type type; | ||
|  | #endif | ||
|  |         }; | ||
|  | 
 | ||
|  |         template <typename Cons> | ||
|  |         struct cons_advance<Cons, 4> | ||
|  |         { | ||
|  | #if BOOST_WORKAROUND(BOOST_MSVC, > 1400) // VC8 and above | ||
|  |             typedef typename Cons::cdr_type::cdr_type::cdr_type::cdr_type type; | ||
|  | #else | ||
|  |             typedef typename Cons::cdr_type _a; | ||
|  |             typedef typename _a::cdr_type _b; | ||
|  |             typedef typename _b::cdr_type _c; | ||
|  |             typedef typename _c::cdr_type type; | ||
|  | #endif | ||
|  |         }; | ||
|  |     } | ||
|  | 
 | ||
|  |     struct cons_tag; | ||
|  | 
 | ||
|  |     namespace extension | ||
|  |     { | ||
|  |         template <typename Tag> | ||
|  |         struct at_impl; | ||
|  | 
 | ||
|  |         template <> | ||
|  |         struct at_impl<cons_tag> | ||
|  |         { | ||
|  |             template <typename Sequence, typename N> | ||
|  |             struct apply | ||
|  |             { | ||
|  |                 typedef typename detail::cons_deref< | ||
|  |                     typename detail::cons_advance<Sequence, N::value>::type>::type | ||
|  |                 element; | ||
|  | 
 | ||
|  |                 typedef typename | ||
|  |                     mpl::if_< | ||
|  |                         is_const<Sequence> | ||
|  |                       , typename detail::cref_result<element>::type | ||
|  |                       , typename detail::ref_result<element>::type | ||
|  |                     >::type | ||
|  |                 type; | ||
|  | 
 | ||
|  |                 template <typename Cons, int N2> | ||
|  |                 BOOST_CONSTEXPR BOOST_FUSION_GPU_ENABLED | ||
|  |                 static type | ||
|  |                 call(Cons& s, mpl::int_<N2>) | ||
|  |                 { | ||
|  |                     return call(s.cdr, mpl::int_<N2-1>()); | ||
|  |                 } | ||
|  | 
 | ||
|  |                 template <typename Cons> | ||
|  |                 BOOST_CONSTEXPR BOOST_FUSION_GPU_ENABLED | ||
|  |                 static type | ||
|  |                 call(Cons& s, mpl::int_<0>) | ||
|  |                 { | ||
|  |                     return s.car; | ||
|  |                 } | ||
|  | 
 | ||
|  |                 BOOST_CONSTEXPR BOOST_FUSION_GPU_ENABLED | ||
|  |                 static type | ||
|  |                 call(Sequence& s) | ||
|  |                 { | ||
|  |                     return call(s, mpl::int_<N::value>()); | ||
|  |                 } | ||
|  |             }; | ||
|  |         }; | ||
|  |     } | ||
|  | }} | ||
|  | 
 | ||
|  | #endif |