mirror of
https://github.com/boostorg/fusion.git
synced 2025-07-29 03:57:36 +02:00
list-at optimization
[SVN r47643]
This commit is contained in:
@ -15,6 +15,71 @@
|
|||||||
|
|
||||||
namespace boost { namespace fusion
|
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;
|
struct cons_tag;
|
||||||
|
|
||||||
namespace extension
|
namespace extension
|
||||||
@ -28,20 +93,8 @@ namespace boost { namespace fusion
|
|||||||
template <typename Sequence, typename N>
|
template <typename Sequence, typename N>
|
||||||
struct apply
|
struct apply
|
||||||
{
|
{
|
||||||
typedef typename
|
typedef detail::cons_deref<
|
||||||
mpl::eval_if<
|
typename detail::cons_advance<Sequence, N::value>::type>
|
||||||
is_const<Sequence>
|
|
||||||
, add_const<typename Sequence::cdr_type>
|
|
||||||
, mpl::identity<typename Sequence::cdr_type>
|
|
||||||
>::type
|
|
||||||
cdr_type;
|
|
||||||
|
|
||||||
typedef typename
|
|
||||||
mpl::eval_if<
|
|
||||||
mpl::bool_<N::value == 0>
|
|
||||||
, mpl::identity<typename Sequence::car_type>
|
|
||||||
, apply<cdr_type, mpl::int_<N::value-1> >
|
|
||||||
>
|
|
||||||
element;
|
element;
|
||||||
|
|
||||||
typedef typename
|
typedef typename
|
||||||
|
Reference in New Issue
Block a user