You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and dots ('.'), can be up to 35 characters long. Letters must be lowercase.
1056 lines
50 KiB
1056 lines
50 KiB
/////////////////////////////////////////////////////////////////////////////// |
|
/// \file make.hpp |
|
/// Contains definition of the make<> transform. |
|
// |
|
// Copyright 2008 Eric Niebler. 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) |
|
namespace detail |
|
{ |
|
template<typename R > |
|
struct is_applyable<R()> |
|
: mpl::true_ |
|
{}; |
|
template<typename R > |
|
struct is_applyable<R(*)()> |
|
: mpl::true_ |
|
{}; |
|
template<typename T, typename A> |
|
struct construct_<proto::expr<T, A, 0>, true> |
|
{ |
|
typedef proto::expr<T, A, 0> result_type; |
|
template<typename A0> |
|
result_type operator ()(A0 &a0) const |
|
{ |
|
return result_type::make(a0); |
|
} |
|
}; |
|
template<typename T, typename A> |
|
struct construct_<proto::basic_expr<T, A, 0>, true> |
|
{ |
|
typedef proto::basic_expr<T, A, 0> result_type; |
|
template<typename A0> |
|
result_type operator ()(A0 &a0) const |
|
{ |
|
return result_type::make(a0); |
|
} |
|
}; |
|
template<typename Type > |
|
Type construct() |
|
{ |
|
return construct_<Type>()(); |
|
} |
|
} |
|
|
|
|
|
|
|
|
|
template<typename Object > |
|
struct make<Object()> |
|
: transform<make<Object()> > |
|
{ |
|
template<typename Expr, typename State, typename Data> |
|
struct impl : transform_impl<Expr, State, Data> |
|
{ |
|
|
|
typedef typename detail::make_if_<Object, Expr, State, Data>::type result_type; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
result_type operator ()( |
|
typename impl::expr_param e |
|
, typename impl::state_param s |
|
, typename impl::data_param d |
|
) const |
|
{ |
|
proto::detail::ignore_unused(e); |
|
proto::detail::ignore_unused(s); |
|
proto::detail::ignore_unused(d); |
|
return detail::construct<result_type>(); |
|
} |
|
}; |
|
}; |
|
namespace detail |
|
{ |
|
template< |
|
template<typename> class R |
|
, typename A0 |
|
, typename Expr, typename State, typename Data |
|
> |
|
struct make_< |
|
R<A0> |
|
, Expr, State, Data |
|
BOOST_PROTO_TEMPLATE_ARITY_PARAM(1) |
|
> |
|
: nested_type_if< |
|
R<typename make_if_<A0, Expr, State, Data> ::type> |
|
, (make_if_<A0, Expr, State, Data> ::applied || false) |
|
> |
|
{}; |
|
template< |
|
template<typename> class R |
|
, typename A0 |
|
, typename Expr, typename State, typename Data |
|
> |
|
struct make_< |
|
noinvoke<R<A0> > |
|
, Expr, State, Data |
|
BOOST_PROTO_TEMPLATE_ARITY_PARAM(1) |
|
> |
|
{ |
|
typedef R<typename make_if_<A0, Expr, State, Data> ::type> type; |
|
static bool const applied = true; |
|
}; |
|
template<typename R , typename A0> |
|
struct is_applyable<R(A0)> |
|
: mpl::true_ |
|
{}; |
|
template<typename R , typename A0> |
|
struct is_applyable<R(*)(A0)> |
|
: mpl::true_ |
|
{}; |
|
template<typename T, typename A> |
|
struct construct_<proto::expr<T, A, 1>, true> |
|
{ |
|
typedef proto::expr<T, A, 1> result_type; |
|
template<typename A0> |
|
result_type operator ()(A0 &a0) const |
|
{ |
|
return result_type::make(a0); |
|
} |
|
}; |
|
template<typename T, typename A> |
|
struct construct_<proto::basic_expr<T, A, 1>, true> |
|
{ |
|
typedef proto::basic_expr<T, A, 1> result_type; |
|
template<typename A0> |
|
result_type operator ()(A0 &a0) const |
|
{ |
|
return result_type::make(a0); |
|
} |
|
}; |
|
template<typename Type , typename A0> |
|
Type construct(A0 &a0) |
|
{ |
|
return construct_<Type>()(a0); |
|
} |
|
} |
|
|
|
|
|
|
|
|
|
template<typename Object , typename A0> |
|
struct make<Object(A0)> |
|
: transform<make<Object(A0)> > |
|
{ |
|
template<typename Expr, typename State, typename Data> |
|
struct impl : transform_impl<Expr, State, Data> |
|
{ |
|
|
|
typedef typename detail::make_if_<Object, Expr, State, Data>::type result_type; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
result_type operator ()( |
|
typename impl::expr_param e |
|
, typename impl::state_param s |
|
, typename impl::data_param d |
|
) const |
|
{ |
|
proto::detail::ignore_unused(e); |
|
proto::detail::ignore_unused(s); |
|
proto::detail::ignore_unused(d); |
|
return detail::construct<result_type>(detail::as_lvalue( typename when<_, A0>::template impl<Expr, State, Data>()(e, s, d) )); |
|
} |
|
}; |
|
}; |
|
namespace detail |
|
{ |
|
template< |
|
template<typename , typename> class R |
|
, typename A0 , typename A1 |
|
, typename Expr, typename State, typename Data |
|
> |
|
struct make_< |
|
R<A0 , A1> |
|
, Expr, State, Data |
|
BOOST_PROTO_TEMPLATE_ARITY_PARAM(2) |
|
> |
|
: nested_type_if< |
|
R<typename make_if_<A0, Expr, State, Data> ::type , typename make_if_<A1, Expr, State, Data> ::type> |
|
, (make_if_<A0, Expr, State, Data> ::applied || make_if_<A1, Expr, State, Data> ::applied || false) |
|
> |
|
{}; |
|
template< |
|
template<typename , typename> class R |
|
, typename A0 , typename A1 |
|
, typename Expr, typename State, typename Data |
|
> |
|
struct make_< |
|
noinvoke<R<A0 , A1> > |
|
, Expr, State, Data |
|
BOOST_PROTO_TEMPLATE_ARITY_PARAM(1) |
|
> |
|
{ |
|
typedef R<typename make_if_<A0, Expr, State, Data> ::type , typename make_if_<A1, Expr, State, Data> ::type> type; |
|
static bool const applied = true; |
|
}; |
|
template<typename R , typename A0 , typename A1> |
|
struct is_applyable<R(A0 , A1)> |
|
: mpl::true_ |
|
{}; |
|
template<typename R , typename A0 , typename A1> |
|
struct is_applyable<R(*)(A0 , A1)> |
|
: mpl::true_ |
|
{}; |
|
template<typename T, typename A> |
|
struct construct_<proto::expr<T, A, 2>, true> |
|
{ |
|
typedef proto::expr<T, A, 2> result_type; |
|
template<typename A0 , typename A1> |
|
result_type operator ()(A0 &a0 , A1 &a1) const |
|
{ |
|
return result_type::make(a0 , a1); |
|
} |
|
}; |
|
template<typename T, typename A> |
|
struct construct_<proto::basic_expr<T, A, 2>, true> |
|
{ |
|
typedef proto::basic_expr<T, A, 2> result_type; |
|
template<typename A0 , typename A1> |
|
result_type operator ()(A0 &a0 , A1 &a1) const |
|
{ |
|
return result_type::make(a0 , a1); |
|
} |
|
}; |
|
template<typename Type , typename A0 , typename A1> |
|
Type construct(A0 &a0 , A1 &a1) |
|
{ |
|
return construct_<Type>()(a0 , a1); |
|
} |
|
} |
|
|
|
|
|
|
|
|
|
template<typename Object , typename A0 , typename A1> |
|
struct make<Object(A0 , A1)> |
|
: transform<make<Object(A0 , A1)> > |
|
{ |
|
template<typename Expr, typename State, typename Data> |
|
struct impl : transform_impl<Expr, State, Data> |
|
{ |
|
|
|
typedef typename detail::make_if_<Object, Expr, State, Data>::type result_type; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
result_type operator ()( |
|
typename impl::expr_param e |
|
, typename impl::state_param s |
|
, typename impl::data_param d |
|
) const |
|
{ |
|
proto::detail::ignore_unused(e); |
|
proto::detail::ignore_unused(s); |
|
proto::detail::ignore_unused(d); |
|
return detail::construct<result_type>(detail::as_lvalue( typename when<_, A0>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A1>::template impl<Expr, State, Data>()(e, s, d) )); |
|
} |
|
}; |
|
}; |
|
namespace detail |
|
{ |
|
template< |
|
template<typename , typename , typename> class R |
|
, typename A0 , typename A1 , typename A2 |
|
, typename Expr, typename State, typename Data |
|
> |
|
struct make_< |
|
R<A0 , A1 , A2> |
|
, Expr, State, Data |
|
BOOST_PROTO_TEMPLATE_ARITY_PARAM(3) |
|
> |
|
: nested_type_if< |
|
R<typename make_if_<A0, Expr, State, Data> ::type , typename make_if_<A1, Expr, State, Data> ::type , typename make_if_<A2, Expr, State, Data> ::type> |
|
, (make_if_<A0, Expr, State, Data> ::applied || make_if_<A1, Expr, State, Data> ::applied || make_if_<A2, Expr, State, Data> ::applied || false) |
|
> |
|
{}; |
|
template< |
|
template<typename , typename , typename> class R |
|
, typename A0 , typename A1 , typename A2 |
|
, typename Expr, typename State, typename Data |
|
> |
|
struct make_< |
|
noinvoke<R<A0 , A1 , A2> > |
|
, Expr, State, Data |
|
BOOST_PROTO_TEMPLATE_ARITY_PARAM(1) |
|
> |
|
{ |
|
typedef R<typename make_if_<A0, Expr, State, Data> ::type , typename make_if_<A1, Expr, State, Data> ::type , typename make_if_<A2, Expr, State, Data> ::type> type; |
|
static bool const applied = true; |
|
}; |
|
template<typename R , typename A0 , typename A1 , typename A2> |
|
struct is_applyable<R(A0 , A1 , A2)> |
|
: mpl::true_ |
|
{}; |
|
template<typename R , typename A0 , typename A1 , typename A2> |
|
struct is_applyable<R(*)(A0 , A1 , A2)> |
|
: mpl::true_ |
|
{}; |
|
template<typename T, typename A> |
|
struct construct_<proto::expr<T, A, 3>, true> |
|
{ |
|
typedef proto::expr<T, A, 3> result_type; |
|
template<typename A0 , typename A1 , typename A2> |
|
result_type operator ()(A0 &a0 , A1 &a1 , A2 &a2) const |
|
{ |
|
return result_type::make(a0 , a1 , a2); |
|
} |
|
}; |
|
template<typename T, typename A> |
|
struct construct_<proto::basic_expr<T, A, 3>, true> |
|
{ |
|
typedef proto::basic_expr<T, A, 3> result_type; |
|
template<typename A0 , typename A1 , typename A2> |
|
result_type operator ()(A0 &a0 , A1 &a1 , A2 &a2) const |
|
{ |
|
return result_type::make(a0 , a1 , a2); |
|
} |
|
}; |
|
template<typename Type , typename A0 , typename A1 , typename A2> |
|
Type construct(A0 &a0 , A1 &a1 , A2 &a2) |
|
{ |
|
return construct_<Type>()(a0 , a1 , a2); |
|
} |
|
} |
|
|
|
|
|
|
|
|
|
template<typename Object , typename A0 , typename A1 , typename A2> |
|
struct make<Object(A0 , A1 , A2)> |
|
: transform<make<Object(A0 , A1 , A2)> > |
|
{ |
|
template<typename Expr, typename State, typename Data> |
|
struct impl : transform_impl<Expr, State, Data> |
|
{ |
|
|
|
typedef typename detail::make_if_<Object, Expr, State, Data>::type result_type; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
result_type operator ()( |
|
typename impl::expr_param e |
|
, typename impl::state_param s |
|
, typename impl::data_param d |
|
) const |
|
{ |
|
proto::detail::ignore_unused(e); |
|
proto::detail::ignore_unused(s); |
|
proto::detail::ignore_unused(d); |
|
return detail::construct<result_type>(detail::as_lvalue( typename when<_, A0>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A1>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A2>::template impl<Expr, State, Data>()(e, s, d) )); |
|
} |
|
}; |
|
}; |
|
namespace detail |
|
{ |
|
template< |
|
template<typename , typename , typename , typename> class R |
|
, typename A0 , typename A1 , typename A2 , typename A3 |
|
, typename Expr, typename State, typename Data |
|
> |
|
struct make_< |
|
R<A0 , A1 , A2 , A3> |
|
, Expr, State, Data |
|
BOOST_PROTO_TEMPLATE_ARITY_PARAM(4) |
|
> |
|
: nested_type_if< |
|
R<typename make_if_<A0, Expr, State, Data> ::type , typename make_if_<A1, Expr, State, Data> ::type , typename make_if_<A2, Expr, State, Data> ::type , typename make_if_<A3, Expr, State, Data> ::type> |
|
, (make_if_<A0, Expr, State, Data> ::applied || make_if_<A1, Expr, State, Data> ::applied || make_if_<A2, Expr, State, Data> ::applied || make_if_<A3, Expr, State, Data> ::applied || false) |
|
> |
|
{}; |
|
template< |
|
template<typename , typename , typename , typename> class R |
|
, typename A0 , typename A1 , typename A2 , typename A3 |
|
, typename Expr, typename State, typename Data |
|
> |
|
struct make_< |
|
noinvoke<R<A0 , A1 , A2 , A3> > |
|
, Expr, State, Data |
|
BOOST_PROTO_TEMPLATE_ARITY_PARAM(1) |
|
> |
|
{ |
|
typedef R<typename make_if_<A0, Expr, State, Data> ::type , typename make_if_<A1, Expr, State, Data> ::type , typename make_if_<A2, Expr, State, Data> ::type , typename make_if_<A3, Expr, State, Data> ::type> type; |
|
static bool const applied = true; |
|
}; |
|
template<typename R , typename A0 , typename A1 , typename A2 , typename A3> |
|
struct is_applyable<R(A0 , A1 , A2 , A3)> |
|
: mpl::true_ |
|
{}; |
|
template<typename R , typename A0 , typename A1 , typename A2 , typename A3> |
|
struct is_applyable<R(*)(A0 , A1 , A2 , A3)> |
|
: mpl::true_ |
|
{}; |
|
template<typename T, typename A> |
|
struct construct_<proto::expr<T, A, 4>, true> |
|
{ |
|
typedef proto::expr<T, A, 4> result_type; |
|
template<typename A0 , typename A1 , typename A2 , typename A3> |
|
result_type operator ()(A0 &a0 , A1 &a1 , A2 &a2 , A3 &a3) const |
|
{ |
|
return result_type::make(a0 , a1 , a2 , a3); |
|
} |
|
}; |
|
template<typename T, typename A> |
|
struct construct_<proto::basic_expr<T, A, 4>, true> |
|
{ |
|
typedef proto::basic_expr<T, A, 4> result_type; |
|
template<typename A0 , typename A1 , typename A2 , typename A3> |
|
result_type operator ()(A0 &a0 , A1 &a1 , A2 &a2 , A3 &a3) const |
|
{ |
|
return result_type::make(a0 , a1 , a2 , a3); |
|
} |
|
}; |
|
template<typename Type , typename A0 , typename A1 , typename A2 , typename A3> |
|
Type construct(A0 &a0 , A1 &a1 , A2 &a2 , A3 &a3) |
|
{ |
|
return construct_<Type>()(a0 , a1 , a2 , a3); |
|
} |
|
} |
|
|
|
|
|
|
|
|
|
template<typename Object , typename A0 , typename A1 , typename A2 , typename A3> |
|
struct make<Object(A0 , A1 , A2 , A3)> |
|
: transform<make<Object(A0 , A1 , A2 , A3)> > |
|
{ |
|
template<typename Expr, typename State, typename Data> |
|
struct impl : transform_impl<Expr, State, Data> |
|
{ |
|
|
|
typedef typename detail::make_if_<Object, Expr, State, Data>::type result_type; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
result_type operator ()( |
|
typename impl::expr_param e |
|
, typename impl::state_param s |
|
, typename impl::data_param d |
|
) const |
|
{ |
|
proto::detail::ignore_unused(e); |
|
proto::detail::ignore_unused(s); |
|
proto::detail::ignore_unused(d); |
|
return detail::construct<result_type>(detail::as_lvalue( typename when<_, A0>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A1>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A2>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A3>::template impl<Expr, State, Data>()(e, s, d) )); |
|
} |
|
}; |
|
}; |
|
namespace detail |
|
{ |
|
template< |
|
template<typename , typename , typename , typename , typename> class R |
|
, typename A0 , typename A1 , typename A2 , typename A3 , typename A4 |
|
, typename Expr, typename State, typename Data |
|
> |
|
struct make_< |
|
R<A0 , A1 , A2 , A3 , A4> |
|
, Expr, State, Data |
|
BOOST_PROTO_TEMPLATE_ARITY_PARAM(5) |
|
> |
|
: nested_type_if< |
|
R<typename make_if_<A0, Expr, State, Data> ::type , typename make_if_<A1, Expr, State, Data> ::type , typename make_if_<A2, Expr, State, Data> ::type , typename make_if_<A3, Expr, State, Data> ::type , typename make_if_<A4, Expr, State, Data> ::type> |
|
, (make_if_<A0, Expr, State, Data> ::applied || make_if_<A1, Expr, State, Data> ::applied || make_if_<A2, Expr, State, Data> ::applied || make_if_<A3, Expr, State, Data> ::applied || make_if_<A4, Expr, State, Data> ::applied || false) |
|
> |
|
{}; |
|
template< |
|
template<typename , typename , typename , typename , typename> class R |
|
, typename A0 , typename A1 , typename A2 , typename A3 , typename A4 |
|
, typename Expr, typename State, typename Data |
|
> |
|
struct make_< |
|
noinvoke<R<A0 , A1 , A2 , A3 , A4> > |
|
, Expr, State, Data |
|
BOOST_PROTO_TEMPLATE_ARITY_PARAM(1) |
|
> |
|
{ |
|
typedef R<typename make_if_<A0, Expr, State, Data> ::type , typename make_if_<A1, Expr, State, Data> ::type , typename make_if_<A2, Expr, State, Data> ::type , typename make_if_<A3, Expr, State, Data> ::type , typename make_if_<A4, Expr, State, Data> ::type> type; |
|
static bool const applied = true; |
|
}; |
|
template<typename R , typename A0 , typename A1 , typename A2 , typename A3 , typename A4> |
|
struct is_applyable<R(A0 , A1 , A2 , A3 , A4)> |
|
: mpl::true_ |
|
{}; |
|
template<typename R , typename A0 , typename A1 , typename A2 , typename A3 , typename A4> |
|
struct is_applyable<R(*)(A0 , A1 , A2 , A3 , A4)> |
|
: mpl::true_ |
|
{}; |
|
template<typename T, typename A> |
|
struct construct_<proto::expr<T, A, 5>, true> |
|
{ |
|
typedef proto::expr<T, A, 5> result_type; |
|
template<typename A0 , typename A1 , typename A2 , typename A3 , typename A4> |
|
result_type operator ()(A0 &a0 , A1 &a1 , A2 &a2 , A3 &a3 , A4 &a4) const |
|
{ |
|
return result_type::make(a0 , a1 , a2 , a3 , a4); |
|
} |
|
}; |
|
template<typename T, typename A> |
|
struct construct_<proto::basic_expr<T, A, 5>, true> |
|
{ |
|
typedef proto::basic_expr<T, A, 5> result_type; |
|
template<typename A0 , typename A1 , typename A2 , typename A3 , typename A4> |
|
result_type operator ()(A0 &a0 , A1 &a1 , A2 &a2 , A3 &a3 , A4 &a4) const |
|
{ |
|
return result_type::make(a0 , a1 , a2 , a3 , a4); |
|
} |
|
}; |
|
template<typename Type , typename A0 , typename A1 , typename A2 , typename A3 , typename A4> |
|
Type construct(A0 &a0 , A1 &a1 , A2 &a2 , A3 &a3 , A4 &a4) |
|
{ |
|
return construct_<Type>()(a0 , a1 , a2 , a3 , a4); |
|
} |
|
} |
|
|
|
|
|
|
|
|
|
template<typename Object , typename A0 , typename A1 , typename A2 , typename A3 , typename A4> |
|
struct make<Object(A0 , A1 , A2 , A3 , A4)> |
|
: transform<make<Object(A0 , A1 , A2 , A3 , A4)> > |
|
{ |
|
template<typename Expr, typename State, typename Data> |
|
struct impl : transform_impl<Expr, State, Data> |
|
{ |
|
|
|
typedef typename detail::make_if_<Object, Expr, State, Data>::type result_type; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
result_type operator ()( |
|
typename impl::expr_param e |
|
, typename impl::state_param s |
|
, typename impl::data_param d |
|
) const |
|
{ |
|
proto::detail::ignore_unused(e); |
|
proto::detail::ignore_unused(s); |
|
proto::detail::ignore_unused(d); |
|
return detail::construct<result_type>(detail::as_lvalue( typename when<_, A0>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A1>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A2>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A3>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A4>::template impl<Expr, State, Data>()(e, s, d) )); |
|
} |
|
}; |
|
}; |
|
namespace detail |
|
{ |
|
template< |
|
template<typename , typename , typename , typename , typename , typename> class R |
|
, typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 |
|
, typename Expr, typename State, typename Data |
|
> |
|
struct make_< |
|
R<A0 , A1 , A2 , A3 , A4 , A5> |
|
, Expr, State, Data |
|
BOOST_PROTO_TEMPLATE_ARITY_PARAM(6) |
|
> |
|
: nested_type_if< |
|
R<typename make_if_<A0, Expr, State, Data> ::type , typename make_if_<A1, Expr, State, Data> ::type , typename make_if_<A2, Expr, State, Data> ::type , typename make_if_<A3, Expr, State, Data> ::type , typename make_if_<A4, Expr, State, Data> ::type , typename make_if_<A5, Expr, State, Data> ::type> |
|
, (make_if_<A0, Expr, State, Data> ::applied || make_if_<A1, Expr, State, Data> ::applied || make_if_<A2, Expr, State, Data> ::applied || make_if_<A3, Expr, State, Data> ::applied || make_if_<A4, Expr, State, Data> ::applied || make_if_<A5, Expr, State, Data> ::applied || false) |
|
> |
|
{}; |
|
template< |
|
template<typename , typename , typename , typename , typename , typename> class R |
|
, typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 |
|
, typename Expr, typename State, typename Data |
|
> |
|
struct make_< |
|
noinvoke<R<A0 , A1 , A2 , A3 , A4 , A5> > |
|
, Expr, State, Data |
|
BOOST_PROTO_TEMPLATE_ARITY_PARAM(1) |
|
> |
|
{ |
|
typedef R<typename make_if_<A0, Expr, State, Data> ::type , typename make_if_<A1, Expr, State, Data> ::type , typename make_if_<A2, Expr, State, Data> ::type , typename make_if_<A3, Expr, State, Data> ::type , typename make_if_<A4, Expr, State, Data> ::type , typename make_if_<A5, Expr, State, Data> ::type> type; |
|
static bool const applied = true; |
|
}; |
|
template<typename R , typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5> |
|
struct is_applyable<R(A0 , A1 , A2 , A3 , A4 , A5)> |
|
: mpl::true_ |
|
{}; |
|
template<typename R , typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5> |
|
struct is_applyable<R(*)(A0 , A1 , A2 , A3 , A4 , A5)> |
|
: mpl::true_ |
|
{}; |
|
template<typename T, typename A> |
|
struct construct_<proto::expr<T, A, 6>, true> |
|
{ |
|
typedef proto::expr<T, A, 6> result_type; |
|
template<typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5> |
|
result_type operator ()(A0 &a0 , A1 &a1 , A2 &a2 , A3 &a3 , A4 &a4 , A5 &a5) const |
|
{ |
|
return result_type::make(a0 , a1 , a2 , a3 , a4 , a5); |
|
} |
|
}; |
|
template<typename T, typename A> |
|
struct construct_<proto::basic_expr<T, A, 6>, true> |
|
{ |
|
typedef proto::basic_expr<T, A, 6> result_type; |
|
template<typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5> |
|
result_type operator ()(A0 &a0 , A1 &a1 , A2 &a2 , A3 &a3 , A4 &a4 , A5 &a5) const |
|
{ |
|
return result_type::make(a0 , a1 , a2 , a3 , a4 , a5); |
|
} |
|
}; |
|
template<typename Type , typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5> |
|
Type construct(A0 &a0 , A1 &a1 , A2 &a2 , A3 &a3 , A4 &a4 , A5 &a5) |
|
{ |
|
return construct_<Type>()(a0 , a1 , a2 , a3 , a4 , a5); |
|
} |
|
} |
|
|
|
|
|
|
|
|
|
template<typename Object , typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5> |
|
struct make<Object(A0 , A1 , A2 , A3 , A4 , A5)> |
|
: transform<make<Object(A0 , A1 , A2 , A3 , A4 , A5)> > |
|
{ |
|
template<typename Expr, typename State, typename Data> |
|
struct impl : transform_impl<Expr, State, Data> |
|
{ |
|
|
|
typedef typename detail::make_if_<Object, Expr, State, Data>::type result_type; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
result_type operator ()( |
|
typename impl::expr_param e |
|
, typename impl::state_param s |
|
, typename impl::data_param d |
|
) const |
|
{ |
|
proto::detail::ignore_unused(e); |
|
proto::detail::ignore_unused(s); |
|
proto::detail::ignore_unused(d); |
|
return detail::construct<result_type>(detail::as_lvalue( typename when<_, A0>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A1>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A2>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A3>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A4>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A5>::template impl<Expr, State, Data>()(e, s, d) )); |
|
} |
|
}; |
|
}; |
|
namespace detail |
|
{ |
|
template< |
|
template<typename , typename , typename , typename , typename , typename , typename> class R |
|
, typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 |
|
, typename Expr, typename State, typename Data |
|
> |
|
struct make_< |
|
R<A0 , A1 , A2 , A3 , A4 , A5 , A6> |
|
, Expr, State, Data |
|
BOOST_PROTO_TEMPLATE_ARITY_PARAM(7) |
|
> |
|
: nested_type_if< |
|
R<typename make_if_<A0, Expr, State, Data> ::type , typename make_if_<A1, Expr, State, Data> ::type , typename make_if_<A2, Expr, State, Data> ::type , typename make_if_<A3, Expr, State, Data> ::type , typename make_if_<A4, Expr, State, Data> ::type , typename make_if_<A5, Expr, State, Data> ::type , typename make_if_<A6, Expr, State, Data> ::type> |
|
, (make_if_<A0, Expr, State, Data> ::applied || make_if_<A1, Expr, State, Data> ::applied || make_if_<A2, Expr, State, Data> ::applied || make_if_<A3, Expr, State, Data> ::applied || make_if_<A4, Expr, State, Data> ::applied || make_if_<A5, Expr, State, Data> ::applied || make_if_<A6, Expr, State, Data> ::applied || false) |
|
> |
|
{}; |
|
template< |
|
template<typename , typename , typename , typename , typename , typename , typename> class R |
|
, typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 |
|
, typename Expr, typename State, typename Data |
|
> |
|
struct make_< |
|
noinvoke<R<A0 , A1 , A2 , A3 , A4 , A5 , A6> > |
|
, Expr, State, Data |
|
BOOST_PROTO_TEMPLATE_ARITY_PARAM(1) |
|
> |
|
{ |
|
typedef R<typename make_if_<A0, Expr, State, Data> ::type , typename make_if_<A1, Expr, State, Data> ::type , typename make_if_<A2, Expr, State, Data> ::type , typename make_if_<A3, Expr, State, Data> ::type , typename make_if_<A4, Expr, State, Data> ::type , typename make_if_<A5, Expr, State, Data> ::type , typename make_if_<A6, Expr, State, Data> ::type> type; |
|
static bool const applied = true; |
|
}; |
|
template<typename R , typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6> |
|
struct is_applyable<R(A0 , A1 , A2 , A3 , A4 , A5 , A6)> |
|
: mpl::true_ |
|
{}; |
|
template<typename R , typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6> |
|
struct is_applyable<R(*)(A0 , A1 , A2 , A3 , A4 , A5 , A6)> |
|
: mpl::true_ |
|
{}; |
|
template<typename T, typename A> |
|
struct construct_<proto::expr<T, A, 7>, true> |
|
{ |
|
typedef proto::expr<T, A, 7> result_type; |
|
template<typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6> |
|
result_type operator ()(A0 &a0 , A1 &a1 , A2 &a2 , A3 &a3 , A4 &a4 , A5 &a5 , A6 &a6) const |
|
{ |
|
return result_type::make(a0 , a1 , a2 , a3 , a4 , a5 , a6); |
|
} |
|
}; |
|
template<typename T, typename A> |
|
struct construct_<proto::basic_expr<T, A, 7>, true> |
|
{ |
|
typedef proto::basic_expr<T, A, 7> result_type; |
|
template<typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6> |
|
result_type operator ()(A0 &a0 , A1 &a1 , A2 &a2 , A3 &a3 , A4 &a4 , A5 &a5 , A6 &a6) const |
|
{ |
|
return result_type::make(a0 , a1 , a2 , a3 , a4 , a5 , a6); |
|
} |
|
}; |
|
template<typename Type , typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6> |
|
Type construct(A0 &a0 , A1 &a1 , A2 &a2 , A3 &a3 , A4 &a4 , A5 &a5 , A6 &a6) |
|
{ |
|
return construct_<Type>()(a0 , a1 , a2 , a3 , a4 , a5 , a6); |
|
} |
|
} |
|
|
|
|
|
|
|
|
|
template<typename Object , typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6> |
|
struct make<Object(A0 , A1 , A2 , A3 , A4 , A5 , A6)> |
|
: transform<make<Object(A0 , A1 , A2 , A3 , A4 , A5 , A6)> > |
|
{ |
|
template<typename Expr, typename State, typename Data> |
|
struct impl : transform_impl<Expr, State, Data> |
|
{ |
|
|
|
typedef typename detail::make_if_<Object, Expr, State, Data>::type result_type; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
result_type operator ()( |
|
typename impl::expr_param e |
|
, typename impl::state_param s |
|
, typename impl::data_param d |
|
) const |
|
{ |
|
proto::detail::ignore_unused(e); |
|
proto::detail::ignore_unused(s); |
|
proto::detail::ignore_unused(d); |
|
return detail::construct<result_type>(detail::as_lvalue( typename when<_, A0>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A1>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A2>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A3>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A4>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A5>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A6>::template impl<Expr, State, Data>()(e, s, d) )); |
|
} |
|
}; |
|
}; |
|
namespace detail |
|
{ |
|
template< |
|
template<typename , typename , typename , typename , typename , typename , typename , typename> class R |
|
, typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7 |
|
, typename Expr, typename State, typename Data |
|
> |
|
struct make_< |
|
R<A0 , A1 , A2 , A3 , A4 , A5 , A6 , A7> |
|
, Expr, State, Data |
|
BOOST_PROTO_TEMPLATE_ARITY_PARAM(8) |
|
> |
|
: nested_type_if< |
|
R<typename make_if_<A0, Expr, State, Data> ::type , typename make_if_<A1, Expr, State, Data> ::type , typename make_if_<A2, Expr, State, Data> ::type , typename make_if_<A3, Expr, State, Data> ::type , typename make_if_<A4, Expr, State, Data> ::type , typename make_if_<A5, Expr, State, Data> ::type , typename make_if_<A6, Expr, State, Data> ::type , typename make_if_<A7, Expr, State, Data> ::type> |
|
, (make_if_<A0, Expr, State, Data> ::applied || make_if_<A1, Expr, State, Data> ::applied || make_if_<A2, Expr, State, Data> ::applied || make_if_<A3, Expr, State, Data> ::applied || make_if_<A4, Expr, State, Data> ::applied || make_if_<A5, Expr, State, Data> ::applied || make_if_<A6, Expr, State, Data> ::applied || make_if_<A7, Expr, State, Data> ::applied || false) |
|
> |
|
{}; |
|
template< |
|
template<typename , typename , typename , typename , typename , typename , typename , typename> class R |
|
, typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7 |
|
, typename Expr, typename State, typename Data |
|
> |
|
struct make_< |
|
noinvoke<R<A0 , A1 , A2 , A3 , A4 , A5 , A6 , A7> > |
|
, Expr, State, Data |
|
BOOST_PROTO_TEMPLATE_ARITY_PARAM(1) |
|
> |
|
{ |
|
typedef R<typename make_if_<A0, Expr, State, Data> ::type , typename make_if_<A1, Expr, State, Data> ::type , typename make_if_<A2, Expr, State, Data> ::type , typename make_if_<A3, Expr, State, Data> ::type , typename make_if_<A4, Expr, State, Data> ::type , typename make_if_<A5, Expr, State, Data> ::type , typename make_if_<A6, Expr, State, Data> ::type , typename make_if_<A7, Expr, State, Data> ::type> type; |
|
static bool const applied = true; |
|
}; |
|
template<typename R , typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7> |
|
struct is_applyable<R(A0 , A1 , A2 , A3 , A4 , A5 , A6 , A7)> |
|
: mpl::true_ |
|
{}; |
|
template<typename R , typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7> |
|
struct is_applyable<R(*)(A0 , A1 , A2 , A3 , A4 , A5 , A6 , A7)> |
|
: mpl::true_ |
|
{}; |
|
template<typename T, typename A> |
|
struct construct_<proto::expr<T, A, 8>, true> |
|
{ |
|
typedef proto::expr<T, A, 8> result_type; |
|
template<typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7> |
|
result_type operator ()(A0 &a0 , A1 &a1 , A2 &a2 , A3 &a3 , A4 &a4 , A5 &a5 , A6 &a6 , A7 &a7) const |
|
{ |
|
return result_type::make(a0 , a1 , a2 , a3 , a4 , a5 , a6 , a7); |
|
} |
|
}; |
|
template<typename T, typename A> |
|
struct construct_<proto::basic_expr<T, A, 8>, true> |
|
{ |
|
typedef proto::basic_expr<T, A, 8> result_type; |
|
template<typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7> |
|
result_type operator ()(A0 &a0 , A1 &a1 , A2 &a2 , A3 &a3 , A4 &a4 , A5 &a5 , A6 &a6 , A7 &a7) const |
|
{ |
|
return result_type::make(a0 , a1 , a2 , a3 , a4 , a5 , a6 , a7); |
|
} |
|
}; |
|
template<typename Type , typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7> |
|
Type construct(A0 &a0 , A1 &a1 , A2 &a2 , A3 &a3 , A4 &a4 , A5 &a5 , A6 &a6 , A7 &a7) |
|
{ |
|
return construct_<Type>()(a0 , a1 , a2 , a3 , a4 , a5 , a6 , a7); |
|
} |
|
} |
|
|
|
|
|
|
|
|
|
template<typename Object , typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7> |
|
struct make<Object(A0 , A1 , A2 , A3 , A4 , A5 , A6 , A7)> |
|
: transform<make<Object(A0 , A1 , A2 , A3 , A4 , A5 , A6 , A7)> > |
|
{ |
|
template<typename Expr, typename State, typename Data> |
|
struct impl : transform_impl<Expr, State, Data> |
|
{ |
|
|
|
typedef typename detail::make_if_<Object, Expr, State, Data>::type result_type; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
result_type operator ()( |
|
typename impl::expr_param e |
|
, typename impl::state_param s |
|
, typename impl::data_param d |
|
) const |
|
{ |
|
proto::detail::ignore_unused(e); |
|
proto::detail::ignore_unused(s); |
|
proto::detail::ignore_unused(d); |
|
return detail::construct<result_type>(detail::as_lvalue( typename when<_, A0>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A1>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A2>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A3>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A4>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A5>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A6>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A7>::template impl<Expr, State, Data>()(e, s, d) )); |
|
} |
|
}; |
|
}; |
|
namespace detail |
|
{ |
|
template< |
|
template<typename , typename , typename , typename , typename , typename , typename , typename , typename> class R |
|
, typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7 , typename A8 |
|
, typename Expr, typename State, typename Data |
|
> |
|
struct make_< |
|
R<A0 , A1 , A2 , A3 , A4 , A5 , A6 , A7 , A8> |
|
, Expr, State, Data |
|
BOOST_PROTO_TEMPLATE_ARITY_PARAM(9) |
|
> |
|
: nested_type_if< |
|
R<typename make_if_<A0, Expr, State, Data> ::type , typename make_if_<A1, Expr, State, Data> ::type , typename make_if_<A2, Expr, State, Data> ::type , typename make_if_<A3, Expr, State, Data> ::type , typename make_if_<A4, Expr, State, Data> ::type , typename make_if_<A5, Expr, State, Data> ::type , typename make_if_<A6, Expr, State, Data> ::type , typename make_if_<A7, Expr, State, Data> ::type , typename make_if_<A8, Expr, State, Data> ::type> |
|
, (make_if_<A0, Expr, State, Data> ::applied || make_if_<A1, Expr, State, Data> ::applied || make_if_<A2, Expr, State, Data> ::applied || make_if_<A3, Expr, State, Data> ::applied || make_if_<A4, Expr, State, Data> ::applied || make_if_<A5, Expr, State, Data> ::applied || make_if_<A6, Expr, State, Data> ::applied || make_if_<A7, Expr, State, Data> ::applied || make_if_<A8, Expr, State, Data> ::applied || false) |
|
> |
|
{}; |
|
template< |
|
template<typename , typename , typename , typename , typename , typename , typename , typename , typename> class R |
|
, typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7 , typename A8 |
|
, typename Expr, typename State, typename Data |
|
> |
|
struct make_< |
|
noinvoke<R<A0 , A1 , A2 , A3 , A4 , A5 , A6 , A7 , A8> > |
|
, Expr, State, Data |
|
BOOST_PROTO_TEMPLATE_ARITY_PARAM(1) |
|
> |
|
{ |
|
typedef R<typename make_if_<A0, Expr, State, Data> ::type , typename make_if_<A1, Expr, State, Data> ::type , typename make_if_<A2, Expr, State, Data> ::type , typename make_if_<A3, Expr, State, Data> ::type , typename make_if_<A4, Expr, State, Data> ::type , typename make_if_<A5, Expr, State, Data> ::type , typename make_if_<A6, Expr, State, Data> ::type , typename make_if_<A7, Expr, State, Data> ::type , typename make_if_<A8, Expr, State, Data> ::type> type; |
|
static bool const applied = true; |
|
}; |
|
template<typename R , typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7 , typename A8> |
|
struct is_applyable<R(A0 , A1 , A2 , A3 , A4 , A5 , A6 , A7 , A8)> |
|
: mpl::true_ |
|
{}; |
|
template<typename R , typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7 , typename A8> |
|
struct is_applyable<R(*)(A0 , A1 , A2 , A3 , A4 , A5 , A6 , A7 , A8)> |
|
: mpl::true_ |
|
{}; |
|
template<typename T, typename A> |
|
struct construct_<proto::expr<T, A, 9>, true> |
|
{ |
|
typedef proto::expr<T, A, 9> result_type; |
|
template<typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7 , typename A8> |
|
result_type operator ()(A0 &a0 , A1 &a1 , A2 &a2 , A3 &a3 , A4 &a4 , A5 &a5 , A6 &a6 , A7 &a7 , A8 &a8) const |
|
{ |
|
return result_type::make(a0 , a1 , a2 , a3 , a4 , a5 , a6 , a7 , a8); |
|
} |
|
}; |
|
template<typename T, typename A> |
|
struct construct_<proto::basic_expr<T, A, 9>, true> |
|
{ |
|
typedef proto::basic_expr<T, A, 9> result_type; |
|
template<typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7 , typename A8> |
|
result_type operator ()(A0 &a0 , A1 &a1 , A2 &a2 , A3 &a3 , A4 &a4 , A5 &a5 , A6 &a6 , A7 &a7 , A8 &a8) const |
|
{ |
|
return result_type::make(a0 , a1 , a2 , a3 , a4 , a5 , a6 , a7 , a8); |
|
} |
|
}; |
|
template<typename Type , typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7 , typename A8> |
|
Type construct(A0 &a0 , A1 &a1 , A2 &a2 , A3 &a3 , A4 &a4 , A5 &a5 , A6 &a6 , A7 &a7 , A8 &a8) |
|
{ |
|
return construct_<Type>()(a0 , a1 , a2 , a3 , a4 , a5 , a6 , a7 , a8); |
|
} |
|
} |
|
|
|
|
|
|
|
|
|
template<typename Object , typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7 , typename A8> |
|
struct make<Object(A0 , A1 , A2 , A3 , A4 , A5 , A6 , A7 , A8)> |
|
: transform<make<Object(A0 , A1 , A2 , A3 , A4 , A5 , A6 , A7 , A8)> > |
|
{ |
|
template<typename Expr, typename State, typename Data> |
|
struct impl : transform_impl<Expr, State, Data> |
|
{ |
|
|
|
typedef typename detail::make_if_<Object, Expr, State, Data>::type result_type; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
result_type operator ()( |
|
typename impl::expr_param e |
|
, typename impl::state_param s |
|
, typename impl::data_param d |
|
) const |
|
{ |
|
proto::detail::ignore_unused(e); |
|
proto::detail::ignore_unused(s); |
|
proto::detail::ignore_unused(d); |
|
return detail::construct<result_type>(detail::as_lvalue( typename when<_, A0>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A1>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A2>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A3>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A4>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A5>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A6>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A7>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A8>::template impl<Expr, State, Data>()(e, s, d) )); |
|
} |
|
}; |
|
}; |
|
namespace detail |
|
{ |
|
template< |
|
template<typename , typename , typename , typename , typename , typename , typename , typename , typename , typename> class R |
|
, typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7 , typename A8 , typename A9 |
|
, typename Expr, typename State, typename Data |
|
> |
|
struct make_< |
|
R<A0 , A1 , A2 , A3 , A4 , A5 , A6 , A7 , A8 , A9> |
|
, Expr, State, Data |
|
BOOST_PROTO_TEMPLATE_ARITY_PARAM(10) |
|
> |
|
: nested_type_if< |
|
R<typename make_if_<A0, Expr, State, Data> ::type , typename make_if_<A1, Expr, State, Data> ::type , typename make_if_<A2, Expr, State, Data> ::type , typename make_if_<A3, Expr, State, Data> ::type , typename make_if_<A4, Expr, State, Data> ::type , typename make_if_<A5, Expr, State, Data> ::type , typename make_if_<A6, Expr, State, Data> ::type , typename make_if_<A7, Expr, State, Data> ::type , typename make_if_<A8, Expr, State, Data> ::type , typename make_if_<A9, Expr, State, Data> ::type> |
|
, (make_if_<A0, Expr, State, Data> ::applied || make_if_<A1, Expr, State, Data> ::applied || make_if_<A2, Expr, State, Data> ::applied || make_if_<A3, Expr, State, Data> ::applied || make_if_<A4, Expr, State, Data> ::applied || make_if_<A5, Expr, State, Data> ::applied || make_if_<A6, Expr, State, Data> ::applied || make_if_<A7, Expr, State, Data> ::applied || make_if_<A8, Expr, State, Data> ::applied || make_if_<A9, Expr, State, Data> ::applied || false) |
|
> |
|
{}; |
|
template< |
|
template<typename , typename , typename , typename , typename , typename , typename , typename , typename , typename> class R |
|
, typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7 , typename A8 , typename A9 |
|
, typename Expr, typename State, typename Data |
|
> |
|
struct make_< |
|
noinvoke<R<A0 , A1 , A2 , A3 , A4 , A5 , A6 , A7 , A8 , A9> > |
|
, Expr, State, Data |
|
BOOST_PROTO_TEMPLATE_ARITY_PARAM(1) |
|
> |
|
{ |
|
typedef R<typename make_if_<A0, Expr, State, Data> ::type , typename make_if_<A1, Expr, State, Data> ::type , typename make_if_<A2, Expr, State, Data> ::type , typename make_if_<A3, Expr, State, Data> ::type , typename make_if_<A4, Expr, State, Data> ::type , typename make_if_<A5, Expr, State, Data> ::type , typename make_if_<A6, Expr, State, Data> ::type , typename make_if_<A7, Expr, State, Data> ::type , typename make_if_<A8, Expr, State, Data> ::type , typename make_if_<A9, Expr, State, Data> ::type> type; |
|
static bool const applied = true; |
|
}; |
|
template<typename R , typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7 , typename A8 , typename A9> |
|
struct is_applyable<R(A0 , A1 , A2 , A3 , A4 , A5 , A6 , A7 , A8 , A9)> |
|
: mpl::true_ |
|
{}; |
|
template<typename R , typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7 , typename A8 , typename A9> |
|
struct is_applyable<R(*)(A0 , A1 , A2 , A3 , A4 , A5 , A6 , A7 , A8 , A9)> |
|
: mpl::true_ |
|
{}; |
|
template<typename T, typename A> |
|
struct construct_<proto::expr<T, A, 10>, true> |
|
{ |
|
typedef proto::expr<T, A, 10> result_type; |
|
template<typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7 , typename A8 , typename A9> |
|
result_type operator ()(A0 &a0 , A1 &a1 , A2 &a2 , A3 &a3 , A4 &a4 , A5 &a5 , A6 &a6 , A7 &a7 , A8 &a8 , A9 &a9) const |
|
{ |
|
return result_type::make(a0 , a1 , a2 , a3 , a4 , a5 , a6 , a7 , a8 , a9); |
|
} |
|
}; |
|
template<typename T, typename A> |
|
struct construct_<proto::basic_expr<T, A, 10>, true> |
|
{ |
|
typedef proto::basic_expr<T, A, 10> result_type; |
|
template<typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7 , typename A8 , typename A9> |
|
result_type operator ()(A0 &a0 , A1 &a1 , A2 &a2 , A3 &a3 , A4 &a4 , A5 &a5 , A6 &a6 , A7 &a7 , A8 &a8 , A9 &a9) const |
|
{ |
|
return result_type::make(a0 , a1 , a2 , a3 , a4 , a5 , a6 , a7 , a8 , a9); |
|
} |
|
}; |
|
template<typename Type , typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7 , typename A8 , typename A9> |
|
Type construct(A0 &a0 , A1 &a1 , A2 &a2 , A3 &a3 , A4 &a4 , A5 &a5 , A6 &a6 , A7 &a7 , A8 &a8 , A9 &a9) |
|
{ |
|
return construct_<Type>()(a0 , a1 , a2 , a3 , a4 , a5 , a6 , a7 , a8 , a9); |
|
} |
|
} |
|
|
|
|
|
|
|
|
|
template<typename Object , typename A0 , typename A1 , typename A2 , typename A3 , typename A4 , typename A5 , typename A6 , typename A7 , typename A8 , typename A9> |
|
struct make<Object(A0 , A1 , A2 , A3 , A4 , A5 , A6 , A7 , A8 , A9)> |
|
: transform<make<Object(A0 , A1 , A2 , A3 , A4 , A5 , A6 , A7 , A8 , A9)> > |
|
{ |
|
template<typename Expr, typename State, typename Data> |
|
struct impl : transform_impl<Expr, State, Data> |
|
{ |
|
|
|
typedef typename detail::make_if_<Object, Expr, State, Data>::type result_type; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
result_type operator ()( |
|
typename impl::expr_param e |
|
, typename impl::state_param s |
|
, typename impl::data_param d |
|
) const |
|
{ |
|
proto::detail::ignore_unused(e); |
|
proto::detail::ignore_unused(s); |
|
proto::detail::ignore_unused(d); |
|
return detail::construct<result_type>(detail::as_lvalue( typename when<_, A0>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A1>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A2>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A3>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A4>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A5>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A6>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A7>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A8>::template impl<Expr, State, Data>()(e, s, d) ) , detail::as_lvalue( typename when<_, A9>::template impl<Expr, State, Data>()(e, s, d) )); |
|
} |
|
}; |
|
};
|
|
|