Сокращенный пример кода:
#include <iostream>
template<typename T>
void func(T &x)
{
std::cout << "non-const " << x << std::endl;
}
template<typename T>
void func(const T &x)
{
std::cout << "const " << x << std::endl;
}
template<typename ...ARGS>
void proxy(ARGS ...args)
{
func(args...);
}
int main()
{
int i = 3;
func(i);
func(5);
func("blah");
proxy(i);
proxy(5);
proxy("blah");
}
Ожидаемый результат:
non-const 3
const 5
const blah
non-const 3
const 5
const blah
Фактический выход:
non-const 3
const 5
const blah
non-const 3
non-const 5
non-const blah
Итак, как-то отделитель const
от параметра функции теряется при переносе вариационного шаблона. Зачем? Как я могу предотвратить это?
PS: проверено с помощью GCC 4.5.1 и SUSE 11.4