// RUN: %clang_cc1 -std=c++11 -fsyntax-only -verify %s template<typename T> struct identity; template<typename ...Types> struct tuple; template<typename T, typename U> struct is_same { static const bool value = false; }; template<typename T> struct is_same<T, T> { static const bool value = true; }; // There is a syntactic ambiguity when an ellipsis occurs at the end // of a parameter-declaration-clause without a preceding comma. In // this case, the ellipsis is parsed as part of the // abstract-declarator if the type of the parameter names a template // parameter pack that has not been expanded; otherwise, it is parsed // as part of the parameter-declaration-clause. template<typename T, typename ...Types> struct X0 { typedef identity<T(Types...)> function_pack_1; typedef identity<T(Types......)> variadic_function_pack_1; // expected-warning {{varargs}} expected-note {{pack}} expected-note {{insert ','}} typedef identity<T(T...)> variadic_1; typedef tuple<T(Types, ...)...> template_arg_expansion_1; }; // FIXME: Once function parameter packs are implemented, we can test all of the disambiguation