Следующий код успешно компилируется в g++ 7.2.0 (флаги компиляции: -std=c++14 -Wall -Wextra -Werror -pedantic-errors
), но не компилируется в clang++ 5.0.0 (с теми же флагами, -std=c++14 -Wall -Wextra -Werror -pedantic-errors
) и vc++ 15.4 (флаги компиляции /EHsc /Za /std:c++14 /permissive-
):
template <template <typename...> class Functor, typename... FixedArguments>
struct apply
{
template <typename... FreeArguments>
using type = Functor<FixedArguments..., FreeArguments...>;
};
template <typename, typename>
struct Bar{};
template <template <typename...> class>
struct Foo{};
int main()
{
(void)Foo<apply<Bar, int, char>::type>{};
}
Какое поведение компилятора соответствует стандарту? Как такой шаблон apply
можно изменить, чтобы он компилировался и на clang++?
clang++ сообщения об ошибках:
5 : <source>:5:15: error: too many template arguments for class template 'Bar' using type = Functor<FixedArguments..., FreeArguments...>; ^ ~~~~~~~~~~~~~~~~~ 16 : <source>:16:15: note: in instantiation of template class 'apply<Bar, int, char>' requested here (void)Foo<apply<Bar, int, char>::type>{}; ^ 9 : <source>:9:8: note: template is declared here struct Bar{};
сообщения об ошибках vc++:
5 : <source>(5): error C2977: 'Bar': too many template arguments 9 : <source>(9): note: see declaration of 'Bar' 16 : <source>(16): note: see reference to class template instantiation 'apply<Bar,int,char>' being compiled
typename...
вBar
? - person songyuanyao   schedule 22.11.2017Bar
иFoo
— это классы-примеры, демонстрирующие проблему. Их характеристики даны извне. На самом деле это самый маленький MWE, который демонстрирует проблему в каком-то сложном коде шаблона. - person Constructor   schedule 22.11.2017apply<Bar, int, char>::type
Bar<int, char>
является полностью специализированным, поэтому дополнительные типы не могут быть переданы вFunctor
позже. - person piwi   schedule 22.11.2017