Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / clang / test / Analysis / initializer.cpp
blob16d7a348fdfb6d57fd722a8639a6c2c7222dc337
1 // RUN: %clang_analyze_cc1 -w -verify %s\
2 // RUN: -analyzer-checker=core,unix.Malloc,cplusplus.NewDeleteLeaks\
3 // RUN: -analyzer-checker=debug.ExprInspection -std=c++11
4 // RUN: %clang_analyze_cc1 -w -verify %s\
5 // RUN: -analyzer-checker=core,unix.Malloc,cplusplus.NewDeleteLeaks\
6 // RUN: -analyzer-checker=debug.ExprInspection -std=c++17
7 // RUN: %clang_analyze_cc1 -w -verify %s\
8 // RUN: -analyzer-checker=core,unix.Malloc,cplusplus.NewDeleteLeaks\
9 // RUN: -analyzer-checker=debug.ExprInspection -std=c++11\
10 // RUN: -DTEST_INLINABLE_ALLOCATORS
11 // RUN: %clang_analyze_cc1 -w -verify %s\
12 // RUN: -analyzer-checker=core,unix.Malloc,cplusplus.NewDeleteLeaks\
13 // RUN: -analyzer-checker=debug.ExprInspection -std=c++17\
14 // RUN: -DTEST_INLINABLE_ALLOCATORS
16 void clang_analyzer_eval(bool);
18 #include "Inputs/system-header-simulator-cxx.h"
20 class A {
21 int x;
22 public:
23 A();
26 A::A() : x(0) {
27 clang_analyzer_eval(x == 0); // expected-warning{{TRUE}}
31 class DirectMember {
32 int x;
33 public:
34 DirectMember(int value) : x(value) {}
36 int getX() { return x; }
39 void testDirectMember() {
40 DirectMember obj(3);
41 clang_analyzer_eval(obj.getX() == 3); // expected-warning{{TRUE}}
45 class IndirectMember {
46 struct {
47 int x;
49 public:
50 IndirectMember(int value) : x(value) {}
52 int getX() { return x; }
55 void testIndirectMember() {
56 IndirectMember obj(3);
57 clang_analyzer_eval(obj.getX() == 3); // expected-warning{{TRUE}}
61 struct DelegatingConstructor {
62 int x;
63 DelegatingConstructor(int y) { x = y; }
64 DelegatingConstructor() : DelegatingConstructor(42) {}
67 void testDelegatingConstructor() {
68 DelegatingConstructor obj;
69 clang_analyzer_eval(obj.x == 42); // expected-warning{{TRUE}}
73 struct RefWrapper {
74 RefWrapper(int *p) : x(*p) {}
75 RefWrapper(int &r) : x(r) {}
76 int &x;
79 void testReferenceMember() {
80 int *p = 0;
81 RefWrapper X(p); // expected-warning@-7 {{Dereference of null pointer}}
84 void testReferenceMember2() {
85 int *p = 0;
86 RefWrapper X(*p); // expected-warning {{Forming reference to null pointer}}
90 extern "C" char *strdup(const char *);
92 class StringWrapper {
93 char *str;
94 public:
95 StringWrapper(const char *input) : str(strdup(input)) {} // no-warning
99 // PR15070 - Constructing a type containing a non-POD array mistakenly
100 // tried to perform a bind instead of relying on the CXXConstructExpr,
101 // which caused a cast<> failure in RegionStore.
102 namespace DefaultConstructorWithCleanups {
103 class Element {
104 public:
105 int value;
107 class Helper {
108 public:
109 ~Helper();
111 Element(Helper h = Helper());
113 class Wrapper {
114 public:
115 Element arr[2];
117 Wrapper();
120 Wrapper::Wrapper() /* initializers synthesized */ {}
122 int test() {
123 Wrapper w;
124 return w.arr[0].value; // no-warning
128 namespace DefaultMemberInitializers {
129 struct Wrapper {
130 int value = 42;
132 Wrapper() {}
133 Wrapper(int x) : value(x) {}
134 Wrapper(bool) {}
137 void test() {
138 Wrapper w1;
139 clang_analyzer_eval(w1.value == 42); // expected-warning{{TRUE}}
141 Wrapper w2(50);
142 clang_analyzer_eval(w2.value == 50); // expected-warning{{TRUE}}
144 Wrapper w3(false);
145 clang_analyzer_eval(w3.value == 42); // expected-warning{{TRUE}}
148 struct StringWrapper {
149 const char s[4] = "abc";
150 const char *p = "xyz";
152 StringWrapper(bool) {}
155 void testString() {
156 StringWrapper w(true);
157 clang_analyzer_eval(w.s[1] == 'b'); // expected-warning{{TRUE}}
158 clang_analyzer_eval(w.p[1] == 'y'); // expected-warning{{TRUE}}
162 namespace ReferenceInitialization {
163 struct OtherStruct {
164 OtherStruct(int i);
165 ~OtherStruct();
168 struct MyStruct {
169 MyStruct(int i);
170 MyStruct(OtherStruct os);
172 void method() const;
175 void referenceInitializeLocal() {
176 const MyStruct &myStruct(5);
177 myStruct.method(); // no-warning
180 void referenceInitializeMultipleLocals() {
181 const MyStruct &myStruct1(5), myStruct2(5), &myStruct3(5);
182 myStruct1.method(); // no-warning
183 myStruct2.method(); // no-warning
184 myStruct3.method(); // no-warning
187 void referenceInitializeLocalWithCleanup() {
188 const MyStruct &myStruct(OtherStruct(5));
189 myStruct.method(); // no-warning
193 namespace PR31592 {
194 struct C {
195 C() : f("}") { } // no-crash
196 const char(&f)[2];
200 namespace CXX_initializer_lists {
201 struct C {
202 C(std::initializer_list<int *> list);
204 void testPointerEscapeIntoLists() {
205 C empty{}; // no-crash
207 // Do not warn that 'x' leaks. It might have been deleted by
208 // the destructor of 'c'.
209 int *x = new int;
210 C c{x}; // no-warning
213 void testPassListsWithExplicitConstructors() {
214 (void)(std::initializer_list<int>){12}; // no-crash
218 namespace CXX17_aggregate_construction {
219 struct A {
220 A();
223 struct B: public A {
226 struct C: public B {
229 struct D: public virtual A {
232 // In C++17, classes B and C are aggregates, so they will be constructed
233 // without actually calling their trivial constructor. Used to crash.
234 void foo() {
235 B b = {}; // no-crash
236 const B &bl = {}; // no-crash
237 B &&br = {}; // no-crash
239 C c = {}; // no-crash
240 const C &cl = {}; // no-crash
241 C &&cr = {}; // no-crash
243 D d = {}; // no-crash
245 #if __cplusplus >= 201703L
246 C cd = {{}}; // no-crash
247 const C &cdl = {{}}; // no-crash
248 C &&cdr = {{}}; // no-crash
250 const B &bll = {{}}; // no-crash
251 const B &bcl = C({{}}); // no-crash
252 B &&bcr = C({{}}); // no-crash
253 #endif
255 } // namespace CXX17_aggregate_construction
257 namespace CXX17_transparent_init_list_exprs {
258 class A {};
260 class B: private A {};
262 B boo();
263 void foo1() {
264 B b { boo() }; // no-crash
267 class C: virtual public A {};
269 C coo();
270 void foo2() {
271 C c { coo() }; // no-crash
274 B foo_recursive() {
275 B b { foo_recursive() };
277 } // namespace CXX17_transparent_init_list_exprs
279 namespace skip_vbase_initializer_side_effects {
280 int glob;
281 struct S {
282 S() { ++glob; }
285 struct A {
286 A() {}
287 A(S s) {}
290 struct B : virtual A {
291 B() : A(S()) {}
294 struct C : B {
295 C() {}
298 void foo() {
299 glob = 0;
300 B b;
301 clang_analyzer_eval(glob == 1); // expected-warning{{TRUE}}
302 C c; // no-crash
303 clang_analyzer_eval(glob == 1); // expected-warning{{TRUE}}
305 } // namespace skip_vbase_initializer_side_effects
307 namespace dont_skip_vbase_initializers_in_most_derived_class {
308 struct A {
309 static int a;
310 A() { a = 0; }
311 A(int x) { a = x; }
314 struct B {
315 static int b;
316 B() { b = 0; }
317 B(int y) { b = y; }
320 struct C : virtual A {
321 C() : A(1) {}
323 struct D : C, virtual B {
324 D() : B(2) {}
327 void testD() {
328 D d;
329 clang_analyzer_eval(A::a == 0); // expected-warning{{TRUE}}
330 clang_analyzer_eval(B::b == 2); // expected-warning{{TRUE}}
333 struct E : virtual B, C {
334 E() : B(2) {}
337 void testE() {
338 E e;
339 clang_analyzer_eval(A::a == 0); // expected-warning{{TRUE}}
340 clang_analyzer_eval(B::b == 2); // expected-warning{{TRUE}}
343 struct F : virtual A, virtual B {
344 F() : A(1) {}
346 struct G : F {
347 G(): B(2) {}
350 void testG() {
351 G g;
352 clang_analyzer_eval(A::a == 0); // expected-warning{{TRUE}}
353 clang_analyzer_eval(B::b == 2); // expected-warning{{TRUE}}
356 struct H : virtual B, virtual A {
357 H(): A(1) {}
359 struct I : H {
360 I(): B(2) {}
363 void testI() {
364 I i;
365 clang_analyzer_eval(A::a == 0); // expected-warning{{TRUE}}
366 clang_analyzer_eval(B::b == 2); // expected-warning{{TRUE}}
368 } // namespace dont_skip_vbase_initializers_in_most_derived_class