Richard Smith | 9ca5c42 | 2011-10-13 22:29:44 +0000 | [diff] [blame] | 1 | // RUN: %clang_cc1 -fsyntax-only -fcxx-exceptions -verify -std=c++11 -Wall %s |
Richard Smith | 938f40b | 2011-06-11 17:19:42 +0000 | [diff] [blame] | 2 | |
| 3 | struct Bitfield { |
| 4 | int n : 3 = 7; // expected-error {{bitfield member cannot have an in-class initializer}} |
| 5 | }; |
| 6 | |
| 7 | int a; |
| 8 | class NoWarning { |
| 9 | int &n = a; |
| 10 | public: |
| 11 | int &GetN() { return n; } |
| 12 | }; |
| 13 | |
| 14 | bool b(); |
| 15 | int k; |
| 16 | struct Recurse { |
Reid Kleckner | d60b82f | 2014-11-17 23:36:45 +0000 | [diff] [blame] | 17 | int &n = // expected-error {{cannot use defaulted default constructor of 'Recurse' within the class outside of member functions because 'n' has an initializer}} |
| 18 | b() ? |
| 19 | Recurse().n : // expected-note {{implicit default constructor for 'Recurse' first required here}} |
| 20 | k; |
Richard Smith | 938f40b | 2011-06-11 17:19:42 +0000 | [diff] [blame] | 21 | }; |
| 22 | |
| 23 | struct UnknownBound { |
| 24 | int as[] = { 1, 2, 3 }; // expected-error {{array bound cannot be deduced from an in-class initializer}} |
| 25 | int bs[4] = { 4, 5, 6, 7 }; |
| 26 | int cs[] = { 8, 9, 10 }; // expected-error {{array bound cannot be deduced from an in-class initializer}} |
| 27 | }; |
| 28 | |
| 29 | template<int n> struct T { static const int B; }; |
| 30 | template<> struct T<2> { template<int C, int D> using B = int; }; |
| 31 | const int C = 0, D = 0; |
| 32 | struct S { |
| 33 | int as[] = { decltype(x)::B<C, D>(0) }; // expected-error {{array bound cannot be deduced from an in-class initializer}} |
Richard Smith | 45855df | 2012-05-09 08:23:23 +0000 | [diff] [blame] | 34 | T<sizeof(as) / sizeof(int)> x; |
David Blaikie | cdd91db | 2012-02-14 09:00:46 +0000 | [diff] [blame] | 35 | // test that we handle invalid array bound deductions without crashing when the declarator name is itself invalid |
| 36 | operator int[](){}; // expected-error {{'operator int' cannot be the name of a variable or data member}} \ |
| 37 | // expected-error {{array bound cannot be deduced from an in-class initializer}} |
Richard Smith | 938f40b | 2011-06-11 17:19:42 +0000 | [diff] [blame] | 38 | }; |
| 39 | |
| 40 | struct ThrowCtor { ThrowCtor(int) noexcept(false); }; |
| 41 | struct NoThrowCtor { NoThrowCtor(int) noexcept(true); }; |
| 42 | |
| 43 | struct Throw { ThrowCtor tc = 42; }; |
| 44 | struct NoThrow { NoThrowCtor tc = 42; }; |
| 45 | |
| 46 | static_assert(!noexcept(Throw()), "incorrect exception specification"); |
| 47 | static_assert(noexcept(NoThrow()), "incorrect exception specification"); |
| 48 | |
| 49 | struct CheckExcSpec { |
| 50 | CheckExcSpec() noexcept(true) = default; |
| 51 | int n = 0; |
| 52 | }; |
| 53 | struct CheckExcSpecFail { |
| 54 | CheckExcSpecFail() noexcept(true) = default; // expected-error {{exception specification of explicitly defaulted default constructor does not match the calculated one}} |
| 55 | ThrowCtor tc = 123; |
| 56 | }; |
Richard Smith | 4a4beec | 2011-06-12 11:43:46 +0000 | [diff] [blame] | 57 | |
| 58 | struct TypedefInit { |
| 59 | typedef int A = 0; // expected-error {{illegal initializer}} |
| 60 | }; |
Douglas Gregor | 5ca153f | 2011-09-07 20:36:12 +0000 | [diff] [blame] | 61 | |
| 62 | // PR10578 / <rdar://problem/9877267> |
| 63 | namespace PR10578 { |
| 64 | template<typename T> |
| 65 | struct X { |
| 66 | X() { |
| 67 | T* x = 1; // expected-error{{cannot initialize a variable of type 'int *' with an rvalue of type 'int'}} |
| 68 | } |
| 69 | }; |
| 70 | |
| 71 | struct Y : X<int> { |
| 72 | Y(); |
| 73 | }; |
| 74 | |
| 75 | Y::Y() try { // expected-note{{in instantiation of member function 'PR10578::X<int>::X' requested here}} |
| 76 | } catch(...) { |
| 77 | } |
| 78 | } |
Richard Smith | 27874d6 | 2013-01-08 00:08:23 +0000 | [diff] [blame] | 79 | |
| 80 | namespace PR14838 { |
| 81 | struct base { ~base() {} }; |
| 82 | class function : base { |
| 83 | ~function() {} // expected-note {{implicitly declared private here}} |
| 84 | public: |
| 85 | function(...) {} |
| 86 | }; |
| 87 | struct thing {}; |
| 88 | struct another { |
| 89 | another() : r(thing()) {} |
| 90 | // expected-error@-1 {{temporary of type 'const PR14838::function' has private destructor}} |
| 91 | // expected-warning@-2 {{binding reference member 'r' to a temporary value}} |
| 92 | const function &r; // expected-note {{reference member declared here}} |
| 93 | } af; |
| 94 | } |
Eli Friedman | c9817fd | 2013-06-07 01:48:56 +0000 | [diff] [blame] | 95 | |
| 96 | namespace rdar14084171 { |
| 97 | struct Point { // expected-note 3 {{candidate constructor}} |
| 98 | double x; |
| 99 | double y; |
| 100 | }; |
| 101 | struct Sprite { |
| 102 | Point location = Point(0,0); // expected-error {{no matching constructor for initialization of 'rdar14084171::Point'}} |
| 103 | }; |
| 104 | void f(Sprite& x) { x = x; } |
| 105 | } |
Richard Smith | 7ff2bcb | 2014-01-24 01:54:52 +0000 | [diff] [blame] | 106 | |
| 107 | namespace PR18560 { |
| 108 | struct X { int m; }; |
| 109 | |
| 110 | template<typename T = X, |
| 111 | typename U = decltype(T::m)> |
| 112 | int f(); |
| 113 | |
| 114 | struct Y { int b = f(); }; |
| 115 | } |
Reid Kleckner | d60b82f | 2014-11-17 23:36:45 +0000 | [diff] [blame] | 116 | |
| 117 | namespace template_valid { |
| 118 | // Valid, we shouldn't build a CXXDefaultInitExpr until A's ctor definition. |
| 119 | struct A { |
| 120 | A(); |
| 121 | template <typename T> |
| 122 | struct B { int m1 = sizeof(A) + sizeof(T); }; |
| 123 | B<int> m2; |
| 124 | }; |
| 125 | A::A() {} |
| 126 | } |
| 127 | |
| 128 | namespace template_default_ctor { |
| 129 | struct A { |
| 130 | template <typename T> |
| 131 | struct B { |
| 132 | int m1 = 0; // expected-error {{cannot use defaulted default constructor of 'B' within 'A' outside of member functions because 'm1' has an initializer}} |
| 133 | }; |
| 134 | // expected-note@+1 {{implicit default constructor for 'template_default_ctor::A::B<int>' first required here}} |
| 135 | enum { NOE = noexcept(B<int>()) }; |
| 136 | }; |
| 137 | } |
| 138 | |
| 139 | namespace default_ctor { |
| 140 | struct A { |
| 141 | struct B { |
| 142 | int m1 = 0; // expected-error {{cannot use defaulted default constructor of 'B' within 'A' outside of member functions because 'm1' has an initializer}} |
| 143 | }; |
| 144 | // expected-note@+1 {{implicit default constructor for 'default_ctor::A::B' first required here}} |
| 145 | enum { NOE = noexcept(B()) }; |
| 146 | }; |
| 147 | } |
| 148 | |
| 149 | namespace member_template { |
| 150 | struct A { |
| 151 | template <typename T> |
| 152 | struct B { |
| 153 | struct C { |
| 154 | int m1 = 0; // expected-error {{cannot use defaulted default constructor of 'C' within 'A' outside of member functions because 'm1' has an initializer}} |
| 155 | }; |
| 156 | template <typename U> |
| 157 | struct D { |
| 158 | int m1 = 0; // expected-error {{cannot use defaulted default constructor of 'D' within 'A' outside of member functions because 'm1' has an initializer}} |
| 159 | }; |
| 160 | }; |
| 161 | enum { |
| 162 | // expected-note@+1 {{implicit default constructor for 'member_template::A::B<int>::C' first required here}} |
| 163 | NOE1 = noexcept(B<int>::C()), |
| 164 | // expected-note@+1 {{implicit default constructor for 'member_template::A::B<int>::D<int>' first required here}} |
| 165 | NOE2 = noexcept(B<int>::D<int>()) |
| 166 | }; |
| 167 | }; |
| 168 | } |
| 169 | |
| 170 | namespace explicit_instantiation { |
| 171 | template<typename T> struct X { |
| 172 | X(); // expected-note {{in instantiation of default member initializer 'explicit_instantiation::X<float>::n' requested here}} |
| 173 | int n = T::error; // expected-error {{type 'float' cannot be used prior to '::' because it has no members}} |
| 174 | }; |
| 175 | template struct X<int>; // ok |
| 176 | template<typename T> X<T>::X() {} |
| 177 | template struct X<float>; // expected-note {{in instantiation of member function 'explicit_instantiation::X<float>::X' requested here}} |
| 178 | } |
| 179 | |
| 180 | namespace local_class { |
| 181 | template<typename T> void f() { |
| 182 | struct X { // expected-note {{in instantiation of default member initializer 'local_class::f()::X::n' requested here}} |
| 183 | int n = T::error; // expected-error {{type 'int' cannot be used prior to '::' because it has no members}} |
| 184 | }; |
| 185 | } |
| 186 | void g() { f<int>(); } // expected-note {{in instantiation of function template specialization 'local_class::f<int>' requested here}} |
| 187 | } |
David Majnemer | 4f21768 | 2015-01-09 01:39:09 +0000 | [diff] [blame] | 188 | |
| 189 | namespace PR22056 { |
| 190 | template <int N> |
| 191 | struct S { |
| 192 | int x[3] = {[N] = 3}; |
| 193 | }; |
| 194 | } |