// Copyright David Abrahams, Daniel Wallin 2003. // Copyright Cromwell D. Enage 2017. // 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) #ifndef BOOST_PARAMETER_MACROS_050412_HPP #define BOOST_PARAMETER_MACROS_050412_HPP #include #include #if !defined(BOOST_NO_SFINAE) && \ !BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x592)) #define BOOST_PARAMETER_MATCH_TYPE(n, param) \ , typename param::match::type kw = param() /**/ #define BOOST_PARAMETER_MATCH_TYPE_Z(z, n, param) \ , typename param::match::type kw = param() /**/ #else // SFINAE disbled, or Borland workarounds needed. #define BOOST_PARAMETER_MATCH_TYPE(n, param) , param kw = param() /**/ #define BOOST_PARAMETER_MATCH_TYPE_Z(z, n, param) , param kw = param() /**/ #endif // SFINAE enabled, not Borland. #include #include #include #include #if defined(BOOST_PARAMETER_HAS_PERFECT_FORWARDING) #define BOOST_PARAMETER_FUN_0(z, n, params) \ BOOST_PP_TUPLE_ELEM(3, 0, params) BOOST_PP_TUPLE_ELEM(3, 1, params)() \ { \ return BOOST_PP_CAT( \ BOOST_PP_TUPLE_ELEM(3, 1, params) \ , _with_named_params \ )(BOOST_PP_TUPLE_ELEM(3, 2, params)()()); \ } /**/ #include #define BOOST_PARAMETER_FUN_DECL_PARAM(z, n, p) \ ::std::forward(BOOST_PP_CAT(p, n)) /**/ #include #define BOOST_PARAMETER_FUN_DEFN_1(z, n, params) \ template \ BOOST_PP_TUPLE_ELEM(3, 0, params) \ BOOST_PP_TUPLE_ELEM(3, 1, params)( \ BOOST_PP_ENUM_BINARY_PARAMS_Z(z, n, T, && p) \ BOOST_PARAMETER_MATCH_TYPE_Z( \ z, n, BOOST_PP_TUPLE_ELEM(3, 2, params) \ ) \ ) \ { \ return BOOST_PP_CAT( \ BOOST_PP_TUPLE_ELEM(3, 1, params) \ , _with_named_params \ )( \ kw( \ BOOST_PP_CAT(BOOST_PP_ENUM_, z)( \ n, BOOST_PARAMETER_FUN_DECL_PARAM, p \ ) \ ) \ ); \ } /**/ #define BOOST_PARAMETER_FUN_DECL(z, n, params) \ BOOST_PP_IF( \ n \ , BOOST_PARAMETER_FUN_DEFN_1 \ , BOOST_PARAMETER_FUN_0 \ )(z, n, params) /**/ #else // !defined(BOOST_PARAMETER_HAS_PERFECT_FORWARDING) #define BOOST_PARAMETER_FUN_DEFN_0(z, n, params) \ template \ BOOST_PP_TUPLE_ELEM(3, 0, params) \ BOOST_PP_TUPLE_ELEM(3, 1, params)( \ BOOST_PP_ENUM_BINARY_PARAMS_Z(z, n, T, const& p) \ BOOST_PARAMETER_MATCH_TYPE_Z( \ z, n, BOOST_PP_TUPLE_ELEM(3, 2, params) \ ) \ ) \ { \ return BOOST_PP_CAT( \ BOOST_PP_TUPLE_ELEM(3, 1, params) \ , _with_named_params \ )(kw(BOOST_PP_ENUM_PARAMS_Z(z, n, p))); \ } /**/ #include #define BOOST_PARAMETER_FUN_0(z, n, seq) \ BOOST_PP_TUPLE_ELEM(3, 0, BOOST_PP_SEQ_HEAD(BOOST_PP_SEQ_TAIL(seq))) \ BOOST_PP_TUPLE_ELEM(3, 1, BOOST_PP_SEQ_HEAD(BOOST_PP_SEQ_TAIL(seq)))() \ { \ return BOOST_PP_CAT( \ BOOST_PP_TUPLE_ELEM( \ 3, 1, BOOST_PP_SEQ_HEAD(BOOST_PP_SEQ_TAIL(seq)) \ ) \ , _with_named_params \ )( \ BOOST_PP_TUPLE_ELEM(3, 2, BOOST_PP_SEQ_HEAD(BOOST_PP_SEQ_TAIL(seq))) \ ()() \ ); \ } /**/ #include #include #define BOOST_PARAMETER_FUN_DEFN_R(r, seq) \ template < \ BOOST_PP_ENUM_PARAMS( \ BOOST_PP_SEQ_SIZE(BOOST_PP_SEQ_TAIL(seq)) \ , typename T \ ) \ > BOOST_PP_TUPLE_ELEM(3, 0, BOOST_PP_SEQ_HEAD(seq)) \ BOOST_PP_TUPLE_ELEM(3, 1, BOOST_PP_SEQ_HEAD(seq))( \ BOOST_PARAMETER_AUX_PP_BINARY_SEQ_TO_ARGS( \ BOOST_PP_SEQ_TAIL(seq), (T)(p) \ ) \ BOOST_PARAMETER_MATCH_TYPE( \ BOOST_PP_SEQ_SIZE(BOOST_PP_SEQ_TAIL(seq)) \ , BOOST_PP_TUPLE_ELEM(3, 2, BOOST_PP_SEQ_HEAD(seq)) \ ) \ ) \ { \ return BOOST_PP_CAT( \ BOOST_PP_TUPLE_ELEM(3, 1, BOOST_PP_SEQ_HEAD(seq)) \ , _with_named_params \ )( \ kw( \ BOOST_PP_ENUM_PARAMS( \ BOOST_PP_SEQ_SIZE(BOOST_PP_SEQ_TAIL(seq)), p \ ) \ ) \ ); \ } /**/ #include #include #define BOOST_PARAMETER_FUN_DEFN_1(z, n, params) \ BOOST_PP_IF( \ n \ , BOOST_PARAMETER_AUX_PP_BINARY_SEQ_FOR_EACH_Z \ , BOOST_PARAMETER_FUN_0 \ )(z, n, (BOOST_PARAMETER_FUN_DEFN_R)(params)) /**/ #include #define BOOST_PARAMETER_FUN_DECL(z, n, params) \ BOOST_PP_CAT( \ BOOST_PARAMETER_FUN_DEFN_ \ , BOOST_PP_LESS( \ n \ , BOOST_PARAMETER_EXPONENTIAL_OVERLOAD_THRESHOLD_ARITY \ ) \ )(z, n, params) /**/ #endif // BOOST_PARAMETER_HAS_PERFECT_FORWARDING #include #include // Generates: // // template // ret name ## _with_named_params(Params const&); // // template // ret name( // T0 && p0 // , typename parameters::match::type kw = parameters() // ) // { // return name ## _with_named_params(kw(p0)); // } // // template // ret name( // T0 && p0, ..., TN && p ## N // , typename parameters::match::type kw = parameters() // ) // { // return name ## _with_named_params(kw(p0, ..., p ## N)); // } // // template // ret name ## _with_named_params(Params const&) // // lo and hi determine the min and max arities of the generated functions. #define BOOST_PARAMETER_MEMFUN(ret, name, lo, hi, parameters) \ BOOST_PP_REPEAT_FROM_TO( \ lo, BOOST_PP_INC(hi), BOOST_PARAMETER_FUN_DECL \ , (ret, name, parameters) \ ) \ template \ ret BOOST_PP_CAT(name, _with_named_params)(Params const& p) /**/ #define BOOST_PARAMETER_FUN(ret, name, lo, hi, parameters) \ template \ ret BOOST_PP_CAT(name, _with_named_params)(Params const& p); \ BOOST_PARAMETER_MEMFUN(ret, name, lo, hi, parameters) /**/ #endif // include guard