Daniel Dunbar | a572887 | 2009-12-15 20:14:24 +0000 | [diff] [blame] | 1 | // RUN: %clang_cc1 -fsyntax-only -verify %s |
Douglas Gregor | ddc29e1 | 2009-02-06 22:42:48 +0000 | [diff] [blame] | 2 | |
| 3 | template<typename T> class A; |
| 4 | |
| 5 | extern "C++" { |
| 6 | template<typename T> class B; |
| 7 | } |
| 8 | |
| 9 | namespace N { |
| 10 | template<typename T> class C; |
| 11 | } |
| 12 | |
| 13 | extern "C" { |
| 14 | template<typename T> class D; // expected-error{{templates must have C++ linkage}} |
| 15 | } |
| 16 | |
Douglas Gregor | ed4ec8f | 2009-05-03 17:18:57 +0000 | [diff] [blame] | 17 | template<class U> class A; // expected-note{{previous template declaration is here}} |
Douglas Gregor | ddc29e1 | 2009-02-06 22:42:48 +0000 | [diff] [blame] | 18 | |
| 19 | template<int N> class A; // expected-error{{template parameter has a different kind in template redeclaration}} |
| 20 | |
Douglas Gregor | ddc29e1 | 2009-02-06 22:42:48 +0000 | [diff] [blame] | 21 | template<int N> class NonTypeTemplateParm; |
| 22 | |
| 23 | typedef int INT; |
| 24 | |
Chris Lattner | d0344a4 | 2009-02-19 23:45:49 +0000 | [diff] [blame] | 25 | template<INT M> class NonTypeTemplateParm; // expected-note{{previous non-type template parameter with type 'INT' (aka 'int') is here}} |
Douglas Gregor | ddc29e1 | 2009-02-06 22:42:48 +0000 | [diff] [blame] | 26 | |
| 27 | template<long> class NonTypeTemplateParm; // expected-error{{template non-type parameter has a different type 'long' in template redeclaration}} |
| 28 | |
| 29 | template<template<typename T> class X> class TemplateTemplateParm; |
| 30 | |
| 31 | template<template<class> class Y> class TemplateTemplateParm; // expected-note{{previous template declaration is here}} \ |
| 32 | // expected-note{{previous template template parameter is here}} |
| 33 | |
| 34 | template<typename> class TemplateTemplateParm; // expected-error{{template parameter has a different kind in template redeclaration}} |
| 35 | |
| 36 | template<template<typename T, int> class X> class TemplateTemplateParm; // expected-error{{too many template parameters in template template parameter redeclaration}} |
| 37 | |
Douglas Gregor | 4c4f7cb | 2009-06-22 23:20:33 +0000 | [diff] [blame] | 38 | template<typename T> |
| 39 | struct test {}; // expected-note{{previous definition}} |
| 40 | |
| 41 | template<typename T> |
| 42 | struct test : T {}; // expected-error{{redefinition}} |
| 43 | |
Douglas Gregor | ddc29e1 | 2009-02-06 22:42:48 +0000 | [diff] [blame] | 44 | class X { |
| 45 | public: |
| 46 | template<typename T> class C; |
| 47 | }; |
| 48 | |
| 49 | void f() { |
Douglas Gregor | c2f3882 | 2009-11-05 20:02:41 +0000 | [diff] [blame] | 50 | template<typename T> class X; // expected-error{{expression}} |
Douglas Gregor | ddc29e1 | 2009-02-06 22:42:48 +0000 | [diff] [blame] | 51 | } |
Douglas Gregor | c7621a6 | 2009-11-05 20:54:04 +0000 | [diff] [blame] | 52 | |
Larisse Voufo | ef4579c | 2013-08-06 01:03:05 +0000 | [diff] [blame] | 53 | template<typename T> class X1 var; // expected-warning{{variable templates are a C++1y extension}} \ |
| 54 | // expected-error {{variable has incomplete type 'class X1'}} \ |
| 55 | // expected-note {{forward declaration of 'X1'}} |
Douglas Gregor | 57265e3 | 2010-04-12 16:00:01 +0000 | [diff] [blame] | 56 | |
| 57 | namespace M { |
| 58 | } |
| 59 | |
| 60 | template<typename T> class M::C3 { }; // expected-error{{out-of-line definition of 'C3' does not match any declaration in namespace 'M'}} |
Nick Lewycky | 37574f5 | 2010-11-08 23:29:42 +0000 | [diff] [blame] | 61 | |
| 62 | namespace PR8001 { |
| 63 | template<typename T1> |
| 64 | struct Foo { |
| 65 | template<typename T2> class Bar; |
| 66 | typedef Bar<T1> Baz; |
| 67 | |
| 68 | template<typename T2> |
| 69 | struct Bar { |
| 70 | Bar() {} |
| 71 | }; |
| 72 | }; |
| 73 | |
| 74 | void pr8001() { |
| 75 | Foo<int>::Baz x; |
| 76 | Foo<int>::Bar<int> y(x); |
| 77 | } |
| 78 | } |
Douglas Gregor | 95e5510 | 2011-10-21 15:47:52 +0000 | [diff] [blame] | 79 | |
Douglas Gregor | 2c1227c | 2011-11-07 17:43:18 +0000 | [diff] [blame] | 80 | namespace rdar9676205 { |
| 81 | template <unsigned, class _Tp> class tuple_element; |
| 82 | |
| 83 | template <class _T1, class _T2> class pair; |
| 84 | |
| 85 | template <class _T1, class _T2> |
| 86 | class tuple_element<0, pair<_T1, _T2> > |
| 87 | { |
| 88 | template <class _Tp> |
| 89 | struct X |
| 90 | { |
| 91 | template <class _Up, bool = X<_Up>::value> |
| 92 | struct Y |
| 93 | : public X<_Up>, |
| 94 | public Y<_Up> |
| 95 | { }; |
| 96 | }; |
| 97 | }; |
| 98 | } |
Richard Smith | 71c598f | 2012-04-21 01:27:54 +0000 | [diff] [blame] | 99 | |
| 100 | namespace redecl { |
| 101 | int A; // expected-note {{here}} |
| 102 | template<typename T> struct A; // expected-error {{different kind of symbol}} |
| 103 | |
Richard Smith | 227e9f6 | 2012-04-21 01:51:32 +0000 | [diff] [blame] | 104 | int B; // expected-note {{here}} |
Richard Smith | 71c598f | 2012-04-21 01:27:54 +0000 | [diff] [blame] | 105 | template<typename T> struct B { // expected-error {{different kind of symbol}} |
| 106 | }; |
| 107 | |
| 108 | template<typename T> struct F; |
| 109 | template<typename T> struct K; |
| 110 | |
Richard Smith | 227e9f6 | 2012-04-21 01:51:32 +0000 | [diff] [blame] | 111 | int G, H; // expected-note {{here}} |
Richard Smith | 71c598f | 2012-04-21 01:27:54 +0000 | [diff] [blame] | 112 | |
| 113 | struct S { |
| 114 | int C; // expected-note {{here}} |
| 115 | template<typename T> struct C; // expected-error {{different kind of symbol}} |
| 116 | |
Richard Smith | 227e9f6 | 2012-04-21 01:51:32 +0000 | [diff] [blame] | 117 | int D; // expected-note {{here}} |
Richard Smith | 71c598f | 2012-04-21 01:27:54 +0000 | [diff] [blame] | 118 | template<typename T> struct D { // expected-error {{different kind of symbol}} |
| 119 | }; |
| 120 | |
| 121 | int E; |
| 122 | template<typename T> friend struct E { // expected-error {{cannot define a type in a friend}} |
| 123 | }; |
| 124 | |
| 125 | int F; |
| 126 | template<typename T> friend struct F; // ok, redecl::F |
| 127 | |
| 128 | template<typename T> struct G; // ok |
| 129 | |
| 130 | template<typename T> friend struct H; // expected-error {{different kind of symbol}} |
| 131 | |
| 132 | int I, J, K; |
| 133 | |
| 134 | struct U { |
| 135 | template<typename T> struct I; // ok |
| 136 | template<typename T> struct J { // ok |
| 137 | }; |
| 138 | template<typename T> friend struct K; // ok, redecl::K |
| 139 | }; |
| 140 | }; |
| 141 | } |