I\'ve recently learned that I cannot:
For non-overloaded functions, pointers to functions, and pointers to member functions, simply doing decltype(function)
gives you the type of the function in an unevaluated context, and that type contains all the arguments.
So to get the the argument types as a tuple, all you need are a lot of specializations:
// primary for function objects
template
struct function_args
: function_args
{ };
// normal function
template
struct function_args {
using type = std::tuple;
};
// pointer to non-cv-qualified, non-ref-qualified, non-variadic member function
template
struct function_args
: function_args
{ };
// + a few dozen more in C++14
// + a few dozen more on top of that with noexcept being part of the type system in C++17
With that:
template
using decltypeargs = typename function_args::type;
This requires you to write decltypeargs
.
With C++17, we will have template
, so the above can be:
template
using decltypeargs = typename function_args::type;
and you'd get the decltypeargs
syntax.