1 // RUN: %clang_cc1 -std=c++14 -fsyntax-only -verify %s
3 template<typename T
> class A
{};
6 template<typename T
> class B
{};
7 template<typename T
> class A
<T
*>;
8 template<> class A
<int[1]>;
9 template class A
<int[2]>;
10 template<typename T
> class B
<T
*>;
11 template<> class B
<int[1]>;
12 template class B
<int[2]>;
16 template<typename T
> class C
;
19 extern "C" { // expected-note 3 {{extern "C" language linkage specification begins here}}
20 template<typename T
> class D
; // expected-error{{templates must have C++ linkage}}
21 template<typename T
> class A
<T
**>; // expected-error{{templates must have C++ linkage}}
22 template<> class A
<int[3]>; // expected-error{{templates must have C++ linkage}}
23 template class A
<int[4]>; // OK (surprisingly) FIXME: Should we warn on this?
26 extern "C" { // expected-note 2 {{extern "C" language linkage specification begins here}}
28 template<typename T
> class D
; // expected-error{{templates must have C++ linkage}}
29 template<typename T
> void f(); // expected-error{{templates must have C++ linkage}}
33 template<class U
> class A
; // expected-note{{previous template declaration is here}}
35 template<int N
> class A
; // expected-error{{template parameter has a different kind in template redeclaration}}
37 template<int N
> class NonTypeTemplateParm
;
41 template<INT M
> class NonTypeTemplateParm
; // expected-note{{previous non-type template parameter with type 'INT' (aka 'int') is here}}
43 template<long> class NonTypeTemplateParm
; // expected-error{{template non-type parameter has a different type 'long' in template redeclaration}}
45 template<template<typename T
> class X
> class TemplateTemplateParm
;
47 template<template<class> class Y
> class TemplateTemplateParm
; // expected-note{{previous template declaration is here}} \
48 // expected-note{{previous template template parameter is here}}
50 template<typename
> class TemplateTemplateParm
; // expected-error{{template parameter has a different kind in template redeclaration}}
52 template<template<typename T
, int> class X
> class TemplateTemplateParm
; // expected-error{{too many template parameters in template template parameter redeclaration}}
55 struct test
{}; // expected-note{{previous definition}}
58 struct test
: T
{}; // expected-error{{redefinition}}
62 template<typename T
> class C
;
66 template<typename T
> class X
; // expected-error{{templates can only be declared in namespace or class scope}}
69 template<typename T
> class X1 var
; // expected-error {{variable has incomplete type 'class X1'}} \
70 // expected-note {{forward declaration of 'X1'}}
75 template<typename T
> class M::C3
{ }; // expected-error{{out-of-line definition of 'C3' does not match any declaration in namespace 'M'}}
80 template<typename T2
> class Bar
;
91 Foo
<int>::Bar
<int> y(x
);
95 namespace rdar9676205
{
96 template <unsigned, class _Tp
> class tuple_element
;
98 template <class _T1
, class _T2
> class pair
;
100 template <class _T1
, class _T2
>
101 class tuple_element
<0, pair
<_T1
, _T2
> >
106 template <class _Up
, bool = X
<_Up
>::value
>
116 int A
; // expected-note {{here}}
117 template<typename T
> struct A
; // expected-error {{different kind of symbol}}
119 int B
; // expected-note {{here}}
120 template<typename T
> struct B
{ // expected-error {{different kind of symbol}}
123 template<typename T
> struct F
;
124 template<typename T
> struct K
;
126 int G
, H
; // expected-note {{here}}
129 int C
; // expected-note {{here}}
130 template<typename T
> struct C
; // expected-error {{different kind of symbol}}
132 int D
; // expected-note {{here}}
133 template<typename T
> struct D
{ // expected-error {{different kind of symbol}}
137 template<typename T
> friend struct E
{ // expected-error {{cannot define a type in a friend}}
141 template<typename T
> friend struct F
; // ok, redecl::F
143 template<typename T
> struct G
; // ok
145 template<typename T
> friend struct H
; // expected-error {{different kind of symbol}}
150 template<typename T
> struct I
; // ok
151 template<typename T
> struct J
{ // ok
153 template<typename T
> friend struct K
; // ok, redecl::K
158 extern "C" template <typename T
> // expected-error{{templates must have C++ linkage}}
159 void DontCrashOnThis() { // expected-note@-1 {{extern "C" language linkage specification begins here}}
164 namespace abstract_dependent_class
{
165 template<typename T
> struct A
{
166 virtual A
<T
> *clone() = 0; // expected-note {{pure virtual}}
168 template<typename T
> A
<T
> *A
<T
>::clone() { return new A
<T
>; } // expected-error {{abstract class type 'A<T>'}}
171 namespace qualified_out_of_line
{
173 template<typename T
, typename U
> struct pair
{};
174 template<typename K
, typename V
> struct rbtree
{
176 pair
<base
, base
> f();
178 template<typename K
, typename V
>
179 pair
<typename rbtree
<K
, V
>::base
, typename rbtree
<K
, V
>::base
>