blob: c7b0619e297b3c5b254db1daa13c7a8e92bf9c3b [file] [log] [blame]
George Karpenkova393e682018-08-29 20:29:17 +00001// RUN: %clang_analyze_cc1 -w -x c++ -analyzer-checker=core -analyzer-output=text -verify %s
Artem Dergachev2064e822017-09-27 09:33:37 +00002
3namespace pr34731 {
4int b;
5class c {
6 class B {
7 public:
8 double ***d;
9 B();
10 };
11 void e(double **, int);
12 void f(B &, int &);
13};
14
15// Properly track the null pointer in the array field back to the default
16// constructor of 'h'.
17void c::f(B &g, int &i) {
18 e(g.d[9], i); // expected-warning{{Array access (via field 'd') results in a null pointer dereference}}
19 // expected-note@-1{{Array access (via field 'd') results in a null pointer dereference}}
20 B h, a; // expected-note{{Value assigned to 'h.d'}}
21 a.d == __null; // expected-note{{Assuming the condition is true}}
Csaba Dabisd1f0ec32019-05-29 20:29:02 +000022 a.d != h.d; // expected-note{{Assuming 'a.d' is equal to 'h.d'}}
Artem Dergachev2064e822017-09-27 09:33:37 +000023 f(h, b); // expected-note{{Calling 'c::f'}}
24}
25}