EVOLUTION-MANAGER
Edit File: make.hpp
/////////////////////////////////////////////////////////////////////////////// /// \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> {}; };