Daniel Dunbar | a572887 | 2009-12-15 20:14:24 +0000 | [diff] [blame] | 1 | // RUN: %clang_cc1 -fsyntax-only -verify %s |
Douglas Gregor | d60e105 | 2009-08-27 16:57:43 +0000 | [diff] [blame] | 2 | |
| 3 | template<typename T> |
| 4 | struct X0 { |
| 5 | template<typename U> T f0(U); |
| 6 | template<typename U> U& f1(T*, U); // expected-error{{pointer to a reference}} \ |
| 7 | // expected-note{{candidate}} |
| 8 | }; |
| 9 | |
| 10 | X0<int> x0i; |
| 11 | X0<void> x0v; |
| 12 | X0<int&> x0ir; // expected-note{{instantiation}} |
| 13 | |
| 14 | void test_X0(int *ip, double *dp) { |
| 15 | X0<int> xi; |
| 16 | int i1 = xi.f0(ip); |
| 17 | double *&dpr = xi.f1(ip, dp); |
| 18 | xi.f1(dp, dp); // expected-error{{no matching}} |
| 19 | |
| 20 | X0<void> xv; |
| 21 | double *&dpr2 = xv.f1(ip, dp); |
| 22 | } |
Douglas Gregor | d110243 | 2009-08-28 17:37:35 +0000 | [diff] [blame] | 23 | |
Douglas Gregor | d6350ae | 2009-08-28 20:31:08 +0000 | [diff] [blame] | 24 | template<typename T> |
| 25 | struct X1 { |
| 26 | template<typename U> |
| 27 | struct Inner0 { |
| 28 | U x; |
| 29 | T y; // expected-error{{void}} |
| 30 | }; |
| 31 | |
| 32 | template<typename U> |
| 33 | struct Inner1 { |
| 34 | U x; // expected-error{{void}} |
Douglas Gregor | 357bbd0 | 2009-08-28 20:50:45 +0000 | [diff] [blame] | 35 | T y; |
| 36 | }; |
| 37 | |
| 38 | template<typename U> |
| 39 | struct Inner2 { |
| 40 | struct SuperInner { |
| 41 | U z; // expected-error{{void}} |
| 42 | }; |
Douglas Gregor | d6350ae | 2009-08-28 20:31:08 +0000 | [diff] [blame] | 43 | }; |
Douglas Gregor | 5ec178f | 2009-08-28 21:09:48 +0000 | [diff] [blame] | 44 | |
| 45 | template<typename U> |
| 46 | struct Inner3 { |
Douglas Gregor | a41a8c5 | 2010-04-22 00:20:18 +0000 | [diff] [blame] | 47 | void f0(T t, U u) { // expected-note{{passing argument to parameter 't' here}} |
Douglas Gregor | 5ec178f | 2009-08-28 21:09:48 +0000 | [diff] [blame] | 48 | (void)(t + u); // expected-error{{invalid operands}} |
| 49 | } |
| 50 | |
| 51 | template<typename V> |
| 52 | V f1(T t, U u, V) { |
Douglas Gregor | 18ef5e2 | 2009-12-18 05:02:21 +0000 | [diff] [blame] | 53 | return t + u; // expected-error{{cannot initialize return object}} |
Douglas Gregor | 5ec178f | 2009-08-28 21:09:48 +0000 | [diff] [blame] | 54 | } |
| 55 | }; |
| 56 | |
Douglas Gregor | 8320ad4 | 2009-08-28 21:15:08 +0000 | [diff] [blame] | 57 | template<typename U> |
| 58 | struct Inner4; |
Douglas Gregor | d6350ae | 2009-08-28 20:31:08 +0000 | [diff] [blame] | 59 | }; |
| 60 | |
Douglas Gregor | 8320ad4 | 2009-08-28 21:15:08 +0000 | [diff] [blame] | 61 | template<typename T> |
| 62 | template<typename U> |
| 63 | struct X1<T>::Inner4 { |
| 64 | template<typename V> |
| 65 | V f2(T t, U u, V); |
Douglas Gregor | 3cd4d1e | 2009-08-28 21:41:19 +0000 | [diff] [blame] | 66 | |
| 67 | static U value; |
Douglas Gregor | 8320ad4 | 2009-08-28 21:15:08 +0000 | [diff] [blame] | 68 | }; |
| 69 | |
| 70 | template<typename T> |
| 71 | template<typename U> |
Douglas Gregor | 3cd4d1e | 2009-08-28 21:41:19 +0000 | [diff] [blame] | 72 | U X1<T>::Inner4<U>::value; // expected-error{{reference variable}} |
| 73 | |
| 74 | template<typename T> |
| 75 | template<typename U> |
Douglas Gregor | 8320ad4 | 2009-08-28 21:15:08 +0000 | [diff] [blame] | 76 | template<typename V> |
| 77 | V X1<T>::Inner4<U>::f2(T t, U u, V) { |
Douglas Gregor | 18ef5e2 | 2009-12-18 05:02:21 +0000 | [diff] [blame] | 78 | return t + u; // expected-error{{cannot initialize return object}} |
Douglas Gregor | 8320ad4 | 2009-08-28 21:15:08 +0000 | [diff] [blame] | 79 | } |
| 80 | |
Douglas Gregor | 5ec178f | 2009-08-28 21:09:48 +0000 | [diff] [blame] | 81 | void test_X1(int *ip, int i, double *dp) { |
Douglas Gregor | d6350ae | 2009-08-28 20:31:08 +0000 | [diff] [blame] | 82 | X1<void>::Inner0<int> *xvip; // okay |
| 83 | X1<void>::Inner0<int> xvi; // expected-note{{instantiation}} |
| 84 | |
| 85 | X1<int>::Inner1<void> *xivp; // okay |
| 86 | X1<int>::Inner1<void> xiv; // expected-note{{instantiation}} |
Douglas Gregor | 357bbd0 | 2009-08-28 20:50:45 +0000 | [diff] [blame] | 87 | |
| 88 | X1<int>::Inner2<void>::SuperInner *xisivp; // okay |
| 89 | X1<int>::Inner2<void>::SuperInner xisiv; // expected-note{{instantiation}} |
Douglas Gregor | 5ec178f | 2009-08-28 21:09:48 +0000 | [diff] [blame] | 90 | |
| 91 | X1<int*>::Inner3<int> id3; |
| 92 | id3.f0(ip, i); |
Douglas Gregor | aa03731 | 2009-12-22 07:24:36 +0000 | [diff] [blame] | 93 | id3.f0(dp, i); // expected-error{{cannot initialize a parameter of type 'int *' with an lvalue of type 'double *'}} |
Douglas Gregor | 5ec178f | 2009-08-28 21:09:48 +0000 | [diff] [blame] | 94 | id3.f1(ip, i, ip); |
| 95 | id3.f1(ip, i, dp); // expected-note{{instantiation}} |
| 96 | |
| 97 | X1<int*>::Inner3<double*> id3b; |
| 98 | id3b.f0(ip, dp); // expected-note{{instantiation}} |
Douglas Gregor | 8320ad4 | 2009-08-28 21:15:08 +0000 | [diff] [blame] | 99 | |
| 100 | X1<int*>::Inner4<int> id4; |
| 101 | id4.f2(ip, i, dp); // expected-note{{instantiation}} |
Douglas Gregor | 3cd4d1e | 2009-08-28 21:41:19 +0000 | [diff] [blame] | 102 | |
| 103 | X1<int*>::Inner4<int>::value = 17; |
| 104 | i = X1<int*>::Inner4<int&>::value; // expected-note{{instantiation}} |
Douglas Gregor | d6350ae | 2009-08-28 20:31:08 +0000 | [diff] [blame] | 105 | } |
Douglas Gregor | 11a8240 | 2009-11-09 18:29:00 +0000 | [diff] [blame] | 106 | |
| 107 | |
| 108 | template<typename T> |
| 109 | struct X2 { |
| 110 | template<T *Ptr> // expected-error{{pointer to a reference}} |
| 111 | struct Inner; |
| 112 | |
| 113 | template<T Value> // expected-error{{cannot have type 'float'}} |
| 114 | struct Inner2; |
| 115 | }; |
| 116 | |
| 117 | X2<int&> x2a; // expected-note{{instantiation}} |
| 118 | X2<float> x2b; // expected-note{{instantiation}} |
Douglas Gregor | 699ee52 | 2009-11-20 19:42:02 +0000 | [diff] [blame] | 119 | |
| 120 | namespace N0 { |
| 121 | template<typename T> |
| 122 | struct X0 { }; |
| 123 | |
| 124 | struct X1 { |
| 125 | template<typename T> void f(X0<T>& vals) { g(vals); } |
| 126 | template<typename T> void g(X0<T>& vals) { } |
| 127 | }; |
| 128 | |
| 129 | void test(X1 x1, X0<int> x0i, X0<long> x0l) { |
| 130 | x1.f(x0i); |
| 131 | x1.f(x0l); |
| 132 | } |
| 133 | } |
Douglas Gregor | 8b013bd | 2010-02-05 22:40:03 +0000 | [diff] [blame] | 134 | |
| 135 | namespace PR6239 { |
| 136 | template <typename T> |
| 137 | struct X0 { |
| 138 | class type { |
| 139 | typedef T E; |
| 140 | template <E e> // subsitute T for E and bug goes away |
| 141 | struct sfinae { }; |
| 142 | |
| 143 | template <class U> |
| 144 | typename sfinae<&U::operator=>::type test(int); |
| 145 | }; |
| 146 | }; |
| 147 | |
| 148 | template <typename T> |
| 149 | struct X1 { |
| 150 | typedef T E; |
| 151 | template <E e> // subsitute T for E and bug goes away |
| 152 | struct sfinae { }; |
| 153 | |
| 154 | template <class U> |
| 155 | typename sfinae<&U::operator=>::type test(int); |
| 156 | }; |
| 157 | |
| 158 | } |