You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1321 lines
59 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>
BOOST_FORCEINLINE
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>
BOOST_FORCEINLINE
result_type operator ()(A0 &a0) const
{
return result_type::make(a0);
}
};
template<typename Type >
BOOST_FORCEINLINE
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;
BOOST_FORCEINLINE
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>
BOOST_FORCEINLINE
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>
BOOST_FORCEINLINE
result_type operator ()(A0 &a0) const
{
return result_type::make(a0);
}
};
template<typename Type , typename A0>
BOOST_FORCEINLINE
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;
BOOST_FORCEINLINE
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) ));
}
};
};
template<typename Object , typename A0>
struct make<Object(A0...)>
: transform<make<Object(A0...)> >
{
template<typename Expr, typename State, typename Data>
struct impl
: make<
typename detail::expand_pattern<
proto::arity_of<Expr>::value
, A0
, detail::expand_pattern_rest_0<
Object
>
>::type
>::template impl<Expr, State, Data>
{};
};
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>
BOOST_FORCEINLINE
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>
BOOST_FORCEINLINE
result_type operator ()(A0 &a0 , A1 &a1) const
{
return result_type::make(a0 , a1);
}
};
template<typename Type , typename A0 , typename A1>
BOOST_FORCEINLINE
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;
BOOST_FORCEINLINE
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) ));
}
};
};
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
: make<
typename detail::expand_pattern<
proto::arity_of<Expr>::value
, A1
, detail::expand_pattern_rest_1<
Object
, A0
>
>::type
>::template impl<Expr, State, Data>
{};
};
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>
BOOST_FORCEINLINE
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>
BOOST_FORCEINLINE
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>
BOOST_FORCEINLINE
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;
BOOST_FORCEINLINE
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) ));
}
};
};
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
: make<
typename detail::expand_pattern<
proto::arity_of<Expr>::value
, A2
, detail::expand_pattern_rest_2<
Object
, A0 , A1
>
>::type
>::template impl<Expr, State, Data>
{};
};
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>
BOOST_FORCEINLINE
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>
BOOST_FORCEINLINE
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>
BOOST_FORCEINLINE
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;
BOOST_FORCEINLINE
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) ));
}
};
};
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
: make<
typename detail::expand_pattern<
proto::arity_of<Expr>::value
, A3
, detail::expand_pattern_rest_3<
Object
, A0 , A1 , A2
>
>::type
>::template impl<Expr, State, Data>
{};
};
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>
BOOST_FORCEINLINE
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>
BOOST_FORCEINLINE
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>
BOOST_FORCEINLINE
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;
BOOST_FORCEINLINE
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) ));
}
};
};
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
: make<
typename detail::expand_pattern<
proto::arity_of<Expr>::value
, A4
, detail::expand_pattern_rest_4<
Object
, A0 , A1 , A2 , A3
>
>::type
>::template impl<Expr, State, Data>
{};
};
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>
BOOST_FORCEINLINE
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>
BOOST_FORCEINLINE
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>
BOOST_FORCEINLINE
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;
BOOST_FORCEINLINE
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) ));
}
};
};
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
: make<
typename detail::expand_pattern<
proto::arity_of<Expr>::value
, A5
, detail::expand_pattern_rest_5<
Object
, A0 , A1 , A2 , A3 , A4
>
>::type
>::template impl<Expr, State, Data>
{};
};
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>
BOOST_FORCEINLINE
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>
BOOST_FORCEINLINE
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>
BOOST_FORCEINLINE
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;
BOOST_FORCEINLINE
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) ));
}
};
};
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
: make<
typename detail::expand_pattern<
proto::arity_of<Expr>::value
, A6
, detail::expand_pattern_rest_6<
Object
, A0 , A1 , A2 , A3 , A4 , A5
>
>::type
>::template impl<Expr, State, Data>
{};
};
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>
BOOST_FORCEINLINE
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>
BOOST_FORCEINLINE
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>
BOOST_FORCEINLINE
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;
BOOST_FORCEINLINE
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) ));
}
};
};
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
: make<
typename detail::expand_pattern<
proto::arity_of<Expr>::value
, A7
, detail::expand_pattern_rest_7<
Object
, A0 , A1 , A2 , A3 , A4 , A5 , A6
>
>::type
>::template impl<Expr, State, Data>
{};
};
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>
BOOST_FORCEINLINE
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>
BOOST_FORCEINLINE
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>
BOOST_FORCEINLINE
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;
BOOST_FORCEINLINE
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) ));
}
};
};
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
: make<
typename detail::expand_pattern<
proto::arity_of<Expr>::value
, A8
, detail::expand_pattern_rest_8<
Object
, A0 , A1 , A2 , A3 , A4 , A5 , A6 , A7
>
>::type
>::template impl<Expr, State, Data>
{};
};
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>
BOOST_FORCEINLINE
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>
BOOST_FORCEINLINE
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>
BOOST_FORCEINLINE
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;
BOOST_FORCEINLINE
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) ));
}
};
};
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
: make<
typename detail::expand_pattern<
proto::arity_of<Expr>::value
, A9
, detail::expand_pattern_rest_9<
Object
, A0 , A1 , A2 , A3 , A4 , A5 , A6 , A7 , A8
>
>::type
>::template impl<Expr, State, Data>
{};
};