// RUN: %clang_cc1 -fsyntax-only -verify %s template void *; // expected-error{{expected unqualified-id}} template typedef void f0; // expected-error{{explicit instantiation of typedef}} int v0; // expected-note{{refers here}} template int v0; // expected-error{{does not refer}} template<typename T> struct X0 { static T value; T f0(T x) { return x + 1; // expected-error{{invalid operands}} } T* f0(T*, T*) { return T(); } template<typename U> T f0(T, U) { return T(); } }; template<typename T> T X0<T>::value; // expected-error{{no matching constructor}} template int X0<int>::value; struct NotDefaultConstructible { // expected-note{{candidate constructor (the implicit copy constructor)}} NotDefaultConstructible(int); // expected-note{{candidate constructor}} }; template NotDefaultConstructible X0<NotDefaultConstructible>::value; // expected-note{{instantiation}} template int X0<int>::f0(int); template int* X0<int>::f0(int*, int*); template int X0<int>::f0(int, float); template int X0<int>::f0(int) const; // expected-error{{does not refer}} template int* X0<int>::f0(int*, float*); // expected-error{{does not refer}} struct X1 { }; typedef int X1::*MemPtr; template MemPtr X0<MemPtr>::f0(MemPtr); // expected-note{{requested here}} struct X2 { int f0(int); // expected-note{{refers here}} template<typename T> T f1(T) { return T(); } template<typename T> T* f1(T*) { return 0; } template<typename T, typename U> void f2(T, U*) { } // expected-note{{candidate}} template<typename T, typename U> void f2(T*, U) { } // expected-note{{candidate}} }; template int X2::f0(int); // expected-error{{not an instantiation}} template int *X2::f1(int *); // okay template void X2::f2(int *, int *); // expected-error{{ambiguous}} template<typename T> void print_type() { } template void print_type<int>(); template void print_type<float>(); template<typename T> void print_type(T*) { } template void print_type(int*); template void print_type<int>(float*); // expected-error{{does not refer}} void print_type(double*); template void print_type<double>(double*); // PR5069 template<int I> void foo0 (int (&)[I + 1]) { } template void foo0<2> (int (&)[3]); namespace explicit_instantiation_after_implicit_instantiation { template <int I> struct X0 { static int x; }; template <int I> int X0<I>::x; void test1() { (void)&X0<1>::x; } template struct X0<1>; } template<typename> struct X3 { }; inline template struct X3<int>; // expected-warning{{ignoring 'inline' keyword on explicit template instantiation}} static template struct X3<float>; // expected-warning{{ignoring 'static' keyword on explicit template instantiation}} namespace PR7622 { template<typename,typename=int> struct basic_streambuf; template<typename,typename> struct basic_streambuf{friend bob<>()}; // expected-error{{unknown type name 'bob'}} \ // expected-error{{expected member name or ';' after declaration specifiers}} template struct basic_streambuf<int>; } // Test that we do not crash. class TC1 { class TC2 { template // FIXME: error here. void foo() { } }; };