Если он должен работать в vs2010, тогда ваша лучшая ставка - Boost.Preprocessor . Он не так надежен, как шаблоны с вариадностью, поскольку он имеет максимальную глубину рекурсии 3 и максимальное число итераций 256, но он работает в каждом компиляторе с поддержкой C ++ 11 или без нее. Не совсем понятно, что вы пытаетесь сделать с этими примерами, но если вы просто пытаетесь декорировать функции, я использую следующее (использует C ++ 11 для идеальной пересылки с Boost.Preprocessor вместо шаблонов с переменным числом аргументов):
#define FORWARD(z, n, data) \
::std::forward<BOOST_PP_CAT(BOOST_PP_TUPLE_ELEM(2, 0, data), n)> \
(BOOST_PP_CAT(BOST_PP_TUPLE_ELEM(2, 1, data), n)) \
/**/
//------------------------------------------------------------------------
// template<class R, class... A>
// ::std::function<R(A...)> decorate(::std::function<R(A...)> const& func)
// {
// return [func](A&&... a) -> R
// {
// /* DECORATOR STUFF */
// return func(::std::forward<A>(a)...);
// };
// }
//------------------------------------------------------------------------
#define MACRO(z, n, _) \
template<class R BOOST_PP_ENUM_TRAILING_PARAMS_Z(z, n, class A)> \
::std::function<R(BOOST_PP_ENUM_PARAMS_Z(z, n, a)> \
decorate(::std::function<R(BOOST_PP_ENUM_PARAMS_Z(z, n, A))> const& func) \
{ \
return [func](BOOST_PP_ENUM_BINARY_PARAMS_Z(z, n, A, &&a)) -> R \
{ \
/* DECORATOR STUFF */ \
return func(BOOST_PP_ENUM_ ## z(n, FORWARD, (A, a))); \
}; \
} \
/**/
BOOST_PP_REPEAT(10, MACRO, ~)
#undef MACRO
#undef FORWARD
Если вы просто пытаетесь связать аргументы функции, то std :: bind - это то, что вы ищете. Обратите внимание, что вы можете сделать все это только с помощью lambdas , но функции декоратора можно использовать для декорирования нескольких функций (где лямбды, конечно, однозначно), а связывание может быть немного более кратким для аргументов привязки (однако лямбда-эквивалент иногда более читабелен).