1321 lines
60 KiB
Plaintext
1321 lines
60 KiB
Plaintext
///////////////////////////////////////////////////////////////////////////////
|
|
/// \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>
|
|
{};
|
|
};
|