xref: /aosp_15_r20/external/clang/test/SemaCXX/uninitialized.cpp (revision 67e74705e28f6214e480b399dd47ea732279e315)
1*67e74705SXin Li // RUN: %clang_cc1 -fsyntax-only -Wall -Wuninitialized -Wno-unused-value -std=c++11 -verify %s
2*67e74705SXin Li 
3*67e74705SXin Li // definitions for std::move
4*67e74705SXin Li namespace std {
5*67e74705SXin Li inline namespace foo {
6*67e74705SXin Li template <class T> struct remove_reference { typedef T type; };
7*67e74705SXin Li template <class T> struct remove_reference<T&> { typedef T type; };
8*67e74705SXin Li template <class T> struct remove_reference<T&&> { typedef T type; };
9*67e74705SXin Li 
10*67e74705SXin Li template <class T> typename remove_reference<T>::type&& move(T&& t);
11*67e74705SXin Li }
12*67e74705SXin Li }
13*67e74705SXin Li 
14*67e74705SXin Li int foo(int x);
15*67e74705SXin Li int bar(int* x);
16*67e74705SXin Li int boo(int& x);
17*67e74705SXin Li int far(const int& x);
18*67e74705SXin Li int moved(int&& x);
19*67e74705SXin Li int &ref(int x);
20*67e74705SXin Li 
21*67e74705SXin Li // Test self-references within initializers which are guaranteed to be
22*67e74705SXin Li // uninitialized.
23*67e74705SXin Li int a = a; // no-warning: used to signal intended lack of initialization.
24*67e74705SXin Li int b = b + 1; // expected-warning {{variable 'b' is uninitialized when used within its own initialization}}
25*67e74705SXin Li int c = (c + c); // expected-warning 2 {{variable 'c' is uninitialized when used within its own initialization}}
26*67e74705SXin Li int e = static_cast<long>(e) + 1; // expected-warning {{variable 'e' is uninitialized when used within its own initialization}}
27*67e74705SXin Li int f = foo(f); // expected-warning {{variable 'f' is uninitialized when used within its own initialization}}
28*67e74705SXin Li 
29*67e74705SXin Li // Thes don't warn as they don't require the value.
30*67e74705SXin Li int g = sizeof(g);
31*67e74705SXin Li void* ptr = &ptr;
32*67e74705SXin Li int h = bar(&h);
33*67e74705SXin Li int i = boo(i);
34*67e74705SXin Li int j = far(j);
35*67e74705SXin Li int k = __alignof__(k);
36*67e74705SXin Li 
37*67e74705SXin Li int l = k ? l : l;  // expected-warning 2{{variable 'l' is uninitialized when used within its own initialization}}
38*67e74705SXin Li int m = 1 + (k ? m : m);  // expected-warning 2{{variable 'm' is uninitialized when used within its own initialization}}
39*67e74705SXin Li int n = -n;  // expected-warning {{variable 'n' is uninitialized when used within its own initialization}}
40*67e74705SXin Li int o = std::move(o); // expected-warning {{variable 'o' is uninitialized when used within its own initialization}}
41*67e74705SXin Li const int p = std::move(p); // expected-warning {{variable 'p' is uninitialized when used within its own initialization}}
42*67e74705SXin Li int q = moved(std::move(q)); // expected-warning {{variable 'q' is uninitialized when used within its own initialization}}
43*67e74705SXin Li int r = std::move((p ? q : (18, r))); // expected-warning {{variable 'r' is uninitialized when used within its own initialization}}
44*67e74705SXin Li int s = r ?: s; // expected-warning {{variable 's' is uninitialized when used within its own initialization}}
45*67e74705SXin Li int t = t ?: s; // expected-warning {{variable 't' is uninitialized when used within its own initialization}}
46*67e74705SXin Li int u = (foo(u), s); // expected-warning {{variable 'u' is uninitialized when used within its own initialization}}
47*67e74705SXin Li int v = (u += v); // expected-warning {{variable 'v' is uninitialized when used within its own initialization}}
48*67e74705SXin Li int w = (w += 10); // expected-warning {{variable 'w' is uninitialized when used within its own initialization}}
49*67e74705SXin Li int x = x++; // expected-warning {{variable 'x' is uninitialized when used within its own initialization}}
50*67e74705SXin Li int y = ((s ? (y, v) : (77, y))++, sizeof(y)); // expected-warning {{variable 'y' is uninitialized when used within its own initialization}}
51*67e74705SXin Li int z = ++ref(z); // expected-warning {{variable 'z' is uninitialized when used within its own initialization}}
52*67e74705SXin Li int aa = (ref(aa) += 10); // expected-warning {{variable 'aa' is uninitialized when used within its own initialization}}
53*67e74705SXin Li int bb = bb ? x : y; // expected-warning {{variable 'bb' is uninitialized when used within its own initialization}}
54*67e74705SXin Li 
test_stuff()55*67e74705SXin Li void test_stuff () {
56*67e74705SXin Li   int a = a; // no-warning: used to signal intended lack of initialization.
57*67e74705SXin Li   int b = b + 1; // expected-warning {{variable 'b' is uninitialized when used within its own initialization}}
58*67e74705SXin Li   int c = (c + c); // expected-warning {{variable 'c' is uninitialized when used within its own initialization}}
59*67e74705SXin Li   int d = ({ d + d ;}); // expected-warning {{variable 'd' is uninitialized when used within its own initialization}}
60*67e74705SXin Li   int e = static_cast<long>(e) + 1; // expected-warning {{variable 'e' is uninitialized when used within its own initialization}}
61*67e74705SXin Li   int f = foo(f); // expected-warning {{variable 'f' is uninitialized when used within its own initialization}}
62*67e74705SXin Li 
63*67e74705SXin Li   // Thes don't warn as they don't require the value.
64*67e74705SXin Li   int g = sizeof(g);
65*67e74705SXin Li   void* ptr = &ptr;
66*67e74705SXin Li   int h = bar(&h);
67*67e74705SXin Li   int i = boo(i);
68*67e74705SXin Li   int j = far(j);
69*67e74705SXin Li   int k = __alignof__(k);
70*67e74705SXin Li 
71*67e74705SXin Li   int l = k ? l : l;  // expected-warning {{variable 'l' is uninitialized when used within its own initialization}}
72*67e74705SXin Li   int m = 1 + (k ? m : m);  // expected-warning {{'m' is uninitialized when used within its own initialization}}
73*67e74705SXin Li   int n = -n;  // expected-warning {{variable 'n' is uninitialized when used within its own initialization}}
74*67e74705SXin Li   int o = std::move(o);  // expected-warning {{variable 'o' is uninitialized when used within its own initialization}}
75*67e74705SXin Li   const int p = std::move(p);  // expected-warning {{variable 'p' is uninitialized when used within its own initialization}}
76*67e74705SXin Li   int q = moved(std::move(q));  // expected-warning {{variable 'q' is uninitialized when used within its own initialization}}
77*67e74705SXin Li   int r = std::move((p ? q : (18, r))); // expected-warning {{variable 'r' is uninitialized when used within its own initialization}}
78*67e74705SXin Li   int s = r ?: s; // expected-warning {{variable 's' is uninitialized when used within its own initialization}}
79*67e74705SXin Li   int t = t ?: s; // expected-warning {{variable 't' is uninitialized when used within its own initialization}}
80*67e74705SXin Li   int u = (foo(u), s); // expected-warning {{variable 'u' is uninitialized when used within its own initialization}}
81*67e74705SXin Li   int v = (u += v); // expected-warning {{variable 'v' is uninitialized when used within its own initialization}}
82*67e74705SXin Li   int w = (w += 10); // expected-warning {{variable 'w' is uninitialized when used within its own initialization}}
83*67e74705SXin Li   int x = x++; // expected-warning {{variable 'x' is uninitialized when used within its own initialization}}
84*67e74705SXin Li   int y = ((s ? (y, v) : (77, y))++, sizeof(y)); // expected-warning {{variable 'y' is uninitialized when used within its own initialization}}
85*67e74705SXin Li   int z = ++ref(z);                              // expected-warning {{variable 'z' is uninitialized when used within its own initialization}}
86*67e74705SXin Li   int aa = (ref(aa) += 10); // expected-warning {{variable 'aa' is uninitialized when used within its own initialization}}
87*67e74705SXin Li   int bb = bb ? x : y; // expected-warning {{variable 'bb' is uninitialized when used within its own initialization}}
88*67e74705SXin Li 
89*67e74705SXin Li   for (;;) {
90*67e74705SXin Li     int a = a; // no-warning: used to signal intended lack of initialization.
91*67e74705SXin Li     int b = b + 1; // expected-warning {{variable 'b' is uninitialized when used within its own initialization}}
92*67e74705SXin Li     int c = (c + c); // expected-warning {{variable 'c' is uninitialized when used within its own initialization}}
93*67e74705SXin Li     int d = ({ d + d ;}); // expected-warning {{variable 'd' is uninitialized when used within its own initialization}}
94*67e74705SXin Li     int e = static_cast<long>(e) + 1; // expected-warning {{variable 'e' is uninitialized when used within its own initialization}}
95*67e74705SXin Li     int f = foo(f); // expected-warning {{variable 'f' is uninitialized when used within its own initialization}}
96*67e74705SXin Li 
97*67e74705SXin Li     // Thes don't warn as they don't require the value.
98*67e74705SXin Li     int g = sizeof(g);
99*67e74705SXin Li     void* ptr = &ptr;
100*67e74705SXin Li     int h = bar(&h);
101*67e74705SXin Li     int i = boo(i);
102*67e74705SXin Li     int j = far(j);
103*67e74705SXin Li     int k = __alignof__(k);
104*67e74705SXin Li 
105*67e74705SXin Li     int l = k ? l : l;  // expected-warning {{variable 'l' is uninitialized when used within its own initialization}}
106*67e74705SXin Li     int m = 1 + (k ? m : m);  // expected-warning {{'m' is uninitialized when used within its own initialization}}
107*67e74705SXin Li     int n = -n;  // expected-warning {{variable 'n' is uninitialized when used within its own initialization}}
108*67e74705SXin Li     int o = std::move(o);  // expected-warning {{variable 'o' is uninitialized when used within its own initialization}}
109*67e74705SXin Li     const int p = std::move(p);  // expected-warning {{variable 'p' is uninitialized when used within its own initialization}}
110*67e74705SXin Li     int q = moved(std::move(q));  // expected-warning {{variable 'q' is uninitialized when used within its own initialization}}
111*67e74705SXin Li     int r = std::move((p ? q : (18, r))); // expected-warning {{variable 'r' is uninitialized when used within its own initialization}}
112*67e74705SXin Li     int s = r ?: s; // expected-warning {{variable 's' is uninitialized when used within its own initialization}}
113*67e74705SXin Li     int t = t ?: s; // expected-warning {{variable 't' is uninitialized when used within its own initialization}}
114*67e74705SXin Li     int u = (foo(u), s); // expected-warning {{variable 'u' is uninitialized when used within its own initialization}}
115*67e74705SXin Li     int v = (u += v); // expected-warning {{variable 'v' is uninitialized when used within its own initialization}}
116*67e74705SXin Li     int w = (w += 10); // expected-warning {{variable 'w' is uninitialized when used within its own initialization}}
117*67e74705SXin Li     int x = x++; // expected-warning {{variable 'x' is uninitialized when used within its own initialization}}
118*67e74705SXin Li     int y = ((s ? (y, v) : (77, y))++, sizeof(y)); // expected-warning {{variable 'y' is uninitialized when used within its own initialization}}
119*67e74705SXin Li     int z = ++ref(z);                              // expected-warning {{variable 'z' is uninitialized when used within its own initialization}}
120*67e74705SXin Li     int aa = (ref(aa) += 10); // expected-warning {{variable 'aa' is uninitialized when used within its own initialization}}
121*67e74705SXin Li     int bb = bb ? x : y; // expected-warning {{variable 'bb' is uninitialized when used within its own initialization}}
122*67e74705SXin Li 
123*67e74705SXin Li   }
124*67e74705SXin Li }
125*67e74705SXin Li 
test_comma()126*67e74705SXin Li void test_comma() {
127*67e74705SXin Li   int a;  // expected-note {{initialize the variable 'a' to silence this warning}}
128*67e74705SXin Li   int b = (a, a ?: 2);  // expected-warning {{variable 'a' is uninitialized when used here}}
129*67e74705SXin Li   int c = (a, a, b, c);  // expected-warning {{variable 'c' is uninitialized when used within its own initialization}}
130*67e74705SXin Li   int d;  // expected-note {{initialize the variable 'd' to silence this warning}}
131*67e74705SXin Li   int e = (foo(d), e, b); // expected-warning {{variable 'd' is uninitialized when used here}}
132*67e74705SXin Li   int f;  // expected-note {{initialize the variable 'f' to silence this warning}}
133*67e74705SXin Li   f = f + 1, 2;  // expected-warning {{variable 'f' is uninitialized when used here}}
134*67e74705SXin Li   int h;
135*67e74705SXin Li   int g = (h, g, 2);  // no-warning: h, g are evaluated but not used.
136*67e74705SXin Li }
137*67e74705SXin Li 
138*67e74705SXin Li namespace member_ptr {
139*67e74705SXin Li struct A {
140*67e74705SXin Li   int x;
141*67e74705SXin Li   int y;
Amember_ptr::A142*67e74705SXin Li   A(int x) : x{x} {}
143*67e74705SXin Li };
144*67e74705SXin Li 
test_member_ptr()145*67e74705SXin Li void test_member_ptr() {
146*67e74705SXin Li   int A::* px = &A::x;
147*67e74705SXin Li   A a{a.*px}; // expected-warning {{variable 'a' is uninitialized when used within its own initialization}}
148*67e74705SXin Li   A b = b; // expected-warning {{variable 'b' is uninitialized when used within its own initialization}}
149*67e74705SXin Li }
150*67e74705SXin Li }
151*67e74705SXin Li 
152*67e74705SXin Li namespace const_ptr {
153*67e74705SXin Li void foo(int *a);
154*67e74705SXin Li void bar(const int *a);
155*67e74705SXin Li void foobar(const int **a);
156*67e74705SXin Li 
test_const_ptr()157*67e74705SXin Li void test_const_ptr() {
158*67e74705SXin Li   int a;
159*67e74705SXin Li   int b;  // expected-note {{initialize the variable 'b' to silence this warning}}
160*67e74705SXin Li   foo(&a);
161*67e74705SXin Li   bar(&b);
162*67e74705SXin Li   b = a + b; // expected-warning {{variable 'b' is uninitialized when used here}}
163*67e74705SXin Li   int *ptr;  //expected-note {{initialize the variable 'ptr' to silence this warning}}
164*67e74705SXin Li   const int *ptr2;
165*67e74705SXin Li   foo(ptr); // expected-warning {{variable 'ptr' is uninitialized when used here}}
166*67e74705SXin Li   foobar(&ptr2);
167*67e74705SXin Li }
168*67e74705SXin Li }
169*67e74705SXin Li 
170*67e74705SXin Li // Also test similar constructs in a field's initializer.
171*67e74705SXin Li struct S {
172*67e74705SXin Li   int x;
173*67e74705SXin Li   int y;
174*67e74705SXin Li   const int z = 5;
175*67e74705SXin Li   void *ptr;
176*67e74705SXin Li 
SS177*67e74705SXin Li   S(bool (*)[1]) : x(x) {} // expected-warning {{field 'x' is uninitialized when used here}}
SS178*67e74705SXin Li   S(bool (*)[2]) : x(x + 1) {} // expected-warning {{field 'x' is uninitialized when used here}}
SS179*67e74705SXin Li   S(bool (*)[3]) : x(x + x) {} // expected-warning 2{{field 'x' is uninitialized when used here}}
SS180*67e74705SXin Li   S(bool (*)[4]) : x(static_cast<long>(x) + 1) {} // expected-warning {{field 'x' is uninitialized when used here}}
SS181*67e74705SXin Li   S(bool (*)[5]) : x(foo(x)) {} // expected-warning {{field 'x' is uninitialized when used here}}
182*67e74705SXin Li 
183*67e74705SXin Li   // These don't actually require the value of x and so shouldn't warn.
SS184*67e74705SXin Li   S(char (*)[1]) : x(sizeof(x)) {} // rdar://8610363
SS185*67e74705SXin Li   S(char (*)[2]) : ptr(&ptr) {}
SS186*67e74705SXin Li   S(char (*)[3]) : x(bar(&x)) {}
SS187*67e74705SXin Li   S(char (*)[4]) : x(boo(x)) {}
SS188*67e74705SXin Li   S(char (*)[5]) : x(far(x)) {}
SS189*67e74705SXin Li   S(char (*)[6]) : x(__alignof__(x)) {}
190*67e74705SXin Li 
SS191*67e74705SXin Li   S(int (*)[1]) : x(0), y(x ? y : y) {} // expected-warning 2{{field 'y' is uninitialized when used here}}
SS192*67e74705SXin Li   S(int (*)[2]) : x(0), y(1 + (x ? y : y)) {} // expected-warning 2{{field 'y' is uninitialized when used here}}
SS193*67e74705SXin Li   S(int (*)[3]) : x(-x) {} // expected-warning {{field 'x' is uninitialized when used here}}
SS194*67e74705SXin Li   S(int (*)[4]) : x(std::move(x)) {} // expected-warning {{field 'x' is uninitialized when used here}}
SS195*67e74705SXin Li   S(int (*)[5]) : z(std::move(z)) {} // expected-warning {{field 'z' is uninitialized when used here}}
SS196*67e74705SXin Li   S(int (*)[6]) : x(moved(std::move(x))) {} // expected-warning {{field 'x' is uninitialized when used here}}
SS197*67e74705SXin Li   S(int (*)[7]) : x(0), y(std::move((x ? x : (18, y)))) {} // expected-warning {{field 'y' is uninitialized when used here}}
SS198*67e74705SXin Li   S(int (*)[8]) : x(0), y(x ?: y) {} // expected-warning {{field 'y' is uninitialized when used here}}
SS199*67e74705SXin Li   S(int (*)[9]) : x(0), y(y ?: x) {} // expected-warning {{field 'y' is uninitialized when used here}}
SS200*67e74705SXin Li   S(int (*)[10]) : x(0), y((foo(y), x)) {} // expected-warning {{field 'y' is uninitialized when used here}}
SS201*67e74705SXin Li   S(int (*)[11]) : x(0), y(x += y) {} // expected-warning {{field 'y' is uninitialized when used here}}
SS202*67e74705SXin Li   S(int (*)[12]) : x(x += 10) {} // expected-warning {{field 'x' is uninitialized when used here}}
SS203*67e74705SXin Li   S(int (*)[13]) : x(x++) {} // expected-warning {{field 'x' is uninitialized when used here}}
SS204*67e74705SXin Li   S(int (*)[14]) : x(0), y(((x ? (y, x) : (77, y))++, sizeof(y))) {} // expected-warning {{field 'y' is uninitialized when used here}}
SS205*67e74705SXin Li   S(int (*)[15]) : x(++ref(x)) {} // expected-warning {{field 'x' is uninitialized when used here}}
SS206*67e74705SXin Li   S(int (*)[16]) : x((ref(x) += 10)) {} // expected-warning {{field 'x' is uninitialized when used here}}
SS207*67e74705SXin Li   S(int (*)[17]) : x(0), y(y ? x : x) {} // expected-warning {{field 'y' is uninitialized when used here}}
208*67e74705SXin Li };
209*67e74705SXin Li 
210*67e74705SXin Li // Test self-references with record types.
211*67e74705SXin Li class A {
212*67e74705SXin Li   // Non-POD class.
213*67e74705SXin Li   public:
214*67e74705SXin Li     enum count { ONE, TWO, THREE };
215*67e74705SXin Li     int num;
216*67e74705SXin Li     static int count;
get() const217*67e74705SXin Li     int get() const { return num; }
get2()218*67e74705SXin Li     int get2() { return num; }
set(int x)219*67e74705SXin Li     int set(int x) { num = x; return num; }
zero()220*67e74705SXin Li     static int zero() { return 0; }
221*67e74705SXin Li 
A()222*67e74705SXin Li     A() {}
A(A const & a)223*67e74705SXin Li     A(A const &a) {}
A(int x)224*67e74705SXin Li     A(int x) {}
A(int * x)225*67e74705SXin Li     A(int *x) {}
A(A * a)226*67e74705SXin Li     A(A *a) {}
A(A && a)227*67e74705SXin Li     A(A &&a) {}
228*67e74705SXin Li     ~A();
229*67e74705SXin Li     bool operator!();
230*67e74705SXin Li     bool operator!=(const A&);
231*67e74705SXin Li };
232*67e74705SXin Li 
233*67e74705SXin Li bool operator!=(int, const A&);
234*67e74705SXin Li 
getA()235*67e74705SXin Li A getA() { return A(); }
getA(int x)236*67e74705SXin Li A getA(int x) { return A(); }
getA(A * a)237*67e74705SXin Li A getA(A* a) { return A(); }
getA(A a)238*67e74705SXin Li A getA(A a) { return A(); }
moveA(A && a)239*67e74705SXin Li A moveA(A&& a) { return A(); }
const_refA(const A & a)240*67e74705SXin Li A const_refA(const A& a) { return A(); }
241*67e74705SXin Li 
setupA(bool x)242*67e74705SXin Li void setupA(bool x) {
243*67e74705SXin Li   A a1;
244*67e74705SXin Li   a1.set(a1.get());
245*67e74705SXin Li   A a2(a1.get());
246*67e74705SXin Li   A a3(a1);
247*67e74705SXin Li   A a4(&a4);
248*67e74705SXin Li   A a5(a5.zero());
249*67e74705SXin Li   A a6(a6.ONE);
250*67e74705SXin Li   A a7 = getA();
251*67e74705SXin Li   A a8 = getA(a8.TWO);
252*67e74705SXin Li   A a9 = getA(&a9);
253*67e74705SXin Li   A a10(a10.count);
254*67e74705SXin Li 
255*67e74705SXin Li   A a11(a11);  // expected-warning {{variable 'a11' is uninitialized when used within its own initialization}}
256*67e74705SXin Li   A a12(a12.get());  // expected-warning {{variable 'a12' is uninitialized when used within its own initialization}}
257*67e74705SXin Li   A a13(a13.num);  // expected-warning {{variable 'a13' is uninitialized when used within its own initialization}}
258*67e74705SXin Li   A a14 = A(a14);  // expected-warning {{variable 'a14' is uninitialized when used within its own initialization}}
259*67e74705SXin Li   A a15 = getA(a15.num);  // expected-warning {{variable 'a15' is uninitialized when used within its own initialization}}
260*67e74705SXin Li   A a16(&a16.num);  // expected-warning {{variable 'a16' is uninitialized when used within its own initialization}}
261*67e74705SXin Li   A a17(a17.get2());  // expected-warning {{variable 'a17' is uninitialized when used within its own initialization}}
262*67e74705SXin Li   A a18 = x ? a18 : a17;  // expected-warning {{variable 'a18' is uninitialized when used within its own initialization}}
263*67e74705SXin Li   A a19 = getA(x ? a19 : a17);  // expected-warning {{variable 'a19' is uninitialized when used within its own initialization}}
264*67e74705SXin Li   A a20{a20};  // expected-warning {{variable 'a20' is uninitialized when used within its own initialization}}
265*67e74705SXin Li   A a21 = {a21};  // expected-warning {{variable 'a21' is uninitialized when used within its own initialization}}
266*67e74705SXin Li 
267*67e74705SXin Li   // FIXME: Make the local uninitialized warning consistent with the global
268*67e74705SXin Li   // uninitialized checking.
269*67e74705SXin Li   A *a22 = new A(a22->count);  // expected-warning {{variable 'a22' is uninitialized when used within its own initialization}}
270*67e74705SXin Li   A *a23 = new A(a23->ONE);  // expected-warning {{variable 'a23' is uninitialized when used within its own initialization}}
271*67e74705SXin Li   A *a24 = new A(a24->TWO);  // expected-warning {{variable 'a24' is uninitialized when used within its own initialization}}
272*67e74705SXin Li   A *a25 = new A(a25->zero());  // expected-warning {{variable 'a25' is uninitialized when used within its own initialization}}
273*67e74705SXin Li 
274*67e74705SXin Li   A *a26 = new A(a26->get());    // expected-warning {{variable 'a26' is uninitialized when used within its own initialization}}
275*67e74705SXin Li   A *a27 = new A(a27->get2());  // expected-warning {{variable 'a27' is uninitialized when used within its own initialization}}
276*67e74705SXin Li   A *a28 = new A(a28->num);  // expected-warning {{variable 'a28' is uninitialized when used within its own initialization}}
277*67e74705SXin Li 
278*67e74705SXin Li   const A a29(a29);  // expected-warning {{variable 'a29' is uninitialized when used within its own initialization}}
279*67e74705SXin Li   const A a30 = a30;  // expected-warning {{variable 'a30' is uninitialized when used within its own initialization}}
280*67e74705SXin Li 
281*67e74705SXin Li   A a31 = std::move(a31);  // expected-warning {{variable 'a31' is uninitialized when used within its own initialization}}
282*67e74705SXin Li   A a32 = moveA(std::move(a32));  // expected-warning {{variable 'a32' is uninitialized when used within its own initialization}}
283*67e74705SXin Li   A a33 = A(std::move(a33));   // expected-warning {{variable 'a33' is uninitialized when used within its own initialization}}
284*67e74705SXin Li   A a34(std::move(a34));   // expected-warning {{variable 'a34' is uninitialized when used within its own initialization}}
285*67e74705SXin Li   A a35 = std::move(x ? a34 : (37, a35));  // expected-warning {{variable 'a35' is uninitialized when used within its own initialization}}
286*67e74705SXin Li 
287*67e74705SXin Li   A a36 = const_refA(a36);
288*67e74705SXin Li   A a37(const_refA(a37));
289*67e74705SXin Li 
290*67e74705SXin Li   A a38({a38});  // expected-warning {{variable 'a38' is uninitialized when used within its own initialization}}
291*67e74705SXin Li   A a39 = {a39};  // expected-warning {{variable 'a39' is uninitialized when used within its own initialization}}
292*67e74705SXin Li   A a40 = A({a40});  // expected-warning {{variable 'a40' is uninitialized when used within its own initialization}}
293*67e74705SXin Li 
294*67e74705SXin Li   A a41 = !a41;  // expected-warning {{variable 'a41' is uninitialized when used within its own initialization}}
295*67e74705SXin Li   A a42 = !(a42);  // expected-warning {{variable 'a42' is uninitialized when used within its own initialization}}
296*67e74705SXin Li   A a43 = a43 != a42;  // expected-warning {{variable 'a43' is uninitialized when used within its own initialization}}
297*67e74705SXin Li   A a44 = a43 != a44;  // expected-warning {{variable 'a44' is uninitialized when used within its own initialization}}
298*67e74705SXin Li   A a45 = a45 != a45;  // expected-warning 2{{variable 'a45' is uninitialized when used within its own initialization}}
299*67e74705SXin Li   A a46 = 0 != a46;  // expected-warning {{variable 'a46' is uninitialized when used within its own initialization}}
300*67e74705SXin Li 
301*67e74705SXin Li   A a47(a47.set(a47.num));  // expected-warning 2{{variable 'a47' is uninitialized when used within its own initialization}}
302*67e74705SXin Li   A a48(a47.set(a48.num));  // expected-warning {{variable 'a48' is uninitialized when used within its own initialization}}
303*67e74705SXin Li   A a49(a47.set(a48.num));
304*67e74705SXin Li }
305*67e74705SXin Li 
306*67e74705SXin Li bool cond;
307*67e74705SXin Li 
308*67e74705SXin Li A a1;
309*67e74705SXin Li A a2(a1.get());
310*67e74705SXin Li A a3(a1);
311*67e74705SXin Li A a4(&a4);
312*67e74705SXin Li A a5(a5.zero());
313*67e74705SXin Li A a6(a6.ONE);
314*67e74705SXin Li A a7 = getA();
315*67e74705SXin Li A a8 = getA(a8.TWO);
316*67e74705SXin Li A a9 = getA(&a9);
317*67e74705SXin Li A a10(a10.count);
318*67e74705SXin Li 
319*67e74705SXin Li A a11(a11);  // expected-warning {{variable 'a11' is uninitialized when used within its own initialization}}
320*67e74705SXin Li A a12(a12.get());  // expected-warning {{variable 'a12' is uninitialized when used within its own initialization}}
321*67e74705SXin Li A a13(a13.num);  // expected-warning {{variable 'a13' is uninitialized when used within its own initialization}}
322*67e74705SXin Li A a14 = A(a14);  // expected-warning {{variable 'a14' is uninitialized when used within its own initialization}}
323*67e74705SXin Li A a15 = getA(a15.num);  // expected-warning {{variable 'a15' is uninitialized when used within its own initialization}}
324*67e74705SXin Li A a16(&a16.num);  // expected-warning {{variable 'a16' is uninitialized when used within its own initialization}}
325*67e74705SXin Li A a17(a17.get2());  // expected-warning {{variable 'a17' is uninitialized when used within its own initialization}}
326*67e74705SXin Li A a18 = cond ? a18 : a17;  // expected-warning {{variable 'a18' is uninitialized when used within its own initialization}}
327*67e74705SXin Li A a19 = getA(cond ? a19 : a17);  // expected-warning {{variable 'a19' is uninitialized when used within its own initialization}}
328*67e74705SXin Li A a20{a20};  // expected-warning {{variable 'a20' is uninitialized when used within its own initialization}}
329*67e74705SXin Li A a21 = {a21};  // expected-warning {{variable 'a21' is uninitialized when used within its own initialization}}
330*67e74705SXin Li 
331*67e74705SXin Li A *a22 = new A(a22->count);
332*67e74705SXin Li A *a23 = new A(a23->ONE);
333*67e74705SXin Li A *a24 = new A(a24->TWO);
334*67e74705SXin Li A *a25 = new A(a25->zero());
335*67e74705SXin Li 
336*67e74705SXin Li A *a26 = new A(a26->get());    // expected-warning {{variable 'a26' is uninitialized when used within its own initialization}}
337*67e74705SXin Li A *a27 = new A(a27->get2());  // expected-warning {{variable 'a27' is uninitialized when used within its own initialization}}
338*67e74705SXin Li A *a28 = new A(a28->num);  // expected-warning {{variable 'a28' is uninitialized when used within its own initialization}}
339*67e74705SXin Li 
340*67e74705SXin Li const A a29(a29);  // expected-warning {{variable 'a29' is uninitialized when used within its own initialization}}
341*67e74705SXin Li const A a30 = a30;  // expected-warning {{variable 'a30' is uninitialized when used within its own initialization}}
342*67e74705SXin Li 
343*67e74705SXin Li A a31 = std::move(a31);  // expected-warning {{variable 'a31' is uninitialized when used within its own initialization}}
344*67e74705SXin Li A a32 = moveA(std::move(a32));  // expected-warning {{variable 'a32' is uninitialized when used within its own initialization}}
345*67e74705SXin Li A a33 = A(std::move(a33));   // expected-warning {{variable 'a33' is uninitialized when used within its own initialization}}
346*67e74705SXin Li A a34(std::move(a34));   // expected-warning {{variable 'a34' is uninitialized when used within its own initialization}}
347*67e74705SXin Li A a35 = std::move(x ? a34 : (37, a35));  // expected-warning {{variable 'a35' is uninitialized when used within its own initialization}}
348*67e74705SXin Li 
349*67e74705SXin Li A a36 = const_refA(a36);
350*67e74705SXin Li A a37(const_refA(a37));
351*67e74705SXin Li 
352*67e74705SXin Li A a38({a38});  // expected-warning {{variable 'a38' is uninitialized when used within its own initialization}}
353*67e74705SXin Li A a39 = {a39};  // expected-warning {{variable 'a39' is uninitialized when used within its own initialization}}
354*67e74705SXin Li A a40 = A({a40});  // expected-warning {{variable 'a40' is uninitialized when used within its own initialization}}
355*67e74705SXin Li 
356*67e74705SXin Li A a41 = !a41;  // expected-warning {{variable 'a41' is uninitialized when used within its own initialization}}
357*67e74705SXin Li A a42 = !(a42);  // expected-warning {{variable 'a42' is uninitialized when used within its own initialization}}
358*67e74705SXin Li A a43 = a43 != a42;  // expected-warning {{variable 'a43' is uninitialized when used within its own initialization}}
359*67e74705SXin Li A a44 = a43 != a44;  // expected-warning {{variable 'a44' is uninitialized when used within its own initialization}}
360*67e74705SXin Li A a45 = a45 != a45;  // expected-warning 2{{variable 'a45' is uninitialized when used within its own initialization}}
361*67e74705SXin Li 
362*67e74705SXin Li A a46 = 0 != a46;  // expected-warning {{variable 'a46' is uninitialized when used within its own initialization}}
363*67e74705SXin Li 
364*67e74705SXin Li A a47(a47.set(a47.num));  // expected-warning 2{{variable 'a47' is uninitialized when used within its own initialization}}
365*67e74705SXin Li A a48(a47.set(a48.num));  // expected-warning {{variable 'a48' is uninitialized when used within its own initialization}}
366*67e74705SXin Li A a49(a47.set(a48.num));
367*67e74705SXin Li 
368*67e74705SXin Li class T {
369*67e74705SXin Li   A a, a2;
370*67e74705SXin Li   const A c_a;
371*67e74705SXin Li   A* ptr_a;
372*67e74705SXin Li 
T()373*67e74705SXin Li   T() {}
T(bool (*)[1])374*67e74705SXin Li   T(bool (*)[1]) : a() {}
T(bool (*)[2])375*67e74705SXin Li   T(bool (*)[2]) : a2(a.get()) {}
T(bool (*)[3])376*67e74705SXin Li   T(bool (*)[3]) : a2(a) {}
T(bool (*)[4])377*67e74705SXin Li   T(bool (*)[4]) : a(&a) {}
T(bool (*)[5])378*67e74705SXin Li   T(bool (*)[5]) : a(a.zero()) {}
T(bool (*)[6])379*67e74705SXin Li   T(bool (*)[6]) : a(a.ONE) {}
T(bool (*)[7])380*67e74705SXin Li   T(bool (*)[7]) : a(getA()) {}
T(bool (*)[8])381*67e74705SXin Li   T(bool (*)[8]) : a2(getA(a.TWO)) {}
T(bool (*)[9])382*67e74705SXin Li   T(bool (*)[9]) : a(getA(&a)) {}
T(bool (*)[10])383*67e74705SXin Li   T(bool (*)[10]) : a(a.count) {}
384*67e74705SXin Li 
T(bool (*)[11])385*67e74705SXin Li   T(bool (*)[11]) : a(a) {}  // expected-warning {{field 'a' is uninitialized when used here}}
T(bool (*)[12])386*67e74705SXin Li   T(bool (*)[12]) : a(a.get()) {}  // expected-warning {{field 'a' is uninitialized when used here}}
T(bool (*)[13])387*67e74705SXin Li   T(bool (*)[13]) : a(a.num) {}  // expected-warning {{field 'a' is uninitialized when used here}}
T(bool (*)[14])388*67e74705SXin Li   T(bool (*)[14]) : a(A(a)) {}  // expected-warning {{field 'a' is uninitialized when used here}}
T(bool (*)[15])389*67e74705SXin Li   T(bool (*)[15]) : a(getA(a.num)) {}  // expected-warning {{field 'a' is uninitialized when used here}}
T(bool (*)[16])390*67e74705SXin Li   T(bool (*)[16]) : a(&a.num) {}  // expected-warning {{field 'a' is uninitialized when used here}}
T(bool (*)[17])391*67e74705SXin Li   T(bool (*)[17]) : a(a.get2()) {}  // expected-warning {{field 'a' is uninitialized when used here}}
T(bool (*)[18])392*67e74705SXin Li   T(bool (*)[18]) : a2(cond ? a2 : a) {}  // expected-warning {{field 'a2' is uninitialized when used here}}
T(bool (*)[19])393*67e74705SXin Li   T(bool (*)[19]) : a2(cond ? a2 : a) {}  // expected-warning {{field 'a2' is uninitialized when used here}}
T(bool (*)[20])394*67e74705SXin Li   T(bool (*)[20]) : a{a} {}  // expected-warning {{field 'a' is uninitialized when used here}}
T(bool (*)[21])395*67e74705SXin Li   T(bool (*)[21]) : a({a}) {}  // expected-warning {{field 'a' is uninitialized when used here}}
396*67e74705SXin Li 
T(bool (*)[22])397*67e74705SXin Li   T(bool (*)[22]) : ptr_a(new A(ptr_a->count)) {}
T(bool (*)[23])398*67e74705SXin Li   T(bool (*)[23]) : ptr_a(new A(ptr_a->ONE)) {}
T(bool (*)[24])399*67e74705SXin Li   T(bool (*)[24]) : ptr_a(new A(ptr_a->TWO)) {}
T(bool (*)[25])400*67e74705SXin Li   T(bool (*)[25]) : ptr_a(new A(ptr_a->zero())) {}
401*67e74705SXin Li 
T(bool (*)[26])402*67e74705SXin Li   T(bool (*)[26]) : ptr_a(new A(ptr_a->get())) {}  // expected-warning {{field 'ptr_a' is uninitialized when used here}}
T(bool (*)[27])403*67e74705SXin Li   T(bool (*)[27]) : ptr_a(new A(ptr_a->get2())) {}  // expected-warning {{field 'ptr_a' is uninitialized when used here}}
T(bool (*)[28])404*67e74705SXin Li   T(bool (*)[28]) : ptr_a(new A(ptr_a->num)) {}  // expected-warning {{field 'ptr_a' is uninitialized when used here}}
405*67e74705SXin Li 
T(bool (*)[29])406*67e74705SXin Li   T(bool (*)[29]) : c_a(c_a) {}  // expected-warning {{field 'c_a' is uninitialized when used here}}
T(bool (*)[30])407*67e74705SXin Li   T(bool (*)[30]) : c_a(A(c_a)) {}  // expected-warning {{field 'c_a' is uninitialized when used here}}
408*67e74705SXin Li 
T(bool (*)[31])409*67e74705SXin Li   T(bool (*)[31]) : a(std::move(a)) {}  // expected-warning {{field 'a' is uninitialized when used here}}
T(bool (*)[32])410*67e74705SXin Li   T(bool (*)[32]) : a(moveA(std::move(a))) {}  // expected-warning {{field 'a' is uninitialized when used here}}
T(bool (*)[33])411*67e74705SXin Li   T(bool (*)[33]) : a(A(std::move(a))) {}  // expected-warning {{field 'a' is uninitialized when used here}}
T(bool (*)[34])412*67e74705SXin Li   T(bool (*)[34]) : a(A(std::move(a))) {}  // expected-warning {{field 'a' is uninitialized when used here}}
T(bool (*)[35])413*67e74705SXin Li   T(bool (*)[35]) : a2(std::move(x ? a : (37, a2))) {}  // expected-warning {{field 'a2' is uninitialized when used here}}
414*67e74705SXin Li 
T(bool (*)[36])415*67e74705SXin Li   T(bool (*)[36]) : a(const_refA(a)) {}
T(bool (*)[37])416*67e74705SXin Li   T(bool (*)[37]) : a(A(const_refA(a))) {}
417*67e74705SXin Li 
T(bool (*)[38])418*67e74705SXin Li   T(bool (*)[38]) : a({a}) {}  // expected-warning {{field 'a' is uninitialized when used here}}
T(bool (*)[39])419*67e74705SXin Li   T(bool (*)[39]) : a{a} {}  // expected-warning {{field 'a' is uninitialized when used here}}
T(bool (*)[40])420*67e74705SXin Li   T(bool (*)[40]) : a({a}) {}  // expected-warning {{field 'a' is uninitialized when used here}}
421*67e74705SXin Li 
T(bool (*)[41])422*67e74705SXin Li   T(bool (*)[41]) : a(!a) {}  // expected-warning {{field 'a' is uninitialized when used here}}
T(bool (*)[42])423*67e74705SXin Li   T(bool (*)[42]) : a(!(a)) {}  // expected-warning {{field 'a' is uninitialized when used here}}
T(bool (*)[43])424*67e74705SXin Li   T(bool (*)[43]) : a(), a2(a2 != a) {}  // expected-warning {{field 'a2' is uninitialized when used here}}
T(bool (*)[44])425*67e74705SXin Li   T(bool (*)[44]) : a(), a2(a != a2) {}  // expected-warning {{field 'a2' is uninitialized when used here}}
T(bool (*)[45])426*67e74705SXin Li   T(bool (*)[45]) : a(a != a) {}  // expected-warning 2{{field 'a' is uninitialized when used here}}
T(bool (*)[46])427*67e74705SXin Li   T(bool (*)[46]) : a(0 != a) {}  // expected-warning {{field 'a' is uninitialized when used here}}
428*67e74705SXin Li 
T(bool (*)[47])429*67e74705SXin Li   T(bool (*)[47]) : a2(a2.set(a2.num)) {}  // expected-warning 2{{field 'a2' is uninitialized when used here}}
T(bool (*)[48])430*67e74705SXin Li   T(bool (*)[48]) : a2(a.set(a2.num)) {}  // expected-warning {{field 'a2' is uninitialized when used here}}
T(bool (*)[49])431*67e74705SXin Li   T(bool (*)[49]) : a2(a.set(a.num)) {}
432*67e74705SXin Li 
433*67e74705SXin Li };
434*67e74705SXin Li 
435*67e74705SXin Li struct B {
436*67e74705SXin Li   // POD struct.
437*67e74705SXin Li   int x;
438*67e74705SXin Li   int *y;
439*67e74705SXin Li };
440*67e74705SXin Li 
getB()441*67e74705SXin Li B getB() { return B(); };
getB(int x)442*67e74705SXin Li B getB(int x) { return B(); };
getB(int * x)443*67e74705SXin Li B getB(int *x) { return B(); };
getB(B * b)444*67e74705SXin Li B getB(B *b) { return B(); };
moveB(B && b)445*67e74705SXin Li B moveB(B &&b) { return B(); };
446*67e74705SXin Li 
getPtrB()447*67e74705SXin Li B* getPtrB() { return 0; };
getPtrB(int x)448*67e74705SXin Li B* getPtrB(int x) { return 0; };
getPtrB(int * x)449*67e74705SXin Li B* getPtrB(int *x) { return 0; };
getPtrB(B ** b)450*67e74705SXin Li B* getPtrB(B **b) { return 0; };
451*67e74705SXin Li 
setupB(bool x)452*67e74705SXin Li void setupB(bool x) {
453*67e74705SXin Li   B b1;
454*67e74705SXin Li   B b2(b1);
455*67e74705SXin Li   B b3 = { 5, &b3.x };
456*67e74705SXin Li   B b4 = getB();
457*67e74705SXin Li   B b5 = getB(&b5);
458*67e74705SXin Li   B b6 = getB(&b6.x);
459*67e74705SXin Li 
460*67e74705SXin Li   // Silence unused warning
461*67e74705SXin Li   (void) b2;
462*67e74705SXin Li   (void) b4;
463*67e74705SXin Li 
464*67e74705SXin Li   B b7(b7);  // expected-warning {{variable 'b7' is uninitialized when used within its own initialization}}
465*67e74705SXin Li   B b8 = getB(b8.x);  // expected-warning {{variable 'b8' is uninitialized when used within its own initialization}}
466*67e74705SXin Li   B b9 = getB(b9.y);  // expected-warning {{variable 'b9' is uninitialized when used within its own initialization}}
467*67e74705SXin Li   B b10 = getB(-b10.x);  // expected-warning {{variable 'b10' is uninitialized when used within its own initialization}}
468*67e74705SXin Li 
469*67e74705SXin Li   B* b11 = 0;
470*67e74705SXin Li   B* b12(b11);
471*67e74705SXin Li   B* b13 = getPtrB();
472*67e74705SXin Li   B* b14 = getPtrB(&b14);
473*67e74705SXin Li 
474*67e74705SXin Li   (void) b12;
475*67e74705SXin Li   (void) b13;
476*67e74705SXin Li 
477*67e74705SXin Li   B* b15 = getPtrB(b15->x);  // expected-warning {{variable 'b15' is uninitialized when used within its own initialization}}
478*67e74705SXin Li   B* b16 = getPtrB(b16->y);  // expected-warning {{variable 'b16' is uninitialized when used within its own initialization}}
479*67e74705SXin Li 
480*67e74705SXin Li   B b17 = { b17.x = 5, b17.y = 0 };
481*67e74705SXin Li   B b18 = { b18.x + 1, b18.y };  // expected-warning 2{{variable 'b18' is uninitialized when used within its own initialization}}
482*67e74705SXin Li 
483*67e74705SXin Li   const B b19 = b19;  // expected-warning {{variable 'b19' is uninitialized when used within its own initialization}}
484*67e74705SXin Li   const B b20(b20);  // expected-warning {{variable 'b20' is uninitialized when used within its own initialization}}
485*67e74705SXin Li 
486*67e74705SXin Li   B b21 = std::move(b21);  // expected-warning {{variable 'b21' is uninitialized when used within its own initialization}}
487*67e74705SXin Li   B b22 = moveB(std::move(b22));  // expected-warning {{variable 'b22' is uninitialized when used within its own initialization}}
488*67e74705SXin Li   B b23 = B(std::move(b23));   // expected-warning {{variable 'b23' is uninitialized when used within its own initialization}}
489*67e74705SXin Li   B b24 = std::move(x ? b23 : (18, b24));  // expected-warning {{variable 'b24' is uninitialized when used within its own initialization}}
490*67e74705SXin Li }
491*67e74705SXin Li 
492*67e74705SXin Li B b1;
493*67e74705SXin Li B b2(b1);
494*67e74705SXin Li B b3 = { 5, &b3.x };
495*67e74705SXin Li B b4 = getB();
496*67e74705SXin Li B b5 = getB(&b5);
497*67e74705SXin Li B b6 = getB(&b6.x);
498*67e74705SXin Li 
499*67e74705SXin Li B b7(b7);  // expected-warning {{variable 'b7' is uninitialized when used within its own initialization}}
500*67e74705SXin Li B b8 = getB(b8.x);  // expected-warning {{variable 'b8' is uninitialized when used within its own initialization}}
501*67e74705SXin Li B b9 = getB(b9.y);  // expected-warning {{variable 'b9' is uninitialized when used within its own initialization}}
502*67e74705SXin Li B b10 = getB(-b10.x);  // expected-warning {{variable 'b10' is uninitialized when used within its own initialization}}
503*67e74705SXin Li 
504*67e74705SXin Li B* b11 = 0;
505*67e74705SXin Li B* b12(b11);
506*67e74705SXin Li B* b13 = getPtrB();
507*67e74705SXin Li B* b14 = getPtrB(&b14);
508*67e74705SXin Li 
509*67e74705SXin Li B* b15 = getPtrB(b15->x);  // expected-warning {{variable 'b15' is uninitialized when used within its own initialization}}
510*67e74705SXin Li B* b16 = getPtrB(b16->y);  // expected-warning {{variable 'b16' is uninitialized when used within its own initialization}}
511*67e74705SXin Li 
512*67e74705SXin Li B b17 = { b17.x = 5, b17.y = 0 };
513*67e74705SXin Li B b18 = { b18.x + 1, b18.y };  // expected-warning 2{{variable 'b18' is uninitialized when used within its own initialization}}
514*67e74705SXin Li 
515*67e74705SXin Li const B b19 = b19;  // expected-warning {{variable 'b19' is uninitialized when used within its own initialization}}
516*67e74705SXin Li const B b20(b20);  // expected-warning {{variable 'b20' is uninitialized when used within its own initialization}}
517*67e74705SXin Li 
518*67e74705SXin Li B b21 = std::move(b21);  // expected-warning {{variable 'b21' is uninitialized when used within its own initialization}}
519*67e74705SXin Li B b22 = moveB(std::move(b22));  // expected-warning {{variable 'b22' is uninitialized when used within its own initialization}}
520*67e74705SXin Li B b23 = B(std::move(b23));   // expected-warning {{variable 'b23' is uninitialized when used within its own initialization}}
521*67e74705SXin Li B b24 = std::move(x ? b23 : (18, b24));  // expected-warning {{variable 'b24' is uninitialized when used within its own initialization}}
522*67e74705SXin Li 
523*67e74705SXin Li class U {
524*67e74705SXin Li   B b1, b2;
525*67e74705SXin Li   B *ptr1, *ptr2;
526*67e74705SXin Li   const B constb = {};
527*67e74705SXin Li 
U()528*67e74705SXin Li   U() {}
U(bool (*)[1])529*67e74705SXin Li   U(bool (*)[1]) : b1() {}
U(bool (*)[2])530*67e74705SXin Li   U(bool (*)[2]) : b2(b1) {}
U(bool (*)[3])531*67e74705SXin Li   U(bool (*)[3]) : b1{ 5, &b1.x } {}
U(bool (*)[4])532*67e74705SXin Li   U(bool (*)[4]) : b1(getB()) {}
U(bool (*)[5])533*67e74705SXin Li   U(bool (*)[5]) : b1(getB(&b1)) {}
U(bool (*)[6])534*67e74705SXin Li   U(bool (*)[6]) : b1(getB(&b1.x)) {}
535*67e74705SXin Li 
U(bool (*)[7])536*67e74705SXin Li   U(bool (*)[7]) : b1(b1) {}  // expected-warning {{field 'b1' is uninitialized when used here}}
U(bool (*)[8])537*67e74705SXin Li   U(bool (*)[8]) : b1(getB(b1.x)) {}  // expected-warning {{field 'b1' is uninitialized when used here}}
U(bool (*)[9])538*67e74705SXin Li   U(bool (*)[9]) : b1(getB(b1.y)) {}  // expected-warning {{field 'b1' is uninitialized when used here}}
U(bool (*)[10])539*67e74705SXin Li   U(bool (*)[10]) : b1(getB(-b1.x)) {}  // expected-warning {{field 'b1' is uninitialized when used here}}
540*67e74705SXin Li 
U(bool (*)[11])541*67e74705SXin Li   U(bool (*)[11]) : ptr1(0) {}
U(bool (*)[12])542*67e74705SXin Li   U(bool (*)[12]) : ptr1(0), ptr2(ptr1) {}
U(bool (*)[13])543*67e74705SXin Li   U(bool (*)[13]) : ptr1(getPtrB()) {}
U(bool (*)[14])544*67e74705SXin Li   U(bool (*)[14]) : ptr1(getPtrB(&ptr1)) {}
545*67e74705SXin Li 
U(bool (*)[15])546*67e74705SXin Li   U(bool (*)[15]) : ptr1(getPtrB(ptr1->x)) {}  // expected-warning {{field 'ptr1' is uninitialized when used here}}
U(bool (*)[16])547*67e74705SXin Li   U(bool (*)[16]) : ptr2(getPtrB(ptr2->y)) {}  // expected-warning {{field 'ptr2' is uninitialized when used here}}
548*67e74705SXin Li 
U(bool (*)[17])549*67e74705SXin Li   U(bool (*)[17]) : b1 { b1.x = 5, b1.y = 0 } {}
U(bool (*)[18])550*67e74705SXin Li   U(bool (*)[18]) : b1 { b1.x + 1, b1.y } {}  // expected-warning 2{{field 'b1' is uninitialized when used here}}
551*67e74705SXin Li 
U(bool (*)[19])552*67e74705SXin Li   U(bool (*)[19]) : constb(constb) {}  // expected-warning {{field 'constb' is uninitialized when used here}}
U(bool (*)[20])553*67e74705SXin Li   U(bool (*)[20]) : constb(B(constb)) {}  // expected-warning {{field 'constb' is uninitialized when used here}}
554*67e74705SXin Li 
U(bool (*)[21])555*67e74705SXin Li   U(bool (*)[21]) : b1(std::move(b1)) {}  // expected-warning {{field 'b1' is uninitialized when used here}}
U(bool (*)[22])556*67e74705SXin Li   U(bool (*)[22]) : b1(moveB(std::move(b1))) {}  // expected-warning {{field 'b1' is uninitialized when used here}}
U(bool (*)[23])557*67e74705SXin Li   U(bool (*)[23]) : b1(B(std::move(b1))) {}  // expected-warning {{field 'b1' is uninitialized when used here}}
U(bool (*)[24])558*67e74705SXin Li   U(bool (*)[24]) : b2(std::move(x ? b1 : (18, b2))) {}  // expected-warning {{field 'b2' is uninitialized when used here}}
559*67e74705SXin Li };
560*67e74705SXin Li 
561*67e74705SXin Li struct C { char a[100], *e; } car = { .e = car.a };
562*67e74705SXin Li 
563*67e74705SXin Li // <rdar://problem/10398199>
564*67e74705SXin Li namespace rdar10398199 {
~FooBase()565*67e74705SXin Li   class FooBase { protected: ~FooBase() {} };
566*67e74705SXin Li   class Foo : public FooBase {
567*67e74705SXin Li   public:
568*67e74705SXin Li     operator int&() const;
569*67e74705SXin Li   };
570*67e74705SXin Li   void stuff();
571*67e74705SXin Li   template <typename T> class FooImpl : public Foo {
572*67e74705SXin Li     T val;
573*67e74705SXin Li   public:
FooImpl(const T & x)574*67e74705SXin Li     FooImpl(const T &x) : val(x) {}
~FooImpl()575*67e74705SXin Li     ~FooImpl() { stuff(); }
576*67e74705SXin Li   };
577*67e74705SXin Li 
makeFoo(const T & x)578*67e74705SXin Li   template <typename T> FooImpl<T> makeFoo(const T& x) {
579*67e74705SXin Li     return FooImpl<T>(x);
580*67e74705SXin Li   }
581*67e74705SXin Li 
test()582*67e74705SXin Li   void test() {
583*67e74705SXin Li     const Foo &x = makeFoo(42);
584*67e74705SXin Li     const int&y = makeFoo(42u);
585*67e74705SXin Li     (void)x;
586*67e74705SXin Li     (void)y;
587*67e74705SXin Li   };
588*67e74705SXin Li }
589*67e74705SXin Li 
590*67e74705SXin Li // PR 12325 - this was a false uninitialized value warning due to
591*67e74705SXin Li // a broken CFG.
pr12325(int params)592*67e74705SXin Li int pr12325(int params) {
593*67e74705SXin Li   int x = ({
594*67e74705SXin Li     while (false)
595*67e74705SXin Li       ;
596*67e74705SXin Li     int _v = params;
597*67e74705SXin Li     if (false)
598*67e74705SXin Li       ;
599*67e74705SXin Li     _v; // no-warning
600*67e74705SXin Li   });
601*67e74705SXin Li   return x;
602*67e74705SXin Li }
603*67e74705SXin Li 
604*67e74705SXin Li // Test lambda expressions with -Wuninitialized
test_lambda()605*67e74705SXin Li int test_lambda() {
606*67e74705SXin Li   auto f1 = [] (int x, int y) { int z; return x + y + z; }; // expected-warning{{variable 'z' is uninitialized when used here}} expected-note {{initialize the variable 'z' to silence this warning}}
607*67e74705SXin Li   return f1(1, 2);
608*67e74705SXin Li }
609*67e74705SXin Li 
610*67e74705SXin Li namespace {
611*67e74705SXin Li   struct A {
612*67e74705SXin Li     enum { A1 };
A2__anone7b83c5c0211::A613*67e74705SXin Li     static int A2() {return 5;}
614*67e74705SXin Li     int A3;
A4__anone7b83c5c0211::A615*67e74705SXin Li     int A4() { return 5;}
616*67e74705SXin Li   };
617*67e74705SXin Li 
618*67e74705SXin Li   struct B {
619*67e74705SXin Li     A a;
620*67e74705SXin Li   };
621*67e74705SXin Li 
622*67e74705SXin Li   struct C {
C__anone7b83c5c0211::C623*67e74705SXin Li     C() {}
C__anone7b83c5c0211::C624*67e74705SXin Li     C(int x) {}
625*67e74705SXin Li     static A a;
626*67e74705SXin Li     B b;
627*67e74705SXin Li   };
628*67e74705SXin Li   A C::a = A();
629*67e74705SXin Li 
630*67e74705SXin Li   // Accessing non-static members will give a warning.
631*67e74705SXin Li   struct D {
632*67e74705SXin Li     C c;
D__anone7b83c5c0211::D633*67e74705SXin Li     D(char (*)[1]) : c(c.b.a.A1) {}
D__anone7b83c5c0211::D634*67e74705SXin Li     D(char (*)[2]) : c(c.b.a.A2()) {}
D__anone7b83c5c0211::D635*67e74705SXin Li     D(char (*)[3]) : c(c.b.a.A3) {}    // expected-warning {{field 'c' is uninitialized when used here}}
D__anone7b83c5c0211::D636*67e74705SXin Li     D(char (*)[4]) : c(c.b.a.A4()) {}  // expected-warning {{field 'c' is uninitialized when used here}}
637*67e74705SXin Li 
638*67e74705SXin Li     // c::a is static, so it is already initialized
D__anone7b83c5c0211::D639*67e74705SXin Li     D(char (*)[5]) : c(c.a.A1) {}
D__anone7b83c5c0211::D640*67e74705SXin Li     D(char (*)[6]) : c(c.a.A2()) {}
D__anone7b83c5c0211::D641*67e74705SXin Li     D(char (*)[7]) : c(c.a.A3) {}
D__anone7b83c5c0211::D642*67e74705SXin Li     D(char (*)[8]) : c(c.a.A4()) {}
643*67e74705SXin Li   };
644*67e74705SXin Li 
645*67e74705SXin Li   struct E {
646*67e74705SXin Li     int b = 1;
647*67e74705SXin Li     int c = 1;
648*67e74705SXin Li     int a;  // This field needs to be last to prevent the cross field
649*67e74705SXin Li             // uninitialized warning.
E__anone7b83c5c0211::E650*67e74705SXin Li     E(char (*)[1]) : a(a ? b : c) {}  // expected-warning {{field 'a' is uninitialized when used here}}
E__anone7b83c5c0211::E651*67e74705SXin Li     E(char (*)[2]) : a(b ? a : a) {} // expected-warning 2{{field 'a' is uninitialized when used here}}
E__anone7b83c5c0211::E652*67e74705SXin Li     E(char (*)[3]) : a(b ? (a) : c) {} // expected-warning {{field 'a' is uninitialized when used here}}
E__anone7b83c5c0211::E653*67e74705SXin Li     E(char (*)[4]) : a(b ? c : (a+c)) {} // expected-warning {{field 'a' is uninitialized when used here}}
E__anone7b83c5c0211::E654*67e74705SXin Li     E(char (*)[5]) : a(b ? c : b) {}
655*67e74705SXin Li 
E__anone7b83c5c0211::E656*67e74705SXin Li     E(char (*)[6]) : a(a ?: a) {} // expected-warning 2{{field 'a' is uninitialized when used here}}
E__anone7b83c5c0211::E657*67e74705SXin Li     E(char (*)[7]) : a(b ?: a) {} // expected-warning {{field 'a' is uninitialized when used here}}
E__anone7b83c5c0211::E658*67e74705SXin Li     E(char (*)[8]) : a(a ?: c) {} // expected-warning {{field 'a' is uninitialized when used here}}
E__anone7b83c5c0211::E659*67e74705SXin Li     E(char (*)[9]) : a(b ?: c) {}
660*67e74705SXin Li 
E__anone7b83c5c0211::E661*67e74705SXin Li     E(char (*)[10]) : a((a, a, b)) {}
E__anone7b83c5c0211::E662*67e74705SXin Li     E(char (*)[11]) : a((c + a, a + 1, b)) {} // expected-warning 2{{field 'a' is uninitialized when used here}}
E__anone7b83c5c0211::E663*67e74705SXin Li     E(char (*)[12]) : a((b + c, c, a)) {} // expected-warning {{field 'a' is uninitialized when used here}}
E__anone7b83c5c0211::E664*67e74705SXin Li     E(char (*)[13]) : a((a, a, a, a)) {} // expected-warning {{field 'a' is uninitialized when used here}}
E__anone7b83c5c0211::E665*67e74705SXin Li     E(char (*)[14]) : a((b, c, c)) {}
E__anone7b83c5c0211::E666*67e74705SXin Li     E(char (*)[15]) : a(b ?: a) {} // expected-warning {{field 'a' is uninitialized when used here}}
E__anone7b83c5c0211::E667*67e74705SXin Li     E(char (*)[16]) : a(a ?: b) {} // expected-warning {{field 'a' is uninitialized when used here}}
668*67e74705SXin Li   };
669*67e74705SXin Li 
670*67e74705SXin Li   struct F {
671*67e74705SXin Li     int a;
672*67e74705SXin Li     F* f;
F__anone7b83c5c0211::F673*67e74705SXin Li     F(int) {}
F__anone7b83c5c0211::F674*67e74705SXin Li     F() {}
675*67e74705SXin Li   };
676*67e74705SXin Li 
677*67e74705SXin Li   int F::*ptr = &F::a;
678*67e74705SXin Li   F* F::*f_ptr = &F::f;
679*67e74705SXin Li   struct G {
680*67e74705SXin Li     F f1, f2;
681*67e74705SXin Li     F *f3, *f4;
G__anone7b83c5c0211::G682*67e74705SXin Li     G(char (*)[1]) : f1(f1) {} // expected-warning {{field 'f1' is uninitialized when used here}}
G__anone7b83c5c0211::G683*67e74705SXin Li     G(char (*)[2]) : f2(f1) {}
G__anone7b83c5c0211::G684*67e74705SXin Li     G(char (*)[3]) : f2(F()) {}
685*67e74705SXin Li 
G__anone7b83c5c0211::G686*67e74705SXin Li     G(char (*)[4]) : f1(f1.*ptr) {} // expected-warning {{field 'f1' is uninitialized when used here}}
G__anone7b83c5c0211::G687*67e74705SXin Li     G(char (*)[5]) : f2(f1.*ptr) {}
688*67e74705SXin Li 
G__anone7b83c5c0211::G689*67e74705SXin Li     G(char (*)[6]) : f3(f3) {}  // expected-warning {{field 'f3' is uninitialized when used here}}
G__anone7b83c5c0211::G690*67e74705SXin Li     G(char (*)[7]) : f3(f3->*f_ptr) {} // expected-warning {{field 'f3' is uninitialized when used here}}
G__anone7b83c5c0211::G691*67e74705SXin Li     G(char (*)[8]) : f3(new F(f3->*ptr)) {} // expected-warning {{field 'f3' is uninitialized when used here}}
692*67e74705SXin Li   };
693*67e74705SXin Li 
694*67e74705SXin Li   struct H {
H__anone7b83c5c0211::H695*67e74705SXin Li     H() : a(a) {}  // expected-warning {{field 'a' is uninitialized when used here}}
696*67e74705SXin Li     const A a;
697*67e74705SXin Li   };
698*67e74705SXin Li }
699*67e74705SXin Li 
700*67e74705SXin Li namespace statics {
701*67e74705SXin Li   static int a = a; // no-warning: used to signal intended lack of initialization.
702*67e74705SXin Li   static int b = b + 1; // expected-warning {{variable 'b' is uninitialized when used within its own initialization}}
703*67e74705SXin Li   static int c = (c + c); // expected-warning 2{{variable 'c' is uninitialized when used within its own initialization}}
704*67e74705SXin Li   static int e = static_cast<long>(e) + 1; // expected-warning {{variable 'e' is uninitialized when used within its own initialization}}
705*67e74705SXin Li   static int f = foo(f); // expected-warning {{variable 'f' is uninitialized when used within its own initialization}}
706*67e74705SXin Li 
707*67e74705SXin Li   // Thes don't warn as they don't require the value.
708*67e74705SXin Li   static int g = sizeof(g);
709*67e74705SXin Li   int gg = g;  // Silence unneeded warning
710*67e74705SXin Li   static void* ptr = &ptr;
711*67e74705SXin Li   static int h = bar(&h);
712*67e74705SXin Li   static int i = boo(i);
713*67e74705SXin Li   static int j = far(j);
714*67e74705SXin Li   static int k = __alignof__(k);
715*67e74705SXin Li 
716*67e74705SXin Li   static int l = k ? l : l;  // expected-warning 2{{variable 'l' is uninitialized when used within its own initialization}}
717*67e74705SXin Li   static int m = 1 + (k ? m : m);  // expected-warning 2{{variable 'm' is uninitialized when used within its own initialization}}
718*67e74705SXin Li   static int n = -n;  // expected-warning {{variable 'n' is uninitialized when used within its own initialization}}
719*67e74705SXin Li   static int o = std::move(o); // expected-warning {{variable 'o' is uninitialized when used within its own initialization}}
720*67e74705SXin Li   static const int p = std::move(p); // expected-warning {{variable 'p' is uninitialized when used within its own initialization}}
721*67e74705SXin Li   static int q = moved(std::move(q)); // expected-warning {{variable 'q' is uninitialized when used within its own initialization}}
722*67e74705SXin Li   static int r = std::move((p ? q : (18, r))); // expected-warning {{variable 'r' is uninitialized when used within its own initialization}}
723*67e74705SXin Li   static int s = r ?: s; // expected-warning {{variable 's' is uninitialized when used within its own initialization}}
724*67e74705SXin Li   static int t = t ?: s; // expected-warning {{variable 't' is uninitialized when used within its own initialization}}
725*67e74705SXin Li   static int u = (foo(u), s); // expected-warning {{variable 'u' is uninitialized when used within its own initialization}}
726*67e74705SXin Li   static int v = (u += v); // expected-warning {{variable 'v' is uninitialized when used within its own initialization}}
727*67e74705SXin Li   static int w = (w += 10); // expected-warning {{variable 'w' is uninitialized when used within its own initialization}}
728*67e74705SXin Li   static int x = x++; // expected-warning {{variable 'x' is uninitialized when used within its own initialization}}
729*67e74705SXin Li   static int y = ((s ? (y, v) : (77, y))++, sizeof(y)); // expected-warning {{variable 'y' is uninitialized when used within its own initialization}}
730*67e74705SXin Li   static int z = ++ref(z); // expected-warning {{variable 'z' is uninitialized when used within its own initialization}}
731*67e74705SXin Li   static int aa = (ref(aa) += 10); // expected-warning {{variable 'aa' is uninitialized when used within its own initialization}}
732*67e74705SXin Li   static int bb = bb ? x : y; // expected-warning {{variable 'bb' is uninitialized when used within its own initialization}}
733*67e74705SXin Li 
734*67e74705SXin Li 
test()735*67e74705SXin Li   void test() {
736*67e74705SXin Li     static int a = a; // no-warning: used to signal intended lack of initialization.
737*67e74705SXin Li     static int b = b + 1; // expected-warning {{static variable 'b' is suspiciously used within its own initialization}}
738*67e74705SXin Li     static int c = (c + c); // expected-warning 2{{static variable 'c' is suspiciously used within its own initialization}}
739*67e74705SXin Li     static int d = ({ d + d ;}); // expected-warning 2{{static variable 'd' is suspiciously used within its own initialization}}
740*67e74705SXin Li     static int e = static_cast<long>(e) + 1; // expected-warning {{static variable 'e' is suspiciously used within its own initialization}}
741*67e74705SXin Li     static int f = foo(f); // expected-warning {{static variable 'f' is suspiciously used within its own initialization}}
742*67e74705SXin Li 
743*67e74705SXin Li     // Thes don't warn as they don't require the value.
744*67e74705SXin Li     static int g = sizeof(g);
745*67e74705SXin Li     static void* ptr = &ptr;
746*67e74705SXin Li     static int h = bar(&h);
747*67e74705SXin Li     static int i = boo(i);
748*67e74705SXin Li     static int j = far(j);
749*67e74705SXin Li     static int k = __alignof__(k);
750*67e74705SXin Li 
751*67e74705SXin Li     static int l = k ? l : l;  // expected-warning 2{{static variable 'l' is suspiciously used within its own initialization}}
752*67e74705SXin Li     static int m = 1 + (k ? m : m);  // expected-warning 2{{static variable 'm' is suspiciously used within its own initialization}}
753*67e74705SXin Li     static int n = -n;  // expected-warning {{static variable 'n' is suspiciously used within its own initialization}}
754*67e74705SXin Li     static int o = std::move(o);  // expected-warning {{static variable 'o' is suspiciously used within its own initialization}}
755*67e74705SXin Li     static const int p = std::move(p);  // expected-warning {{static variable 'p' is suspiciously used within its own initialization}}
756*67e74705SXin Li     static int q = moved(std::move(q));  // expected-warning {{static variable 'q' is suspiciously used within its own initialization}}
757*67e74705SXin Li     static int r = std::move((p ? q : (18, r)));  // expected-warning {{static variable 'r' is suspiciously used within its own initialization}}
758*67e74705SXin Li     static int s = r ?: s;  // expected-warning {{static variable 's' is suspiciously used within its own initialization}}
759*67e74705SXin Li     static int t = t ?: s;  // expected-warning {{static variable 't' is suspiciously used within its own initialization}}
760*67e74705SXin Li     static int u = (foo(u), s);  // expected-warning {{static variable 'u' is suspiciously used within its own initialization}}
761*67e74705SXin Li     static int v = (u += v);  // expected-warning {{static variable 'v' is suspiciously used within its own initialization}}
762*67e74705SXin Li     static int w = (w += 10);  // expected-warning {{static variable 'w' is suspiciously used within its own initialization}}
763*67e74705SXin Li     static int x = x++;  // expected-warning {{static variable 'x' is suspiciously used within its own initialization}}
764*67e74705SXin Li     static int y = ((s ? (y, v) : (77, y))++, sizeof(y));  // expected-warning {{static variable 'y' is suspiciously used within its own initialization}}
765*67e74705SXin Li     static int z = ++ref(z); // expected-warning {{static variable 'z' is suspiciously used within its own initialization}}
766*67e74705SXin Li     static int aa = (ref(aa) += 10); // expected-warning {{static variable 'aa' is suspiciously used within its own initialization}}
767*67e74705SXin Li     static int bb = bb ? x : y; // expected-warning {{static variable 'bb' is suspiciously used within its own initialization}}
768*67e74705SXin Li 
769*67e74705SXin Li     for (;;) {
770*67e74705SXin Li       static int a = a; // no-warning: used to signal intended lack of initialization.
771*67e74705SXin Li       static int b = b + 1; // expected-warning {{static variable 'b' is suspiciously used within its own initialization}}
772*67e74705SXin Li       static int c = (c + c); // expected-warning 2{{static variable 'c' is suspiciously used within its own initialization}}
773*67e74705SXin Li       static int d = ({ d + d ;}); // expected-warning 2{{static variable 'd' is suspiciously used within its own initialization}}
774*67e74705SXin Li       static int e = static_cast<long>(e) + 1; // expected-warning {{static variable 'e' is suspiciously used within its own initialization}}
775*67e74705SXin Li       static int f = foo(f); // expected-warning {{static variable 'f' is suspiciously used within its own initialization}}
776*67e74705SXin Li 
777*67e74705SXin Li       // Thes don't warn as they don't require the value.
778*67e74705SXin Li       static int g = sizeof(g);
779*67e74705SXin Li       static void* ptr = &ptr;
780*67e74705SXin Li       static int h = bar(&h);
781*67e74705SXin Li       static int i = boo(i);
782*67e74705SXin Li       static int j = far(j);
783*67e74705SXin Li       static int k = __alignof__(k);
784*67e74705SXin Li 
785*67e74705SXin Li       static int l = k ? l : l;  // expected-warning 2{{static variable 'l' is suspiciously used within its own initialization}}
786*67e74705SXin Li       static int m = 1 + (k ? m : m); // expected-warning 2{{static variable 'm' is suspiciously used within its own initialization}}
787*67e74705SXin Li       static int n = -n;  // expected-warning {{static variable 'n' is suspiciously used within its own initialization}}
788*67e74705SXin Li       static int o = std::move(o);  // expected-warning {{static variable 'o' is suspiciously used within its own initialization}}
789*67e74705SXin Li       static const int p = std::move(p);  // expected-warning {{static variable 'p' is suspiciously used within its own initialization}}
790*67e74705SXin Li       static int q = moved(std::move(q));  // expected-warning {{static variable 'q' is suspiciously used within its own initialization}}
791*67e74705SXin Li       static int r = std::move((p ? q : (18, r)));  // expected-warning {{static variable 'r' is suspiciously used within its own initialization}}
792*67e74705SXin Li       static int s = r ?: s;  // expected-warning {{static variable 's' is suspiciously used within its own initialization}}
793*67e74705SXin Li       static int t = t ?: s;  // expected-warning {{static variable 't' is suspiciously used within its own initialization}}
794*67e74705SXin Li       static int u = (foo(u), s);  // expected-warning {{static variable 'u' is suspiciously used within its own initialization}}
795*67e74705SXin Li       static int v = (u += v);  // expected-warning {{static variable 'v' is suspiciously used within its own initialization}}
796*67e74705SXin Li       static int w = (w += 10);  // expected-warning {{static variable 'w' is suspiciously used within its own initialization}}
797*67e74705SXin Li       static int x = x++;  // expected-warning {{static variable 'x' is suspiciously used within its own initialization}}
798*67e74705SXin Li       static int y = ((s ? (y, v) : (77, y))++, sizeof(y));  // expected-warning {{static variable 'y' is suspiciously used within its own initialization}}
799*67e74705SXin Li       static int z = ++ref(z); // expected-warning {{static variable 'z' is suspiciously used within its own initialization}}
800*67e74705SXin Li       static int aa = (ref(aa) += 10); // expected-warning {{static variable 'aa' is suspiciously used within its own initialization}}
801*67e74705SXin Li       static int bb = bb ? x : y; // expected-warning {{static variable 'bb' is suspiciously used within its own initialization}}
802*67e74705SXin Li     }
803*67e74705SXin Li   }
804*67e74705SXin Li }
805*67e74705SXin Li 
806*67e74705SXin Li namespace in_class_initializers {
807*67e74705SXin Li   struct S {
Sin_class_initializers::S808*67e74705SXin Li     S() : a(a + 1) {} // expected-warning{{field 'a' is uninitialized when used here}}
809*67e74705SXin Li     int a = 42; // Note: because a is in a member initializer list, this initialization is ignored.
810*67e74705SXin Li   };
811*67e74705SXin Li 
812*67e74705SXin Li   struct T {
Tin_class_initializers::T813*67e74705SXin Li     T() : b(a + 1) {} // No-warning.
814*67e74705SXin Li     int a = 42;
815*67e74705SXin Li     int b;
816*67e74705SXin Li   };
817*67e74705SXin Li 
818*67e74705SXin Li   struct U {
Uin_class_initializers::U819*67e74705SXin Li     U() : a(b + 1), b(a + 1) {} // expected-warning{{field 'b' is uninitialized when used here}}
820*67e74705SXin Li     int a = 42; // Note: because a and b are in the member initializer list, these initializers are ignored.
821*67e74705SXin Li     int b = 1;
822*67e74705SXin Li   };
823*67e74705SXin Li }
824*67e74705SXin Li 
825*67e74705SXin Li namespace references {
826*67e74705SXin Li   int &a = a; // expected-warning{{reference 'a' is not yet bound to a value when used within its own initialization}}
827*67e74705SXin Li   int &b(b); // expected-warning{{reference 'b' is not yet bound to a value when used within its own initialization}}
828*67e74705SXin Li   int &c = a ? b : c; // expected-warning{{reference 'c' is not yet bound to a value when used within its own initialization}}
829*67e74705SXin Li   int &d{d}; // expected-warning{{reference 'd' is not yet bound to a value when used within its own initialization}}
830*67e74705SXin Li   int &e = d ?: e; // expected-warning{{reference 'e' is not yet bound to a value when used within its own initialization}}
831*67e74705SXin Li   int &f = f ?: d; // expected-warning{{reference 'f' is not yet bound to a value when used within its own initialization}}
832*67e74705SXin Li 
833*67e74705SXin Li   int &return_ref1(int);
834*67e74705SXin Li   int &return_ref2(int&);
835*67e74705SXin Li 
836*67e74705SXin Li   int &g = return_ref1(g); // expected-warning{{reference 'g' is not yet bound to a value when used within its own initialization}}
837*67e74705SXin Li   int &h = return_ref2(h); // expected-warning{{reference 'h' is not yet bound to a value when used within its own initialization}}
838*67e74705SXin Li 
839*67e74705SXin Li   struct S {
Sreferences::S840*67e74705SXin Li     S() : a(a) {} // expected-warning{{reference 'a' is not yet bound to a value when used here}}
841*67e74705SXin Li     int &a;
842*67e74705SXin Li   };
843*67e74705SXin Li 
test()844*67e74705SXin Li   void test() {
845*67e74705SXin Li     int &a = a; // expected-warning{{reference 'a' is not yet bound to a value when used within its own initialization}}
846*67e74705SXin Li     int &b(b); // expected-warning{{reference 'b' is not yet bound to a value when used within its own initialization}}
847*67e74705SXin Li     int &c = a ? b : c; // expected-warning{{reference 'c' is not yet bound to a value when used within its own initialization}}
848*67e74705SXin Li     int &d{d}; // expected-warning{{reference 'd' is not yet bound to a value when used within its own initialization}}
849*67e74705SXin Li   }
850*67e74705SXin Li 
851*67e74705SXin Li   struct T {
Treferences::T852*67e74705SXin Li     T() // expected-note{{during field initialization in this constructor}}
853*67e74705SXin Li      : a(b), b(a) {} // expected-warning{{reference 'b' is not yet bound to a value when used here}}
854*67e74705SXin Li     int &a, &b;
855*67e74705SXin Li     int &c = c; // expected-warning{{reference 'c' is not yet bound to a value when used here}}
856*67e74705SXin Li   };
857*67e74705SXin Li 
858*67e74705SXin Li   int x;
859*67e74705SXin Li   struct U {
Ureferences::U860*67e74705SXin Li     U() : b(a) {} // No-warning.
861*67e74705SXin Li     int &a = x;
862*67e74705SXin Li     int &b;
863*67e74705SXin Li   };
864*67e74705SXin Li }
865*67e74705SXin Li 
866*67e74705SXin Li namespace operators {
867*67e74705SXin Li   struct A {
868*67e74705SXin Li     A(bool);
869*67e74705SXin Li     bool operator==(A);
870*67e74705SXin Li   };
871*67e74705SXin Li 
872*67e74705SXin Li   A makeA();
873*67e74705SXin Li 
874*67e74705SXin Li   A a1 = a1 = makeA();  // expected-warning{{variable 'a1' is uninitialized when used within its own initialization}}
875*67e74705SXin Li   A a2 = a2 == a1;  // expected-warning{{variable 'a2' is uninitialized when used within its own initialization}}
876*67e74705SXin Li   A a3 = a2 == a3;  // expected-warning{{variable 'a3' is uninitialized when used within its own initialization}}
877*67e74705SXin Li 
878*67e74705SXin Li   int x = x = 5;
879*67e74705SXin Li }
880*67e74705SXin Li 
881*67e74705SXin Li namespace lambdas {
882*67e74705SXin Li   struct A {
Alambdas::A883*67e74705SXin Li     template<typename T> A(T) {}
884*67e74705SXin Li     int x;
885*67e74705SXin Li   };
__anone7b83c5c0402null886*67e74705SXin Li   A a0([] { return a0.x; }); // ok
f()887*67e74705SXin Li   void f() {
888*67e74705SXin Li     A a1([=] { return a1.x; }); // expected-warning{{variable 'a1' is uninitialized when used within its own initialization}}
889*67e74705SXin Li     A a2([&] { return a2.x; }); // ok
890*67e74705SXin Li   }
891*67e74705SXin Li }
892*67e74705SXin Li 
893*67e74705SXin Li namespace record_fields {
894*67e74705SXin Li   bool x;
895*67e74705SXin Li   struct A {
Arecord_fields::A896*67e74705SXin Li     A() {}
897*67e74705SXin Li     A get();
898*67e74705SXin Li     static A num();
899*67e74705SXin Li     static A copy(A);
900*67e74705SXin Li     static A something(A&);
901*67e74705SXin Li   };
902*67e74705SXin Li 
903*67e74705SXin Li   A ref(A&);
904*67e74705SXin Li   A const_ref(const A&);
905*67e74705SXin Li   A pointer(A*);
906*67e74705SXin Li   A normal(A);
907*67e74705SXin Li   A rref(A&&);
908*67e74705SXin Li 
909*67e74705SXin Li   struct B {
910*67e74705SXin Li     A a;
Brecord_fields::B911*67e74705SXin Li     B(char (*)[1]) : a(a) {}  // expected-warning {{uninitialized}}
Brecord_fields::B912*67e74705SXin Li     B(char (*)[2]) : a(a.get()) {}  // expected-warning {{uninitialized}}
Brecord_fields::B913*67e74705SXin Li     B(char (*)[3]) : a(a.num()) {}
Brecord_fields::B914*67e74705SXin Li     B(char (*)[4]) : a(a.copy(a)) {}  // expected-warning {{uninitialized}}
Brecord_fields::B915*67e74705SXin Li     B(char (*)[5]) : a(a.something(a)) {}
Brecord_fields::B916*67e74705SXin Li     B(char (*)[6]) : a(ref(a)) {}
Brecord_fields::B917*67e74705SXin Li     B(char (*)[7]) : a(const_ref(a)) {}
Brecord_fields::B918*67e74705SXin Li     B(char (*)[8]) : a(pointer(&a)) {}
Brecord_fields::B919*67e74705SXin Li     B(char (*)[9]) : a(normal(a)) {}  // expected-warning {{uninitialized}}
Brecord_fields::B920*67e74705SXin Li     B(char (*)[10]) : a(std::move(a)) {}  // expected-warning {{uninitialized}}
Brecord_fields::B921*67e74705SXin Li     B(char (*)[11]) : a(A(std::move(a))) {}  // expected-warning {{uninitialized}}
Brecord_fields::B922*67e74705SXin Li     B(char (*)[12]) : a(rref(std::move(a))) {}  // expected-warning {{uninitialized}}
Brecord_fields::B923*67e74705SXin Li     B(char (*)[13]) : a(std::move(x ? a : (25, a))) {}  // expected-warning 2{{uninitialized}}
924*67e74705SXin Li   };
925*67e74705SXin Li   struct C {
Crecord_fields::C926*67e74705SXin Li     C() {} // expected-note9{{in this constructor}}
927*67e74705SXin Li     A a1 = a1;  // expected-warning {{uninitialized}}
928*67e74705SXin Li     A a2 = a2.get();  // expected-warning {{uninitialized}}
929*67e74705SXin Li     A a3 = a3.num();
930*67e74705SXin Li     A a4 = a4.copy(a4);  // expected-warning {{uninitialized}}
931*67e74705SXin Li     A a5 = a5.something(a5);
932*67e74705SXin Li     A a6 = ref(a6);
933*67e74705SXin Li     A a7 = const_ref(a7);
934*67e74705SXin Li     A a8 = pointer(&a8);
935*67e74705SXin Li     A a9 = normal(a9);  // expected-warning {{uninitialized}}
936*67e74705SXin Li     const A a10 = a10;  // expected-warning {{uninitialized}}
937*67e74705SXin Li     A a11 = std::move(a11);  // expected-warning {{uninitialized}}
938*67e74705SXin Li     A a12 = A(std::move(a12));  // expected-warning {{uninitialized}}
939*67e74705SXin Li     A a13 = rref(std::move(a13));  // expected-warning {{uninitialized}}
940*67e74705SXin Li     A a14 = std::move(x ? a13 : (22, a14));  // expected-warning {{uninitialized}}
941*67e74705SXin Li   };
942*67e74705SXin Li   struct D {  // expected-note9{{in the implicit default constructor}}
943*67e74705SXin Li     A a1 = a1;  // expected-warning {{uninitialized}}
944*67e74705SXin Li     A a2 = a2.get();  // expected-warning {{uninitialized}}
945*67e74705SXin Li     A a3 = a3.num();
946*67e74705SXin Li     A a4 = a4.copy(a4);  // expected-warning {{uninitialized}}
947*67e74705SXin Li     A a5 = a5.something(a5);
948*67e74705SXin Li     A a6 = ref(a6);
949*67e74705SXin Li     A a7 = const_ref(a7);
950*67e74705SXin Li     A a8 = pointer(&a8);
951*67e74705SXin Li     A a9 = normal(a9);  // expected-warning {{uninitialized}}
952*67e74705SXin Li     const A a10 = a10;  // expected-warning {{uninitialized}}
953*67e74705SXin Li     A a11 = std::move(a11);  // expected-warning {{uninitialized}}
954*67e74705SXin Li     A a12 = A(std::move(a12));  // expected-warning {{uninitialized}}
955*67e74705SXin Li     A a13 = rref(std::move(a13));  // expected-warning {{uninitialized}}
956*67e74705SXin Li     A a14 = std::move(x ? a13 : (22, a14));  // expected-warning {{uninitialized}}
957*67e74705SXin Li   };
958*67e74705SXin Li   D d;
959*67e74705SXin Li   struct E {
960*67e74705SXin Li     A a1 = a1;
961*67e74705SXin Li     A a2 = a2.get();
962*67e74705SXin Li     A a3 = a3.num();
963*67e74705SXin Li     A a4 = a4.copy(a4);
964*67e74705SXin Li     A a5 = a5.something(a5);
965*67e74705SXin Li     A a6 = ref(a6);
966*67e74705SXin Li     A a7 = const_ref(a7);
967*67e74705SXin Li     A a8 = pointer(&a8);
968*67e74705SXin Li     A a9 = normal(a9);
969*67e74705SXin Li     const A a10 = a10;
970*67e74705SXin Li     A a11 = std::move(a11);
971*67e74705SXin Li     A a12 = A(std::move(a12));
972*67e74705SXin Li     A a13 = rref(std::move(a13));
973*67e74705SXin Li     A a14 = std::move(x ? a13 : (22, a14));
974*67e74705SXin Li   };
975*67e74705SXin Li }
976*67e74705SXin Li 
977*67e74705SXin Li namespace cross_field_warnings {
978*67e74705SXin Li   struct A {
979*67e74705SXin Li     int a, b;
Across_field_warnings::A980*67e74705SXin Li     A() {}
Across_field_warnings::A981*67e74705SXin Li     A(char (*)[1]) : b(a) {}  // expected-warning{{field 'a' is uninitialized when used here}}
Across_field_warnings::A982*67e74705SXin Li     A(char (*)[2]) : a(b) {}  // expected-warning{{field 'b' is uninitialized when used here}}
983*67e74705SXin Li   };
984*67e74705SXin Li 
985*67e74705SXin Li   struct B {
986*67e74705SXin Li     int a = b;  // expected-warning{{field 'b' is uninitialized when used here}}
987*67e74705SXin Li     int b;
Bcross_field_warnings::B988*67e74705SXin Li     B() {} // expected-note{{during field initialization in this constructor}}
989*67e74705SXin Li   };
990*67e74705SXin Li 
991*67e74705SXin Li   struct C {
992*67e74705SXin Li     int a;
993*67e74705SXin Li     int b = a;  // expected-warning{{field 'a' is uninitialized when used here}}
Ccross_field_warnings::C994*67e74705SXin Li     C(char (*)[1]) : a(5) {}
Ccross_field_warnings::C995*67e74705SXin Li     C(char (*)[2]) {} // expected-note{{during field initialization in this constructor}}
996*67e74705SXin Li   };
997*67e74705SXin Li 
998*67e74705SXin Li   struct D {
999*67e74705SXin Li     int a;
1000*67e74705SXin Li     int &b;
1001*67e74705SXin Li     int &c = a;
1002*67e74705SXin Li     int d = b;
Dcross_field_warnings::D1003*67e74705SXin Li     D() : b(a) {}
1004*67e74705SXin Li   };
1005*67e74705SXin Li 
1006*67e74705SXin Li   struct E {
1007*67e74705SXin Li     int a;
1008*67e74705SXin Li     int get();
1009*67e74705SXin Li     static int num();
Ecross_field_warnings::E1010*67e74705SXin Li     E() {}
Ecross_field_warnings::E1011*67e74705SXin Li     E(int) {}
1012*67e74705SXin Li   };
1013*67e74705SXin Li 
1014*67e74705SXin Li   struct F {
1015*67e74705SXin Li     int a;
1016*67e74705SXin Li     E e;
1017*67e74705SXin Li     int b;
Fcross_field_warnings::F1018*67e74705SXin Li     F(char (*)[1]) : a(e.get()) {}  // expected-warning{{field 'e' is uninitialized when used here}}
Fcross_field_warnings::F1019*67e74705SXin Li     F(char (*)[2]) : a(e.num()) {}
Fcross_field_warnings::F1020*67e74705SXin Li     F(char (*)[3]) : e(a) {}  // expected-warning{{field 'a' is uninitialized when used here}}
Fcross_field_warnings::F1021*67e74705SXin Li     F(char (*)[4]) : a(4), e(a) {}
Fcross_field_warnings::F1022*67e74705SXin Li     F(char (*)[5]) : e(b) {}  // expected-warning{{field 'b' is uninitialized when used here}}
Fcross_field_warnings::F1023*67e74705SXin Li     F(char (*)[6]) : e(b), b(4) {}  // expected-warning{{field 'b' is uninitialized when used here}}
1024*67e74705SXin Li   };
1025*67e74705SXin Li 
1026*67e74705SXin Li   struct G {
Gcross_field_warnings::G1027*67e74705SXin Li     G(const A&) {};
1028*67e74705SXin Li   };
1029*67e74705SXin Li 
1030*67e74705SXin Li   struct H {
1031*67e74705SXin Li     A a1;
1032*67e74705SXin Li     G g;
1033*67e74705SXin Li     A a2;
Hcross_field_warnings::H1034*67e74705SXin Li     H() : g(a1) {}
Hcross_field_warnings::H1035*67e74705SXin Li     H(int) : g(a2) {}
1036*67e74705SXin Li   };
1037*67e74705SXin Li 
1038*67e74705SXin Li   struct I {
Icross_field_warnings::I1039*67e74705SXin Li     I(int*) {}
1040*67e74705SXin Li   };
1041*67e74705SXin Li 
1042*67e74705SXin Li   struct J : public I {
1043*67e74705SXin Li     int *a;
1044*67e74705SXin Li     int *b;
1045*67e74705SXin Li     int c;
Jcross_field_warnings::J1046*67e74705SXin Li     J() : I((a = new int(5))), b(a), c(*a) {}
1047*67e74705SXin Li   };
1048*67e74705SXin Li 
1049*67e74705SXin Li   struct K {
1050*67e74705SXin Li     int a = (b = 5);
1051*67e74705SXin Li     int b = b + 5;
1052*67e74705SXin Li   };
1053*67e74705SXin Li 
1054*67e74705SXin Li   struct L {
1055*67e74705SXin Li     int a = (b = 5);
1056*67e74705SXin Li     int b = b + 5;  // expected-warning{{field 'b' is uninitialized when used here}}
Lcross_field_warnings::L1057*67e74705SXin Li     L() : a(5) {}  // expected-note{{during field initialization in this constructor}}
1058*67e74705SXin Li   };
1059*67e74705SXin Li 
1060*67e74705SXin Li   struct M { };
1061*67e74705SXin Li 
1062*67e74705SXin Li   struct N : public M {
1063*67e74705SXin Li     int a;
1064*67e74705SXin Li     int b;
Ncross_field_warnings::N1065*67e74705SXin Li     N() : b(a) { }  // expected-warning{{field 'a' is uninitialized when used here}}
1066*67e74705SXin Li   };
1067*67e74705SXin Li 
1068*67e74705SXin Li   struct O {
1069*67e74705SXin Li     int x = 42;
getcross_field_warnings::O1070*67e74705SXin Li     int get() { return x; }
1071*67e74705SXin Li   };
1072*67e74705SXin Li 
1073*67e74705SXin Li   struct P {
1074*67e74705SXin Li     O o;
1075*67e74705SXin Li     int x = o.get();
Pcross_field_warnings::P1076*67e74705SXin Li     P() : x(o.get()) { }
1077*67e74705SXin Li   };
1078*67e74705SXin Li 
1079*67e74705SXin Li   struct Q {
1080*67e74705SXin Li     int a;
1081*67e74705SXin Li     int b;
1082*67e74705SXin Li     int &c;
Qcross_field_warnings::Q1083*67e74705SXin Li     Q() :
1084*67e74705SXin Li       a(c = 5),  // expected-warning{{reference 'c' is not yet bound to a value when used here}}
1085*67e74705SXin Li       b(c),  // expected-warning{{reference 'c' is not yet bound to a value when used here}}
1086*67e74705SXin Li       c(a) {}
1087*67e74705SXin Li   };
1088*67e74705SXin Li 
1089*67e74705SXin Li   struct R {
1090*67e74705SXin Li     int a;
1091*67e74705SXin Li     int b;
1092*67e74705SXin Li     int c;
1093*67e74705SXin Li     int d = a + b + c;
Rcross_field_warnings::R1094*67e74705SXin Li     R() : a(c = 5), b(c), c(a) {}
1095*67e74705SXin Li   };
1096*67e74705SXin Li 
1097*67e74705SXin Li   // FIXME: Use the CFG-based analysis to give a sometimes uninitialized
1098*67e74705SXin Li   // warning on y.
1099*67e74705SXin Li   struct T {
1100*67e74705SXin Li     int x;
1101*67e74705SXin Li     int y;
Tcross_field_warnings::T1102*67e74705SXin Li     T(bool b)
1103*67e74705SXin Li         : x(b ? (y = 5) : (1 + y)),  // expected-warning{{field 'y' is uninitialized when used here}}
1104*67e74705SXin Li           y(y + 1) {}
Tcross_field_warnings::T1105*67e74705SXin Li     T(int b)
1106*67e74705SXin Li         : x(!b ? (1 + y) : (y = 5)),  // expected-warning{{field 'y' is uninitialized when used here}}
1107*67e74705SXin Li           y(y + 1) {}
1108*67e74705SXin Li   };
1109*67e74705SXin Li 
1110*67e74705SXin Li }
1111*67e74705SXin Li 
1112*67e74705SXin Li namespace base_class {
1113*67e74705SXin Li   struct A {
Abase_class::A1114*67e74705SXin Li     A (int) {}
1115*67e74705SXin Li   };
1116*67e74705SXin Li 
1117*67e74705SXin Li   struct B : public A {
1118*67e74705SXin Li     int x;
Bbase_class::B1119*67e74705SXin Li     B() : A(x) {}   // expected-warning{{field 'x' is uninitialized when used here}}
1120*67e74705SXin Li   };
1121*67e74705SXin Li 
1122*67e74705SXin Li   struct C : public A {
1123*67e74705SXin Li     int x;
1124*67e74705SXin Li     int y;
Cbase_class::C1125*67e74705SXin Li     C() : A(y = 4), x(y) {}
1126*67e74705SXin Li   };
1127*67e74705SXin Li }
1128*67e74705SXin Li 
1129*67e74705SXin Li namespace delegating_constructor {
1130*67e74705SXin Li   struct A {
1131*67e74705SXin Li     A(int);
1132*67e74705SXin Li     A(int&, int);
1133*67e74705SXin Li 
Adelegating_constructor::A1134*67e74705SXin Li     A(char (*)[1]) : A(x) {}
1135*67e74705SXin Li     // expected-warning@-1 {{field 'x' is uninitialized when used here}}
Adelegating_constructor::A1136*67e74705SXin Li     A(char (*)[2]) : A(x, x) {}
1137*67e74705SXin Li     // expected-warning@-1 {{field 'x' is uninitialized when used here}}
1138*67e74705SXin Li 
Adelegating_constructor::A1139*67e74705SXin Li     A(char (*)[3]) : A(x, 0) {}
1140*67e74705SXin Li 
1141*67e74705SXin Li     int x;
1142*67e74705SXin Li   };
1143*67e74705SXin Li }
1144*67e74705SXin Li 
1145*67e74705SXin Li namespace init_list {
1146*67e74705SXin Li   int num = 5;
1147*67e74705SXin Li   struct A { int i1, i2; };
1148*67e74705SXin Li   struct B { A a1, a2; };
1149*67e74705SXin Li 
1150*67e74705SXin Li   A a1{1,2};
1151*67e74705SXin Li   A a2{a2.i1 + 2};  // expected-warning{{uninitialized}}
1152*67e74705SXin Li   A a3 = {a3.i1 + 2};  // expected-warning{{uninitialized}}
1153*67e74705SXin Li   A a4 = A{a4.i2 + 2};  // expected-warning{{uninitialized}}
1154*67e74705SXin Li 
1155*67e74705SXin Li   B b1 = { {}, {} };
1156*67e74705SXin Li   B b2 = { {}, b2.a1 };
1157*67e74705SXin Li   B b3 = { b3.a1 };  // expected-warning{{uninitialized}}
1158*67e74705SXin Li   B b4 = { {}, b4.a2} ;  // expected-warning{{uninitialized}}
1159*67e74705SXin Li   B b5 = { b5.a2 };  // expected-warning{{uninitialized}}
1160*67e74705SXin Li 
1161*67e74705SXin Li   B b6 = { {b6.a1.i1} };  // expected-warning{{uninitialized}}
1162*67e74705SXin Li   B b7 = { {0, b7.a1.i1} };
1163*67e74705SXin Li   B b8 = { {}, {b8.a1.i1} };
1164*67e74705SXin Li   B b9 = { {}, {0, b9.a1.i1} };
1165*67e74705SXin Li 
1166*67e74705SXin Li   B b10 = { {b10.a1.i2} };  // expected-warning{{uninitialized}}
1167*67e74705SXin Li   B b11 = { {0, b11.a1.i2} };  // expected-warning{{uninitialized}}
1168*67e74705SXin Li   B b12 = { {}, {b12.a1.i2} };
1169*67e74705SXin Li   B b13 = { {}, {0, b13.a1.i2} };
1170*67e74705SXin Li 
1171*67e74705SXin Li   B b14 = { {b14.a2.i1} };  // expected-warning{{uninitialized}}
1172*67e74705SXin Li   B b15 = { {0, b15.a2.i1} };  // expected-warning{{uninitialized}}
1173*67e74705SXin Li   B b16 = { {}, {b16.a2.i1} };  // expected-warning{{uninitialized}}
1174*67e74705SXin Li   B b17 = { {}, {0, b17.a2.i1} };
1175*67e74705SXin Li 
1176*67e74705SXin Li   B b18 = { {b18.a2.i2} };  // expected-warning{{uninitialized}}
1177*67e74705SXin Li   B b19 = { {0, b19.a2.i2} };  // expected-warning{{uninitialized}}
1178*67e74705SXin Li   B b20 = { {}, {b20.a2.i2} };  // expected-warning{{uninitialized}}
1179*67e74705SXin Li   B b21 = { {}, {0, b21.a2.i2} };  // expected-warning{{uninitialized}}
1180*67e74705SXin Li 
1181*67e74705SXin Li   B b22 = { {b18.a2.i2 + 5} };
1182*67e74705SXin Li 
1183*67e74705SXin Li   struct C {int a; int& b; int c; };
1184*67e74705SXin Li   C c1 = { 0, num, 0 };
1185*67e74705SXin Li   C c2 = { 1, num, c2.b };
1186*67e74705SXin Li   C c3 = { c3.b, num };  // expected-warning{{uninitialized}}
1187*67e74705SXin Li   C c4 = { 0, c4.b, 0 };  // expected-warning{{uninitialized}}
1188*67e74705SXin Li   C c5 = { 0, c5.c, 0 };
1189*67e74705SXin Li   C c6 = { c6.b, num, 0 };  // expected-warning{{uninitialized}}
1190*67e74705SXin Li   C c7 = { 0, c7.a, 0 };
1191*67e74705SXin Li 
1192*67e74705SXin Li   struct D {int &a; int &b; };
1193*67e74705SXin Li   D d1 = { num, num };
1194*67e74705SXin Li   D d2 = { num, d2.a };
1195*67e74705SXin Li   D d3 = { d3.b, num };  // expected-warning{{uninitialized}}
1196*67e74705SXin Li 
1197*67e74705SXin Li   // Same as above in member initializer form.
1198*67e74705SXin Li   struct Awrapper {
1199*67e74705SXin Li     A a1{1,2};
1200*67e74705SXin Li     A a2{a2.i1 + 2};  // expected-warning{{uninitialized}}
1201*67e74705SXin Li     A a3 = {a3.i1 + 2};  // expected-warning{{uninitialized}}
1202*67e74705SXin Li     A a4 = A{a4.i2 + 2};  // expected-warning{{uninitialized}}
Awrapperinit_list::Awrapper1203*67e74705SXin Li     Awrapper() {}  // expected-note 3{{in this constructor}}
Awrapperinit_list::Awrapper1204*67e74705SXin Li     Awrapper(int) :
1205*67e74705SXin Li       a1{1,2},
1206*67e74705SXin Li       a2{a2.i1 + 2},  // expected-warning{{uninitialized}}
1207*67e74705SXin Li       a3{a3.i1 + 2},  // expected-warning{{uninitialized}}
1208*67e74705SXin Li       a4{a4.i2 + 2}  // expected-warning{{uninitialized}}
1209*67e74705SXin Li     {}
1210*67e74705SXin Li   };
1211*67e74705SXin Li 
1212*67e74705SXin Li   struct Bwrapper {
1213*67e74705SXin Li     B b1 = { {}, {} };
1214*67e74705SXin Li     B b2 = { {}, b2.a1 };
1215*67e74705SXin Li     B b3 = { b3.a1 };  // expected-warning{{uninitialized}}
1216*67e74705SXin Li     B b4 = { {}, b4.a2} ;  // expected-warning{{uninitialized}}
1217*67e74705SXin Li     B b5 = { b5.a2 };  // expected-warning{{uninitialized}}
1218*67e74705SXin Li 
1219*67e74705SXin Li     B b6 = { {b6.a1.i1} };  // expected-warning{{uninitialized}}
1220*67e74705SXin Li     B b7 = { {0, b7.a1.i1} };
1221*67e74705SXin Li     B b8 = { {}, {b8.a1.i1} };
1222*67e74705SXin Li     B b9 = { {}, {0, b9.a1.i1} };
1223*67e74705SXin Li 
1224*67e74705SXin Li     B b10 = { {b10.a1.i2} };  // expected-warning{{uninitialized}}
1225*67e74705SXin Li     B b11 = { {0, b11.a1.i2} };  // expected-warning{{uninitialized}}
1226*67e74705SXin Li     B b12 = { {}, {b12.a1.i2} };
1227*67e74705SXin Li     B b13 = { {}, {0, b13.a1.i2} };
1228*67e74705SXin Li 
1229*67e74705SXin Li     B b14 = { {b14.a2.i1} };  // expected-warning{{uninitialized}}
1230*67e74705SXin Li     B b15 = { {0, b15.a2.i1} };  // expected-warning{{uninitialized}}
1231*67e74705SXin Li     B b16 = { {}, {b16.a2.i1} };  // expected-warning{{uninitialized}}
1232*67e74705SXin Li     B b17 = { {}, {0, b17.a2.i1} };
1233*67e74705SXin Li 
1234*67e74705SXin Li     B b18 = { {b18.a2.i2} };  // expected-warning{{uninitialized}}
1235*67e74705SXin Li     B b19 = { {0, b19.a2.i2} };  // expected-warning{{uninitialized}}
1236*67e74705SXin Li     B b20 = { {}, {b20.a2.i2} };  // expected-warning{{uninitialized}}
1237*67e74705SXin Li     B b21 = { {}, {0, b21.a2.i2} };  // expected-warning{{uninitialized}}
1238*67e74705SXin Li 
1239*67e74705SXin Li     B b22 = { {b18.a2.i2 + 5} };
Bwrapperinit_list::Bwrapper1240*67e74705SXin Li     Bwrapper() {}  // expected-note 13{{in this constructor}}
Bwrapperinit_list::Bwrapper1241*67e74705SXin Li     Bwrapper(int) :
1242*67e74705SXin Li       b1{ {}, {} },
1243*67e74705SXin Li       b2{ {}, b2.a1 },
1244*67e74705SXin Li       b3{ b3.a1 },  // expected-warning{{uninitialized}}
1245*67e74705SXin Li       b4{ {}, b4.a2}, // expected-warning{{uninitialized}}
1246*67e74705SXin Li       b5{ b5.a2 },  // expected-warning{{uninitialized}}
1247*67e74705SXin Li 
1248*67e74705SXin Li       b6{ {b6.a1.i1} },  // expected-warning{{uninitialized}}
1249*67e74705SXin Li       b7{ {0, b7.a1.i1} },
1250*67e74705SXin Li       b8{ {}, {b8.a1.i1} },
1251*67e74705SXin Li       b9{ {}, {0, b9.a1.i1} },
1252*67e74705SXin Li 
1253*67e74705SXin Li       b10{ {b10.a1.i2} },  // expected-warning{{uninitialized}}
1254*67e74705SXin Li       b11{ {0, b11.a1.i2} },  // expected-warning{{uninitialized}}
1255*67e74705SXin Li       b12{ {}, {b12.a1.i2} },
1256*67e74705SXin Li       b13{ {}, {0, b13.a1.i2} },
1257*67e74705SXin Li 
1258*67e74705SXin Li       b14{ {b14.a2.i1} },  // expected-warning{{uninitialized}}
1259*67e74705SXin Li       b15{ {0, b15.a2.i1} },  // expected-warning{{uninitialized}}
1260*67e74705SXin Li       b16{ {}, {b16.a2.i1} },  // expected-warning{{uninitialized}}
1261*67e74705SXin Li       b17{ {}, {0, b17.a2.i1} },
1262*67e74705SXin Li 
1263*67e74705SXin Li       b18{ {b18.a2.i2} },  // expected-warning{{uninitialized}}
1264*67e74705SXin Li       b19{ {0, b19.a2.i2} },  // expected-warning{{uninitialized}}
1265*67e74705SXin Li       b20{ {}, {b20.a2.i2} },  // expected-warning{{uninitialized}}
1266*67e74705SXin Li       b21{ {}, {0, b21.a2.i2} },  // expected-warning{{uninitialized}}
1267*67e74705SXin Li 
1268*67e74705SXin Li       b22{ {b18.a2.i2 + 5} }
1269*67e74705SXin Li     {}
1270*67e74705SXin Li   };
1271*67e74705SXin Li 
1272*67e74705SXin Li   struct Cwrapper {
1273*67e74705SXin Li     C c1 = { 0, num, 0 };
1274*67e74705SXin Li     C c2 = { 1, num, c2.b };
1275*67e74705SXin Li     C c3 = { c3.b, num };  // expected-warning{{uninitialized}}
1276*67e74705SXin Li     C c4 = { 0, c4.b, 0 };  // expected-warning{{uninitialized}}
1277*67e74705SXin Li     C c5 = { 0, c5.c, 0 };
1278*67e74705SXin Li     C c6 = { c6.b, num, 0 };  // expected-warning{{uninitialized}}
1279*67e74705SXin Li     C c7 = { 0, c7.a, 0 };
1280*67e74705SXin Li 
Cwrapperinit_list::Cwrapper1281*67e74705SXin Li     Cwrapper() {} // expected-note 3{{in this constructor}}
Cwrapperinit_list::Cwrapper1282*67e74705SXin Li     Cwrapper(int) :
1283*67e74705SXin Li       c1{ 0, num, 0 },
1284*67e74705SXin Li       c2{ 1, num, c2.b },
1285*67e74705SXin Li       c3{ c3.b, num },  // expected-warning{{uninitialized}}
1286*67e74705SXin Li       c4{ 0, c4.b, 0 },  // expected-warning{{uninitialized}}
1287*67e74705SXin Li       c5{ 0, c5.c, 0 },
1288*67e74705SXin Li       c6{ c6.b, num, 0 },  // expected-warning{{uninitialized}}
1289*67e74705SXin Li       c7{ 0, c7.a, 0 }
1290*67e74705SXin Li     {}
1291*67e74705SXin Li   };
1292*67e74705SXin Li 
1293*67e74705SXin Li   struct Dwrapper {
1294*67e74705SXin Li     D d1 = { num, num };
1295*67e74705SXin Li     D d2 = { num, d2.a };
1296*67e74705SXin Li     D d3 = { d3.b, num }; // expected-warning{{uninitialized}}
Dwrapperinit_list::Dwrapper1297*67e74705SXin Li     Dwrapper() {}  // expected-note{{in this constructor}}
Dwrapperinit_list::Dwrapper1298*67e74705SXin Li     Dwrapper(int) :
1299*67e74705SXin Li       d1{ num, num },
1300*67e74705SXin Li       d2{ num, d2.a },
1301*67e74705SXin Li       d3{ d3.b, num } // expected-warning{{uninitialized}}
1302*67e74705SXin Li     {}
1303*67e74705SXin Li   };
1304*67e74705SXin Li }
1305*67e74705SXin Li 
1306*67e74705SXin Li namespace template_class {
1307*67e74705SXin Li class Foo {
1308*67e74705SXin Li  public:
Create()1309*67e74705SXin Li     int *Create() { return nullptr; }
1310*67e74705SXin Li };
1311*67e74705SXin Li 
1312*67e74705SXin Li template <typename T>
1313*67e74705SXin Li class A {
1314*67e74705SXin Li public:
1315*67e74705SXin Li   // Don't warn on foo here.
A()1316*67e74705SXin Li   A() : ptr(foo->Create()) {}
1317*67e74705SXin Li 
1318*67e74705SXin Li private:
1319*67e74705SXin Li   Foo *foo = new Foo;
1320*67e74705SXin Li   int *ptr;
1321*67e74705SXin Li };
1322*67e74705SXin Li 
1323*67e74705SXin Li template <typename T>
1324*67e74705SXin Li class B {
1325*67e74705SXin Li public:
1326*67e74705SXin Li   // foo is uninitialized here, but class B is never instantiated.
B()1327*67e74705SXin Li   B() : ptr(foo->Create()) {}
1328*67e74705SXin Li 
1329*67e74705SXin Li private:
1330*67e74705SXin Li   Foo *foo;
1331*67e74705SXin Li   int *ptr;
1332*67e74705SXin Li };
1333*67e74705SXin Li 
1334*67e74705SXin Li template <typename T>
1335*67e74705SXin Li class C {
1336*67e74705SXin Li public:
C()1337*67e74705SXin Li   C() : ptr(foo->Create()) {}
1338*67e74705SXin Li   // expected-warning@-1 {{field 'foo' is uninitialized when used here}}
1339*67e74705SXin Li private:
1340*67e74705SXin Li   Foo *foo;
1341*67e74705SXin Li   int *ptr;
1342*67e74705SXin Li };
1343*67e74705SXin Li 
1344*67e74705SXin Li C<int> c;
1345*67e74705SXin Li // expected-note@-1 {{in instantiation of member function 'template_class::C<int>::C' requested here}}
1346*67e74705SXin Li 
1347*67e74705SXin Li }
1348*67e74705SXin Li 
1349*67e74705SXin Li namespace base_class_access {
1350*67e74705SXin Li struct A {
1351*67e74705SXin Li   A();
1352*67e74705SXin Li   A(int);
1353*67e74705SXin Li 
1354*67e74705SXin Li   int i;
1355*67e74705SXin Li   int foo();
1356*67e74705SXin Li 
1357*67e74705SXin Li   static int bar();
1358*67e74705SXin Li };
1359*67e74705SXin Li 
1360*67e74705SXin Li struct B : public A {
Bbase_class_access::B1361*67e74705SXin Li   B(int (*)[1]) : A() {}
Bbase_class_access::B1362*67e74705SXin Li   B(int (*)[2]) : A(bar()) {}
1363*67e74705SXin Li 
Bbase_class_access::B1364*67e74705SXin Li   B(int (*)[3]) : A(i) {}
1365*67e74705SXin Li   // expected-warning@-1 {{base class 'base_class_access::A' is uninitialized when used here to access 'base_class_access::A::i'}}
1366*67e74705SXin Li 
Bbase_class_access::B1367*67e74705SXin Li   B(int (*)[4]) : A(foo()) {}
1368*67e74705SXin Li   // expected-warning@-1 {{base_class_access::A' is uninitialized when used here to access 'base_class_access::A::foo'}}
1369*67e74705SXin Li };
1370*67e74705SXin Li 
1371*67e74705SXin Li struct C {
Cbase_class_access::C1372*67e74705SXin Li   C(int) {}
1373*67e74705SXin Li };
1374*67e74705SXin Li 
1375*67e74705SXin Li struct D : public C, public A {
Dbase_class_access::D1376*67e74705SXin Li   D(int (*)[1]) : C(0) {}
Dbase_class_access::D1377*67e74705SXin Li   D(int (*)[2]) : C(bar()) {}
1378*67e74705SXin Li 
Dbase_class_access::D1379*67e74705SXin Li   D(int (*)[3]) : C(i) {}
1380*67e74705SXin Li   // expected-warning@-1 {{base class 'base_class_access::A' is uninitialized when used here to access 'base_class_access::A::i'}}
1381*67e74705SXin Li 
Dbase_class_access::D1382*67e74705SXin Li   D(int (*)[4]) : C(foo()) {}
1383*67e74705SXin Li   // expected-warning@-1 {{base_class_access::A' is uninitialized when used here to access 'base_class_access::A::foo'}}
1384*67e74705SXin Li };
1385*67e74705SXin Li 
1386*67e74705SXin Li }
1387*67e74705SXin Li 
1388*67e74705SXin Li namespace value {
1389*67e74705SXin Li template <class T> T move(T t);
1390*67e74705SXin Li template <class T> T notmove(T t);
1391*67e74705SXin Li }
1392*67e74705SXin Li namespace lvalueref {
1393*67e74705SXin Li template <class T> T move(T& t);
1394*67e74705SXin Li template <class T> T notmove(T& t);
1395*67e74705SXin Li }
1396*67e74705SXin Li namespace rvalueref {
1397*67e74705SXin Li template <class T> T move(T&& t);
1398*67e74705SXin Li template <class T> T notmove(T&& t);
1399*67e74705SXin Li }
1400*67e74705SXin Li 
1401*67e74705SXin Li namespace move_test {
1402*67e74705SXin Li int a1 = std::move(a1); // expected-warning {{uninitialized}}
1403*67e74705SXin Li int a2 = value::move(a2); // expected-warning {{uninitialized}}
1404*67e74705SXin Li int a3 = value::notmove(a3); // expected-warning {{uninitialized}}
1405*67e74705SXin Li int a4 = lvalueref::move(a4);
1406*67e74705SXin Li int a5 = lvalueref::notmove(a5);
1407*67e74705SXin Li int a6 = rvalueref::move(a6);
1408*67e74705SXin Li int a7 = rvalueref::notmove(a7);
1409*67e74705SXin Li 
test()1410*67e74705SXin Li void test() {
1411*67e74705SXin Li   int a1 = std::move(a1); // expected-warning {{uninitialized}}
1412*67e74705SXin Li   int a2 = value::move(a2); // expected-warning {{uninitialized}}
1413*67e74705SXin Li   int a3 = value::notmove(a3); // expected-warning {{uninitialized}}
1414*67e74705SXin Li   int a4 = lvalueref::move(a4);
1415*67e74705SXin Li   int a5 = lvalueref::notmove(a5);
1416*67e74705SXin Li   int a6 = rvalueref::move(a6);
1417*67e74705SXin Li   int a7 = rvalueref::notmove(a7);
1418*67e74705SXin Li }
1419*67e74705SXin Li 
1420*67e74705SXin Li class A {
1421*67e74705SXin Li   int a;
A(int (*)[1])1422*67e74705SXin Li   A(int (*) [1]) : a(std::move(a)) {} // expected-warning {{uninitialized}}
A(int (*)[2])1423*67e74705SXin Li   A(int (*) [2]) : a(value::move(a)) {} // expected-warning {{uninitialized}}
A(int (*)[3])1424*67e74705SXin Li   A(int (*) [3]) : a(value::notmove(a)) {} // expected-warning {{uninitialized}}
A(int (*)[4])1425*67e74705SXin Li   A(int (*) [4]) : a(lvalueref::move(a)) {}
A(int (*)[5])1426*67e74705SXin Li   A(int (*) [5]) : a(lvalueref::notmove(a)) {}
A(int (*)[6])1427*67e74705SXin Li   A(int (*) [6]) : a(rvalueref::move(a)) {}
A(int (*)[7])1428*67e74705SXin Li   A(int (*) [7]) : a(rvalueref::notmove(a)) {}
1429*67e74705SXin Li };
1430*67e74705SXin Li }
1431*67e74705SXin Li 
array_capture(bool b)1432*67e74705SXin Li void array_capture(bool b) {
1433*67e74705SXin Li   const char fname[] = "array_capture";
1434*67e74705SXin Li   if (b) {
1435*67e74705SXin Li     int unused; // expected-warning {{unused variable}}
1436*67e74705SXin Li   } else {
1437*67e74705SXin Li     [fname]{};
1438*67e74705SXin Li   }
1439*67e74705SXin Li }
1440