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
 | 
