// RUN: %clang_cc1 -fsyntax-only -verify %s -fcxx-exceptions template struct X0 { typedef T* type; void f0(T); void f1(type); }; template<> void X0::f0(char); template<> void X0::f1(type); namespace PR6161 { template class numpunct : public locale::facet // expected-error{{use of undeclared identifier 'locale'}} \ // expected-error{{expected class name}} { static locale::id id; // expected-error{{use of undeclared identifier}} }; numpunct::~numpunct(); } namespace PR12331 { template struct S { struct U { static const int n = 5; }; enum E { e = U::n }; // expected-note {{implicit instantiation first required here}} int arr[e]; }; template<> struct S::U { static const int n = sizeof(int); }; // expected-error {{explicit specialization of 'U' after instantiation}} } namespace PR18246 { template class Baz { public: template void bar(); }; template template void Baz::bar() { // expected-note {{couldn't infer template argument 'N'}} } // FIXME: We shouldn't try to match this against a prior declaration if // template parameter matching failed. template void Baz::bar<0>() { // expected-error {{cannot specialize a member of an unspecialized template}} \ // expected-error {{no function template matches}} } } namespace PR19340 { template struct Helper { template static void func(const T *m) {} // expected-note {{failed template argument deduction}} }; template void Helper::func<2>() {} // expected-error {{cannot specialize a member}} \ // expected-error {{no function template matches}} } namespace SpecLoc { template struct A { static int n; // expected-note {{previous}} static void f(); // expected-note {{previous}} }; template<> float A::n; // expected-error {{different type}} template<> void A::f() throw(); // expected-error {{does not match}} }