Я упускаю кое-что очень фундаментальное в выводе типа здесь:
Я пытаюсь написать функцию-обертку, которая вызывает функцию записи с nullptr для получения требуемой длины, затем изменяет размер буфера, затем снова вызывает функцию, теперь с измененным размером буфера, чтобы получить окончательный вывод. Существует большое количество этих функций записи, и я хочу обобщить шаблон call / resize / call в функцию шаблона variadic.
Однако я застрял при попытке передать как указатель функции на функцию, принимающую переменные аргументы, так и передав переменные, когда любой параметр в списке является константной ссылкой:
static void val_arg(int) { }
static void ref_arg(const int&) { }
template <typename... Args>
static void helper(void (*fun)(Args...), Args... args)
{
(*fun)(args...);
}
void proxy(const int& arg)
{
helper(&val_arg, arg); // Fine
helper(&ref_arg, arg); // 'void helper(void (__cdecl *)(Args...),Args...)': template parameter 'Args' is ambiguous
// note: could be 'const int&'
// note: or 'int'
}
void test()
{
proxy(1); // Force 1 to be const int&
}
Что я могу сделать, чтобы он прозрачно принимал оба случая? Почему он не подтверждает, что переданная функция принимает const ref, а аргумент прокси-сервера также является const ref?