blob: 8558e8f6ab8c23333e7f0570476c6322a251a0a9 [file] [log] [blame]
Jordan Roseb9d4e5e2012-09-22 01:25:06 +00001// RUN: %clang --analyze %s -fblocks -Xanalyzer -analyzer-output=text -Xanalyzer -analyzer-config -Xanalyzer suppress-null-return-paths=false -Xclang -verify %s
Jordan Rose048eeea2013-06-03 23:00:19 +00002// RUN: %clang --analyze %s -fblocks -Xanalyzer -analyzer-config -Xanalyzer suppress-null-return-paths=false -Xanalyzer -analyzer-config -Xanalyzer path-diagnostics-alternate=false -o %t
Ted Kremenek4ba86bc2012-03-02 21:16:22 +00003// RUN: FileCheck -input-file %t %s
4
5// <rdar://problem/10967815>
6void mmm(int y) {
7 if (y != 0)
Jordan Rose85e99372012-09-22 01:24:46 +00008 y++;
Ted Kremenek4ba86bc2012-03-02 21:16:22 +00009}
10
11int foo(int x, int y) {
Jordan Rose85e99372012-09-22 01:24:46 +000012 mmm(y);
13 if (x != 0) {
14 // expected-note@-1 {{Assuming 'x' is equal to 0}}
15 // expected-note@-2 {{Taking false branch}}
16 x++;
17 }
18 return 5/x; // expected-warning{{Division by zero}} expected-note{{Division by zero}}
Ted Kremenek4ba86bc2012-03-02 21:16:22 +000019}
20
Ted Kremeneke881efe2012-03-12 22:10:57 +000021// Test a bug triggering only when inlined.
22void has_bug(int *p) {
Jordan Rose85e99372012-09-22 01:24:46 +000023 *p = 0xDEADBEEF; // expected-warning{{Dereference of null pointer (loaded from variable 'p')}} expected-note{{Dereference of null pointer (loaded from variable 'p')}}
Ted Kremeneke881efe2012-03-12 22:10:57 +000024}
25
26void test_has_bug() {
27 has_bug(0);
Jordan Rose85e99372012-09-22 01:24:46 +000028 // expected-note@-1 {{Passing null pointer value via 1st parameter 'p'}}
29 // expected-note@-2 {{Calling 'has_bug'}}
Ted Kremeneke881efe2012-03-12 22:10:57 +000030}
31
Ted Kremenek11abcec2012-05-02 00:31:29 +000032void triggers_bug(int *p) {
Jordan Rose85e99372012-09-22 01:24:46 +000033 *p = 0xDEADBEEF; // expected-warning{{Dereference of null pointer (loaded from variable 'p')}} expected-note{{Dereference of null pointer (loaded from variable 'p')}}
Ted Kremenek11abcec2012-05-02 00:31:29 +000034}
35
36// This function triggers a bug by calling triggers_bug(). The diagnostics
37// should show when p is assumed to be null.
38void bar(int *p) {
Jordan Rose85e99372012-09-22 01:24:46 +000039 if (!!p) {
40 // expected-note@-1 {{Assuming 'p' is null}}
Ted Kremenekb85cce02012-10-25 22:07:10 +000041 // expected-note@-2 {{Taking false branch}}
Ted Kremenek11abcec2012-05-02 00:31:29 +000042 return;
Jordan Rose85e99372012-09-22 01:24:46 +000043 }
Ted Kremenek11abcec2012-05-02 00:31:29 +000044
Jordan Rose85e99372012-09-22 01:24:46 +000045 if (p == 0) {
46 // expected-note@-1 {{Taking true branch}}
Ted Kremenek11abcec2012-05-02 00:31:29 +000047 triggers_bug(p);
Jordan Rose85e99372012-09-22 01:24:46 +000048 // expected-note@-1 {{Passing null pointer value via 1st parameter 'p'}}
49 // expected-note@-2 {{Calling 'triggers_bug'}}
50 }
Ted Kremenek11abcec2012-05-02 00:31:29 +000051}
Ted Kremenekbd613132012-04-06 22:10:18 +000052
Ted Kremenek7fa9b4f2012-06-01 20:04:04 +000053// ========================================================================== //
54// Test inlining of blocks.
55// ========================================================================== //
56
57void test_block__capture_null() {
Ted Kremenek4238f412013-02-26 19:44:38 +000058 int *p = 0; // expected-note{{'p' initialized to a null pointer value}}
Jordan Rose85e99372012-09-22 01:24:46 +000059 ^(){ // expected-note {{Calling anonymous block}}
60 *p = 1; // expected-warning{{Dereference of null pointer (loaded from variable 'p')}} expected-note{{Dereference of null pointer (loaded from variable 'p')}}
61 }();
62
Ted Kremenek7fa9b4f2012-06-01 20:04:04 +000063}
64
65void test_block_ret() {
Jordan Rose9abf1b42013-03-01 19:45:10 +000066 int *p = ^int*(){ // expected-note {{Calling anonymous block}} expected-note{{Returning to caller}} expected-note {{'p' initialized to a null pointer value}}
Ted Kremenek4238f412013-02-26 19:44:38 +000067 int *q = 0; // expected-note {{'q' initialized to a null pointer value}}
Jordan Rose85e99372012-09-22 01:24:46 +000068 return q; // expected-note {{Returning null pointer (loaded from 'q')}}
69 }();
70 *p = 1; // expected-warning{{Dereference of null pointer (loaded from variable 'p')}} expected-note{{Dereference of null pointer (loaded from variable 'p')}}
Ted Kremenek7fa9b4f2012-06-01 20:04:04 +000071}
72
73void test_block_blockvar() {
74 __block int *p;
Jordan Rose85e99372012-09-22 01:24:46 +000075 ^(){ // expected-note{{Calling anonymous block}} expected-note{{Returning to caller}}
76 p = 0; // expected-note{{Null pointer value stored to 'p'}}
77 }();
78 *p = 1; // expected-warning{{Dereference of null pointer (loaded from variable 'p')}} expected-note{{Dereference of null pointer (loaded from variable 'p')}}
Ted Kremenek7fa9b4f2012-06-01 20:04:04 +000079}
80
81void test_block_arg() {
82 int *p;
Jordan Rose85e99372012-09-22 01:24:46 +000083 ^(int **q){ // expected-note{{Calling anonymous block}} expected-note{{Returning to caller}}
84 *q = 0; // expected-note{{Null pointer value stored to 'p'}}
85 }(&p);
86 *p = 1; // expected-warning{{Dereference of null pointer (loaded from variable 'p')}} expected-note{{Dereference of null pointer (loaded from variable 'p')}}
Ted Kremenek7fa9b4f2012-06-01 20:04:04 +000087}
88
Ted Kremenek4ba86bc2012-03-02 21:16:22 +000089// CHECK: <key>diagnostics</key>
Ted Kremenek0187a1b2012-09-08 04:26:37 +000090// CHECK-NEXT: <array>
91// CHECK-NEXT: <dict>
92// CHECK-NEXT: <key>path</key>
93// CHECK-NEXT: <array>
94// CHECK-NEXT: <dict>
95// CHECK-NEXT: <key>kind</key><string>control</string>
96// CHECK-NEXT: <key>edges</key>
97// CHECK-NEXT: <array>
98// CHECK-NEXT: <dict>
99// CHECK-NEXT: <key>start</key>
100// CHECK-NEXT: <array>
101// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000102// CHECK-NEXT: <key>line</key><integer>12</integer>
103// CHECK-NEXT: <key>col</key><integer>3</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000104// CHECK-NEXT: <key>file</key><integer>0</integer>
105// CHECK-NEXT: </dict>
106// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000107// CHECK-NEXT: <key>line</key><integer>12</integer>
108// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000109// CHECK-NEXT: <key>file</key><integer>0</integer>
110// CHECK-NEXT: </dict>
111// CHECK-NEXT: </array>
112// CHECK-NEXT: <key>end</key>
113// CHECK-NEXT: <array>
114// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000115// CHECK-NEXT: <key>line</key><integer>13</integer>
116// CHECK-NEXT: <key>col</key><integer>3</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000117// CHECK-NEXT: <key>file</key><integer>0</integer>
118// CHECK-NEXT: </dict>
119// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000120// CHECK-NEXT: <key>line</key><integer>13</integer>
121// CHECK-NEXT: <key>col</key><integer>4</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000122// CHECK-NEXT: <key>file</key><integer>0</integer>
123// CHECK-NEXT: </dict>
124// CHECK-NEXT: </array>
125// CHECK-NEXT: </dict>
126// CHECK-NEXT: </array>
127// CHECK-NEXT: </dict>
128// CHECK-NEXT: <dict>
129// CHECK-NEXT: <key>kind</key><string>control</string>
130// CHECK-NEXT: <key>edges</key>
131// CHECK-NEXT: <array>
132// CHECK-NEXT: <dict>
133// CHECK-NEXT: <key>start</key>
134// CHECK-NEXT: <array>
135// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000136// CHECK-NEXT: <key>line</key><integer>13</integer>
137// CHECK-NEXT: <key>col</key><integer>3</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000138// CHECK-NEXT: <key>file</key><integer>0</integer>
139// CHECK-NEXT: </dict>
140// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000141// CHECK-NEXT: <key>line</key><integer>13</integer>
142// CHECK-NEXT: <key>col</key><integer>4</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000143// CHECK-NEXT: <key>file</key><integer>0</integer>
144// CHECK-NEXT: </dict>
145// CHECK-NEXT: </array>
146// CHECK-NEXT: <key>end</key>
147// CHECK-NEXT: <array>
148// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000149// CHECK-NEXT: <key>line</key><integer>13</integer>
150// CHECK-NEXT: <key>col</key><integer>7</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000151// CHECK-NEXT: <key>file</key><integer>0</integer>
152// CHECK-NEXT: </dict>
153// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000154// CHECK-NEXT: <key>line</key><integer>13</integer>
155// CHECK-NEXT: <key>col</key><integer>7</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000156// CHECK-NEXT: <key>file</key><integer>0</integer>
157// CHECK-NEXT: </dict>
158// CHECK-NEXT: </array>
159// CHECK-NEXT: </dict>
160// CHECK-NEXT: </array>
161// CHECK-NEXT: </dict>
162// CHECK-NEXT: <dict>
163// CHECK-NEXT: <key>kind</key><string>event</string>
164// CHECK-NEXT: <key>location</key>
165// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000166// CHECK-NEXT: <key>line</key><integer>13</integer>
167// CHECK-NEXT: <key>col</key><integer>7</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000168// CHECK-NEXT: <key>file</key><integer>0</integer>
169// CHECK-NEXT: </dict>
170// CHECK-NEXT: <key>ranges</key>
171// CHECK-NEXT: <array>
172// CHECK-NEXT: <array>
173// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000174// CHECK-NEXT: <key>line</key><integer>13</integer>
175// CHECK-NEXT: <key>col</key><integer>7</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000176// CHECK-NEXT: <key>file</key><integer>0</integer>
177// CHECK-NEXT: </dict>
178// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000179// CHECK-NEXT: <key>line</key><integer>13</integer>
180// CHECK-NEXT: <key>col</key><integer>12</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000181// CHECK-NEXT: <key>file</key><integer>0</integer>
182// CHECK-NEXT: </dict>
183// CHECK-NEXT: </array>
184// CHECK-NEXT: </array>
185// CHECK-NEXT: <key>depth</key><integer>0</integer>
186// CHECK-NEXT: <key>extended_message</key>
187// CHECK-NEXT: <string>Assuming &apos;x&apos; is equal to 0</string>
188// CHECK-NEXT: <key>message</key>
Jordan Rose85e99372012-09-22 01:24:46 +0000189// CHECK-NEXT: <string>Assuming &apos;x&apos; is equal to 0</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000190// CHECK-NEXT: </dict>
191// CHECK-NEXT: <dict>
192// CHECK-NEXT: <key>kind</key><string>control</string>
193// CHECK-NEXT: <key>edges</key>
194// CHECK-NEXT: <array>
195// CHECK-NEXT: <dict>
196// CHECK-NEXT: <key>start</key>
197// CHECK-NEXT: <array>
198// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000199// CHECK-NEXT: <key>line</key><integer>13</integer>
200// CHECK-NEXT: <key>col</key><integer>7</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000201// CHECK-NEXT: <key>file</key><integer>0</integer>
202// CHECK-NEXT: </dict>
203// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000204// CHECK-NEXT: <key>line</key><integer>13</integer>
205// CHECK-NEXT: <key>col</key><integer>7</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000206// CHECK-NEXT: <key>file</key><integer>0</integer>
207// CHECK-NEXT: </dict>
208// CHECK-NEXT: </array>
209// CHECK-NEXT: <key>end</key>
210// CHECK-NEXT: <array>
211// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000212// CHECK-NEXT: <key>line</key><integer>18</integer>
213// CHECK-NEXT: <key>col</key><integer>3</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000214// CHECK-NEXT: <key>file</key><integer>0</integer>
215// CHECK-NEXT: </dict>
216// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000217// CHECK-NEXT: <key>line</key><integer>18</integer>
218// CHECK-NEXT: <key>col</key><integer>8</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000219// CHECK-NEXT: <key>file</key><integer>0</integer>
220// CHECK-NEXT: </dict>
221// CHECK-NEXT: </array>
222// CHECK-NEXT: </dict>
223// CHECK-NEXT: </array>
224// CHECK-NEXT: </dict>
225// CHECK-NEXT: <dict>
226// CHECK-NEXT: <key>kind</key><string>control</string>
227// CHECK-NEXT: <key>edges</key>
228// CHECK-NEXT: <array>
229// CHECK-NEXT: <dict>
230// CHECK-NEXT: <key>start</key>
231// CHECK-NEXT: <array>
232// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000233// CHECK-NEXT: <key>line</key><integer>18</integer>
234// CHECK-NEXT: <key>col</key><integer>3</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000235// CHECK-NEXT: <key>file</key><integer>0</integer>
236// CHECK-NEXT: </dict>
237// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000238// CHECK-NEXT: <key>line</key><integer>18</integer>
239// CHECK-NEXT: <key>col</key><integer>8</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000240// CHECK-NEXT: <key>file</key><integer>0</integer>
241// CHECK-NEXT: </dict>
242// CHECK-NEXT: </array>
243// CHECK-NEXT: <key>end</key>
244// CHECK-NEXT: <array>
245// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000246// CHECK-NEXT: <key>line</key><integer>18</integer>
Anna Zaks0f857922013-04-23 23:57:43 +0000247// CHECK-NEXT: <key>col</key><integer>11</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000248// CHECK-NEXT: <key>file</key><integer>0</integer>
249// CHECK-NEXT: </dict>
250// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000251// CHECK-NEXT: <key>line</key><integer>18</integer>
Anna Zaks0f857922013-04-23 23:57:43 +0000252// CHECK-NEXT: <key>col</key><integer>11</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000253// CHECK-NEXT: <key>file</key><integer>0</integer>
254// CHECK-NEXT: </dict>
255// CHECK-NEXT: </array>
256// CHECK-NEXT: </dict>
257// CHECK-NEXT: </array>
258// CHECK-NEXT: </dict>
259// CHECK-NEXT: <dict>
260// CHECK-NEXT: <key>kind</key><string>event</string>
261// CHECK-NEXT: <key>location</key>
262// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000263// CHECK-NEXT: <key>line</key><integer>18</integer>
Anna Zaks0f857922013-04-23 23:57:43 +0000264// CHECK-NEXT: <key>col</key><integer>11</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000265// CHECK-NEXT: <key>file</key><integer>0</integer>
266// CHECK-NEXT: </dict>
267// CHECK-NEXT: <key>ranges</key>
268// CHECK-NEXT: <array>
269// CHECK-NEXT: <array>
270// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000271// CHECK-NEXT: <key>line</key><integer>18</integer>
272// CHECK-NEXT: <key>col</key><integer>10</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000273// CHECK-NEXT: <key>file</key><integer>0</integer>
274// CHECK-NEXT: </dict>
275// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000276// CHECK-NEXT: <key>line</key><integer>18</integer>
277// CHECK-NEXT: <key>col</key><integer>12</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000278// CHECK-NEXT: <key>file</key><integer>0</integer>
279// CHECK-NEXT: </dict>
280// CHECK-NEXT: </array>
281// CHECK-NEXT: </array>
282// CHECK-NEXT: <key>depth</key><integer>0</integer>
283// CHECK-NEXT: <key>extended_message</key>
284// CHECK-NEXT: <string>Division by zero</string>
285// CHECK-NEXT: <key>message</key>
Jordan Rose85e99372012-09-22 01:24:46 +0000286// CHECK-NEXT: <string>Division by zero</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000287// CHECK-NEXT: </dict>
288// CHECK-NEXT: </array>
289// CHECK-NEXT: <key>description</key><string>Division by zero</string>
290// CHECK-NEXT: <key>category</key><string>Logic error</string>
291// CHECK-NEXT: <key>type</key><string>Division by zero</string>
Stephen Hines0e2c34f2015-03-23 12:09:02 -0700292// CHECK-NEXT: <key>check_name</key><string>core.DivideZero</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000293// CHECK-NEXT: <key>issue_context_kind</key><string>function</string>
294// CHECK-NEXT: <key>issue_context</key><string>foo</string>
Anna Zaksc1c6a492013-01-08 00:25:22 +0000295// CHECK-NEXT: <key>issue_hash</key><string>7</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000296// CHECK-NEXT: <key>location</key>
297// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000298// CHECK-NEXT: <key>line</key><integer>18</integer>
Anna Zaks0f857922013-04-23 23:57:43 +0000299// CHECK-NEXT: <key>col</key><integer>11</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000300// CHECK-NEXT: <key>file</key><integer>0</integer>
301// CHECK-NEXT: </dict>
302// CHECK-NEXT: </dict>
303// CHECK-NEXT: <dict>
304// CHECK-NEXT: <key>path</key>
305// CHECK-NEXT: <array>
306// CHECK-NEXT: <dict>
307// CHECK-NEXT: <key>kind</key><string>control</string>
308// CHECK-NEXT: <key>edges</key>
309// CHECK-NEXT: <array>
310// CHECK-NEXT: <dict>
311// CHECK-NEXT: <key>start</key>
312// CHECK-NEXT: <array>
313// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000314// CHECK-NEXT: <key>line</key><integer>27</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000315// CHECK-NEXT: <key>col</key><integer>3</integer>
316// CHECK-NEXT: <key>file</key><integer>0</integer>
317// CHECK-NEXT: </dict>
318// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000319// CHECK-NEXT: <key>line</key><integer>27</integer>
320// CHECK-NEXT: <key>col</key><integer>9</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000321// CHECK-NEXT: <key>file</key><integer>0</integer>
322// CHECK-NEXT: </dict>
323// CHECK-NEXT: </array>
324// CHECK-NEXT: <key>end</key>
325// CHECK-NEXT: <array>
326// CHECK-NEXT: <dict>
327// CHECK-NEXT: <key>line</key><integer>27</integer>
Jordan Rose85e99372012-09-22 01:24:46 +0000328// CHECK-NEXT: <key>col</key><integer>11</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000329// CHECK-NEXT: <key>file</key><integer>0</integer>
330// CHECK-NEXT: </dict>
331// CHECK-NEXT: <dict>
332// CHECK-NEXT: <key>line</key><integer>27</integer>
Jordan Rose85e99372012-09-22 01:24:46 +0000333// CHECK-NEXT: <key>col</key><integer>11</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000334// CHECK-NEXT: <key>file</key><integer>0</integer>
335// CHECK-NEXT: </dict>
336// CHECK-NEXT: </array>
337// CHECK-NEXT: </dict>
338// CHECK-NEXT: </array>
339// CHECK-NEXT: </dict>
340// CHECK-NEXT: <dict>
341// CHECK-NEXT: <key>kind</key><string>event</string>
342// CHECK-NEXT: <key>location</key>
343// CHECK-NEXT: <dict>
344// CHECK-NEXT: <key>line</key><integer>27</integer>
Jordan Rose85e99372012-09-22 01:24:46 +0000345// CHECK-NEXT: <key>col</key><integer>11</integer>
346// CHECK-NEXT: <key>file</key><integer>0</integer>
347// CHECK-NEXT: </dict>
348// CHECK-NEXT: <key>ranges</key>
349// CHECK-NEXT: <array>
350// CHECK-NEXT: <array>
351// CHECK-NEXT: <dict>
352// CHECK-NEXT: <key>line</key><integer>27</integer>
353// CHECK-NEXT: <key>col</key><integer>11</integer>
354// CHECK-NEXT: <key>file</key><integer>0</integer>
355// CHECK-NEXT: </dict>
356// CHECK-NEXT: <dict>
357// CHECK-NEXT: <key>line</key><integer>27</integer>
358// CHECK-NEXT: <key>col</key><integer>11</integer>
359// CHECK-NEXT: <key>file</key><integer>0</integer>
360// CHECK-NEXT: </dict>
361// CHECK-NEXT: </array>
362// CHECK-NEXT: </array>
363// CHECK-NEXT: <key>depth</key><integer>0</integer>
364// CHECK-NEXT: <key>extended_message</key>
365// CHECK-NEXT: <string>Passing null pointer value via 1st parameter &apos;p&apos;</string>
366// CHECK-NEXT: <key>message</key>
367// CHECK-NEXT: <string>Passing null pointer value via 1st parameter &apos;p&apos;</string>
368// CHECK-NEXT: </dict>
369// CHECK-NEXT: <dict>
370// CHECK-NEXT: <key>kind</key><string>event</string>
371// CHECK-NEXT: <key>location</key>
372// CHECK-NEXT: <dict>
373// CHECK-NEXT: <key>line</key><integer>27</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000374// CHECK-NEXT: <key>col</key><integer>3</integer>
375// CHECK-NEXT: <key>file</key><integer>0</integer>
376// CHECK-NEXT: </dict>
377// CHECK-NEXT: <key>ranges</key>
378// CHECK-NEXT: <array>
379// CHECK-NEXT: <array>
380// CHECK-NEXT: <dict>
381// CHECK-NEXT: <key>line</key><integer>27</integer>
Jordan Rose85e99372012-09-22 01:24:46 +0000382// CHECK-NEXT: <key>col</key><integer>3</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000383// CHECK-NEXT: <key>file</key><integer>0</integer>
384// CHECK-NEXT: </dict>
385// CHECK-NEXT: <dict>
386// CHECK-NEXT: <key>line</key><integer>27</integer>
Jordan Rose85e99372012-09-22 01:24:46 +0000387// CHECK-NEXT: <key>col</key><integer>12</integer>
388// CHECK-NEXT: <key>file</key><integer>0</integer>
389// CHECK-NEXT: </dict>
390// CHECK-NEXT: </array>
391// CHECK-NEXT: </array>
392// CHECK-NEXT: <key>depth</key><integer>0</integer>
393// CHECK-NEXT: <key>extended_message</key>
394// CHECK-NEXT: <string>Calling &apos;has_bug&apos;</string>
395// CHECK-NEXT: <key>message</key>
396// CHECK-NEXT: <string>Calling &apos;has_bug&apos;</string>
397// CHECK-NEXT: </dict>
398// CHECK-NEXT: <dict>
399// CHECK-NEXT: <key>kind</key><string>event</string>
400// CHECK-NEXT: <key>location</key>
401// CHECK-NEXT: <dict>
402// CHECK-NEXT: <key>line</key><integer>22</integer>
403// CHECK-NEXT: <key>col</key><integer>1</integer>
404// CHECK-NEXT: <key>file</key><integer>0</integer>
405// CHECK-NEXT: </dict>
406// CHECK-NEXT: <key>depth</key><integer>1</integer>
407// CHECK-NEXT: <key>extended_message</key>
408// CHECK-NEXT: <string>Entered call from &apos;test_has_bug&apos;</string>
409// CHECK-NEXT: <key>message</key>
410// CHECK-NEXT: <string>Entered call from &apos;test_has_bug&apos;</string>
411// CHECK-NEXT: </dict>
412// CHECK-NEXT: <dict>
413// CHECK-NEXT: <key>kind</key><string>control</string>
414// CHECK-NEXT: <key>edges</key>
415// CHECK-NEXT: <array>
416// CHECK-NEXT: <dict>
417// CHECK-NEXT: <key>start</key>
418// CHECK-NEXT: <array>
419// CHECK-NEXT: <dict>
420// CHECK-NEXT: <key>line</key><integer>22</integer>
421// CHECK-NEXT: <key>col</key><integer>1</integer>
422// CHECK-NEXT: <key>file</key><integer>0</integer>
423// CHECK-NEXT: </dict>
424// CHECK-NEXT: <dict>
425// CHECK-NEXT: <key>line</key><integer>22</integer>
426// CHECK-NEXT: <key>col</key><integer>4</integer>
427// CHECK-NEXT: <key>file</key><integer>0</integer>
428// CHECK-NEXT: </dict>
429// CHECK-NEXT: </array>
430// CHECK-NEXT: <key>end</key>
431// CHECK-NEXT: <array>
432// CHECK-NEXT: <dict>
433// CHECK-NEXT: <key>line</key><integer>23</integer>
434// CHECK-NEXT: <key>col</key><integer>3</integer>
435// CHECK-NEXT: <key>file</key><integer>0</integer>
436// CHECK-NEXT: </dict>
437// CHECK-NEXT: <dict>
438// CHECK-NEXT: <key>line</key><integer>23</integer>
439// CHECK-NEXT: <key>col</key><integer>3</integer>
440// CHECK-NEXT: <key>file</key><integer>0</integer>
441// CHECK-NEXT: </dict>
442// CHECK-NEXT: </array>
443// CHECK-NEXT: </dict>
444// CHECK-NEXT: </array>
445// CHECK-NEXT: </dict>
446// CHECK-NEXT: <dict>
Anna Zaks0f857922013-04-23 23:57:43 +0000447// CHECK-NEXT: <key>kind</key><string>control</string>
448// CHECK-NEXT: <key>edges</key>
449// CHECK-NEXT: <array>
450// CHECK-NEXT: <dict>
451// CHECK-NEXT: <key>start</key>
452// CHECK-NEXT: <array>
453// CHECK-NEXT: <dict>
454// CHECK-NEXT: <key>line</key><integer>23</integer>
455// CHECK-NEXT: <key>col</key><integer>3</integer>
456// CHECK-NEXT: <key>file</key><integer>0</integer>
457// CHECK-NEXT: </dict>
458// CHECK-NEXT: <dict>
459// CHECK-NEXT: <key>line</key><integer>23</integer>
460// CHECK-NEXT: <key>col</key><integer>3</integer>
461// CHECK-NEXT: <key>file</key><integer>0</integer>
462// CHECK-NEXT: </dict>
463// CHECK-NEXT: </array>
464// CHECK-NEXT: <key>end</key>
465// CHECK-NEXT: <array>
466// CHECK-NEXT: <dict>
467// CHECK-NEXT: <key>line</key><integer>23</integer>
468// CHECK-NEXT: <key>col</key><integer>6</integer>
469// CHECK-NEXT: <key>file</key><integer>0</integer>
470// CHECK-NEXT: </dict>
471// CHECK-NEXT: <dict>
472// CHECK-NEXT: <key>line</key><integer>23</integer>
473// CHECK-NEXT: <key>col</key><integer>6</integer>
474// CHECK-NEXT: <key>file</key><integer>0</integer>
475// CHECK-NEXT: </dict>
476// CHECK-NEXT: </array>
477// CHECK-NEXT: </dict>
478// CHECK-NEXT: </array>
479// CHECK-NEXT: </dict>
480// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000481// CHECK-NEXT: <key>kind</key><string>event</string>
482// CHECK-NEXT: <key>location</key>
483// CHECK-NEXT: <dict>
484// CHECK-NEXT: <key>line</key><integer>23</integer>
Anna Zaks0f857922013-04-23 23:57:43 +0000485// CHECK-NEXT: <key>col</key><integer>6</integer>
Jordan Rose85e99372012-09-22 01:24:46 +0000486// CHECK-NEXT: <key>file</key><integer>0</integer>
487// CHECK-NEXT: </dict>
488// CHECK-NEXT: <key>ranges</key>
489// CHECK-NEXT: <array>
490// CHECK-NEXT: <array>
491// CHECK-NEXT: <dict>
492// CHECK-NEXT: <key>line</key><integer>23</integer>
493// CHECK-NEXT: <key>col</key><integer>4</integer>
494// CHECK-NEXT: <key>file</key><integer>0</integer>
495// CHECK-NEXT: </dict>
496// CHECK-NEXT: <dict>
497// CHECK-NEXT: <key>line</key><integer>23</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000498// CHECK-NEXT: <key>col</key><integer>4</integer>
499// CHECK-NEXT: <key>file</key><integer>0</integer>
500// CHECK-NEXT: </dict>
501// CHECK-NEXT: </array>
502// CHECK-NEXT: </array>
503// CHECK-NEXT: <key>depth</key><integer>1</integer>
504// CHECK-NEXT: <key>extended_message</key>
505// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
506// CHECK-NEXT: <key>message</key>
Jordan Rose85e99372012-09-22 01:24:46 +0000507// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
508// CHECK-NEXT: </dict>
509// CHECK-NEXT: </array>
510// CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
511// CHECK-NEXT: <key>category</key><string>Logic error</string>
512// CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string>
Stephen Hines0e2c34f2015-03-23 12:09:02 -0700513// CHECK-NEXT: <key>check_name</key><string>core.NullDereference</string>
Jordan Rose85e99372012-09-22 01:24:46 +0000514// CHECK-NEXT: <key>issue_context_kind</key><string>function</string>
515// CHECK-NEXT: <key>issue_context</key><string>has_bug</string>
Anna Zaksc1c6a492013-01-08 00:25:22 +0000516// CHECK-NEXT: <key>issue_hash</key><string>1</string>
Jordan Rose85e99372012-09-22 01:24:46 +0000517// CHECK-NEXT: <key>location</key>
518// CHECK-NEXT: <dict>
519// CHECK-NEXT: <key>line</key><integer>23</integer>
Anna Zaks0f857922013-04-23 23:57:43 +0000520// CHECK-NEXT: <key>col</key><integer>6</integer>
Jordan Rose85e99372012-09-22 01:24:46 +0000521// CHECK-NEXT: <key>file</key><integer>0</integer>
522// CHECK-NEXT: </dict>
523// CHECK-NEXT: </dict>
524// CHECK-NEXT: <dict>
525// CHECK-NEXT: <key>path</key>
526// CHECK-NEXT: <array>
527// CHECK-NEXT: <dict>
528// CHECK-NEXT: <key>kind</key><string>control</string>
529// CHECK-NEXT: <key>edges</key>
530// CHECK-NEXT: <array>
531// CHECK-NEXT: <dict>
532// CHECK-NEXT: <key>start</key>
533// CHECK-NEXT: <array>
534// CHECK-NEXT: <dict>
535// CHECK-NEXT: <key>line</key><integer>39</integer>
536// CHECK-NEXT: <key>col</key><integer>3</integer>
537// CHECK-NEXT: <key>file</key><integer>0</integer>
538// CHECK-NEXT: </dict>
539// CHECK-NEXT: <dict>
540// CHECK-NEXT: <key>line</key><integer>39</integer>
541// CHECK-NEXT: <key>col</key><integer>4</integer>
542// CHECK-NEXT: <key>file</key><integer>0</integer>
543// CHECK-NEXT: </dict>
544// CHECK-NEXT: </array>
545// CHECK-NEXT: <key>end</key>
546// CHECK-NEXT: <array>
547// CHECK-NEXT: <dict>
548// CHECK-NEXT: <key>line</key><integer>39</integer>
549// CHECK-NEXT: <key>col</key><integer>8</integer>
550// CHECK-NEXT: <key>file</key><integer>0</integer>
551// CHECK-NEXT: </dict>
552// CHECK-NEXT: <dict>
553// CHECK-NEXT: <key>line</key><integer>39</integer>
554// CHECK-NEXT: <key>col</key><integer>8</integer>
555// CHECK-NEXT: <key>file</key><integer>0</integer>
556// CHECK-NEXT: </dict>
557// CHECK-NEXT: </array>
558// CHECK-NEXT: </dict>
559// CHECK-NEXT: </array>
560// CHECK-NEXT: </dict>
561// CHECK-NEXT: <dict>
562// CHECK-NEXT: <key>kind</key><string>event</string>
563// CHECK-NEXT: <key>location</key>
564// CHECK-NEXT: <dict>
565// CHECK-NEXT: <key>line</key><integer>39</integer>
566// CHECK-NEXT: <key>col</key><integer>8</integer>
567// CHECK-NEXT: <key>file</key><integer>0</integer>
568// CHECK-NEXT: </dict>
569// CHECK-NEXT: <key>ranges</key>
570// CHECK-NEXT: <array>
571// CHECK-NEXT: <array>
572// CHECK-NEXT: <dict>
573// CHECK-NEXT: <key>line</key><integer>39</integer>
574// CHECK-NEXT: <key>col</key><integer>8</integer>
575// CHECK-NEXT: <key>file</key><integer>0</integer>
576// CHECK-NEXT: </dict>
577// CHECK-NEXT: <dict>
578// CHECK-NEXT: <key>line</key><integer>39</integer>
579// CHECK-NEXT: <key>col</key><integer>9</integer>
580// CHECK-NEXT: <key>file</key><integer>0</integer>
581// CHECK-NEXT: </dict>
582// CHECK-NEXT: </array>
583// CHECK-NEXT: </array>
584// CHECK-NEXT: <key>depth</key><integer>0</integer>
585// CHECK-NEXT: <key>extended_message</key>
586// CHECK-NEXT: <string>Assuming &apos;p&apos; is null</string>
587// CHECK-NEXT: <key>message</key>
588// CHECK-NEXT: <string>Assuming &apos;p&apos; is null</string>
589// CHECK-NEXT: </dict>
590// CHECK-NEXT: <dict>
591// CHECK-NEXT: <key>kind</key><string>control</string>
592// CHECK-NEXT: <key>edges</key>
593// CHECK-NEXT: <array>
594// CHECK-NEXT: <dict>
595// CHECK-NEXT: <key>start</key>
596// CHECK-NEXT: <array>
597// CHECK-NEXT: <dict>
598// CHECK-NEXT: <key>line</key><integer>39</integer>
599// CHECK-NEXT: <key>col</key><integer>8</integer>
600// CHECK-NEXT: <key>file</key><integer>0</integer>
601// CHECK-NEXT: </dict>
602// CHECK-NEXT: <dict>
603// CHECK-NEXT: <key>line</key><integer>39</integer>
604// CHECK-NEXT: <key>col</key><integer>8</integer>
605// CHECK-NEXT: <key>file</key><integer>0</integer>
606// CHECK-NEXT: </dict>
607// CHECK-NEXT: </array>
608// CHECK-NEXT: <key>end</key>
609// CHECK-NEXT: <array>
610// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000611// CHECK-NEXT: <key>line</key><integer>45</integer>
Jordan Rose85e99372012-09-22 01:24:46 +0000612// CHECK-NEXT: <key>col</key><integer>3</integer>
613// CHECK-NEXT: <key>file</key><integer>0</integer>
614// CHECK-NEXT: </dict>
615// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000616// CHECK-NEXT: <key>line</key><integer>45</integer>
Jordan Rose85e99372012-09-22 01:24:46 +0000617// CHECK-NEXT: <key>col</key><integer>4</integer>
618// CHECK-NEXT: <key>file</key><integer>0</integer>
619// CHECK-NEXT: </dict>
620// CHECK-NEXT: </array>
621// CHECK-NEXT: </dict>
622// CHECK-NEXT: </array>
623// CHECK-NEXT: </dict>
624// CHECK-NEXT: <dict>
625// CHECK-NEXT: <key>kind</key><string>control</string>
626// CHECK-NEXT: <key>edges</key>
627// CHECK-NEXT: <array>
628// CHECK-NEXT: <dict>
629// CHECK-NEXT: <key>start</key>
630// CHECK-NEXT: <array>
631// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000632// CHECK-NEXT: <key>line</key><integer>45</integer>
Jordan Rose85e99372012-09-22 01:24:46 +0000633// CHECK-NEXT: <key>col</key><integer>3</integer>
634// CHECK-NEXT: <key>file</key><integer>0</integer>
635// CHECK-NEXT: </dict>
636// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000637// CHECK-NEXT: <key>line</key><integer>45</integer>
Jordan Rose85e99372012-09-22 01:24:46 +0000638// CHECK-NEXT: <key>col</key><integer>4</integer>
639// CHECK-NEXT: <key>file</key><integer>0</integer>
640// CHECK-NEXT: </dict>
641// CHECK-NEXT: </array>
642// CHECK-NEXT: <key>end</key>
643// CHECK-NEXT: <array>
644// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000645// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose85e99372012-09-22 01:24:46 +0000646// CHECK-NEXT: <key>col</key><integer>5</integer>
647// CHECK-NEXT: <key>file</key><integer>0</integer>
648// CHECK-NEXT: </dict>
649// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000650// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose85e99372012-09-22 01:24:46 +0000651// CHECK-NEXT: <key>col</key><integer>16</integer>
652// CHECK-NEXT: <key>file</key><integer>0</integer>
653// CHECK-NEXT: </dict>
654// CHECK-NEXT: </array>
655// CHECK-NEXT: </dict>
656// CHECK-NEXT: </array>
657// CHECK-NEXT: </dict>
658// CHECK-NEXT: <dict>
659// CHECK-NEXT: <key>kind</key><string>control</string>
660// CHECK-NEXT: <key>edges</key>
661// CHECK-NEXT: <array>
662// CHECK-NEXT: <dict>
663// CHECK-NEXT: <key>start</key>
664// CHECK-NEXT: <array>
665// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000666// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose85e99372012-09-22 01:24:46 +0000667// CHECK-NEXT: <key>col</key><integer>5</integer>
668// CHECK-NEXT: <key>file</key><integer>0</integer>
669// CHECK-NEXT: </dict>
670// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000671// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose85e99372012-09-22 01:24:46 +0000672// CHECK-NEXT: <key>col</key><integer>16</integer>
673// CHECK-NEXT: <key>file</key><integer>0</integer>
674// CHECK-NEXT: </dict>
675// CHECK-NEXT: </array>
676// CHECK-NEXT: <key>end</key>
677// CHECK-NEXT: <array>
678// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000679// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose85e99372012-09-22 01:24:46 +0000680// CHECK-NEXT: <key>col</key><integer>18</integer>
681// CHECK-NEXT: <key>file</key><integer>0</integer>
682// CHECK-NEXT: </dict>
683// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000684// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose85e99372012-09-22 01:24:46 +0000685// CHECK-NEXT: <key>col</key><integer>18</integer>
686// CHECK-NEXT: <key>file</key><integer>0</integer>
687// CHECK-NEXT: </dict>
688// CHECK-NEXT: </array>
689// CHECK-NEXT: </dict>
690// CHECK-NEXT: </array>
691// CHECK-NEXT: </dict>
692// CHECK-NEXT: <dict>
693// CHECK-NEXT: <key>kind</key><string>event</string>
694// CHECK-NEXT: <key>location</key>
695// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000696// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose85e99372012-09-22 01:24:46 +0000697// CHECK-NEXT: <key>col</key><integer>18</integer>
698// CHECK-NEXT: <key>file</key><integer>0</integer>
699// CHECK-NEXT: </dict>
700// CHECK-NEXT: <key>ranges</key>
701// CHECK-NEXT: <array>
702// CHECK-NEXT: <array>
703// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000704// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose85e99372012-09-22 01:24:46 +0000705// CHECK-NEXT: <key>col</key><integer>18</integer>
706// CHECK-NEXT: <key>file</key><integer>0</integer>
707// CHECK-NEXT: </dict>
708// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000709// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose85e99372012-09-22 01:24:46 +0000710// CHECK-NEXT: <key>col</key><integer>18</integer>
711// CHECK-NEXT: <key>file</key><integer>0</integer>
712// CHECK-NEXT: </dict>
713// CHECK-NEXT: </array>
714// CHECK-NEXT: </array>
715// CHECK-NEXT: <key>depth</key><integer>0</integer>
716// CHECK-NEXT: <key>extended_message</key>
717// CHECK-NEXT: <string>Passing null pointer value via 1st parameter &apos;p&apos;</string>
718// CHECK-NEXT: <key>message</key>
719// CHECK-NEXT: <string>Passing null pointer value via 1st parameter &apos;p&apos;</string>
720// CHECK-NEXT: </dict>
721// CHECK-NEXT: <dict>
722// CHECK-NEXT: <key>kind</key><string>event</string>
723// CHECK-NEXT: <key>location</key>
724// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000725// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose85e99372012-09-22 01:24:46 +0000726// CHECK-NEXT: <key>col</key><integer>5</integer>
727// CHECK-NEXT: <key>file</key><integer>0</integer>
728// CHECK-NEXT: </dict>
729// CHECK-NEXT: <key>ranges</key>
730// CHECK-NEXT: <array>
731// CHECK-NEXT: <array>
732// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000733// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose85e99372012-09-22 01:24:46 +0000734// CHECK-NEXT: <key>col</key><integer>5</integer>
735// CHECK-NEXT: <key>file</key><integer>0</integer>
736// CHECK-NEXT: </dict>
737// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000738// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose85e99372012-09-22 01:24:46 +0000739// CHECK-NEXT: <key>col</key><integer>19</integer>
740// CHECK-NEXT: <key>file</key><integer>0</integer>
741// CHECK-NEXT: </dict>
742// CHECK-NEXT: </array>
743// CHECK-NEXT: </array>
744// CHECK-NEXT: <key>depth</key><integer>0</integer>
745// CHECK-NEXT: <key>extended_message</key>
746// CHECK-NEXT: <string>Calling &apos;triggers_bug&apos;</string>
747// CHECK-NEXT: <key>message</key>
748// CHECK-NEXT: <string>Calling &apos;triggers_bug&apos;</string>
749// CHECK-NEXT: </dict>
750// CHECK-NEXT: <dict>
751// CHECK-NEXT: <key>kind</key><string>event</string>
752// CHECK-NEXT: <key>location</key>
753// CHECK-NEXT: <dict>
754// CHECK-NEXT: <key>line</key><integer>32</integer>
755// CHECK-NEXT: <key>col</key><integer>1</integer>
756// CHECK-NEXT: <key>file</key><integer>0</integer>
757// CHECK-NEXT: </dict>
758// CHECK-NEXT: <key>depth</key><integer>1</integer>
759// CHECK-NEXT: <key>extended_message</key>
760// CHECK-NEXT: <string>Entered call from &apos;bar&apos;</string>
761// CHECK-NEXT: <key>message</key>
762// CHECK-NEXT: <string>Entered call from &apos;bar&apos;</string>
763// CHECK-NEXT: </dict>
764// CHECK-NEXT: <dict>
765// CHECK-NEXT: <key>kind</key><string>control</string>
766// CHECK-NEXT: <key>edges</key>
767// CHECK-NEXT: <array>
768// CHECK-NEXT: <dict>
769// CHECK-NEXT: <key>start</key>
770// CHECK-NEXT: <array>
771// CHECK-NEXT: <dict>
772// CHECK-NEXT: <key>line</key><integer>32</integer>
773// CHECK-NEXT: <key>col</key><integer>1</integer>
774// CHECK-NEXT: <key>file</key><integer>0</integer>
775// CHECK-NEXT: </dict>
776// CHECK-NEXT: <dict>
777// CHECK-NEXT: <key>line</key><integer>32</integer>
778// CHECK-NEXT: <key>col</key><integer>4</integer>
779// CHECK-NEXT: <key>file</key><integer>0</integer>
780// CHECK-NEXT: </dict>
781// CHECK-NEXT: </array>
782// CHECK-NEXT: <key>end</key>
783// CHECK-NEXT: <array>
784// CHECK-NEXT: <dict>
785// CHECK-NEXT: <key>line</key><integer>33</integer>
786// CHECK-NEXT: <key>col</key><integer>3</integer>
787// CHECK-NEXT: <key>file</key><integer>0</integer>
788// CHECK-NEXT: </dict>
789// CHECK-NEXT: <dict>
790// CHECK-NEXT: <key>line</key><integer>33</integer>
791// CHECK-NEXT: <key>col</key><integer>3</integer>
792// CHECK-NEXT: <key>file</key><integer>0</integer>
793// CHECK-NEXT: </dict>
794// CHECK-NEXT: </array>
795// CHECK-NEXT: </dict>
796// CHECK-NEXT: </array>
797// CHECK-NEXT: </dict>
798// CHECK-NEXT: <dict>
Anna Zaks0f857922013-04-23 23:57:43 +0000799// CHECK-NEXT: <key>kind</key><string>control</string>
800// CHECK-NEXT: <key>edges</key>
801// CHECK-NEXT: <array>
802// CHECK-NEXT: <dict>
803// CHECK-NEXT: <key>start</key>
804// CHECK-NEXT: <array>
805// CHECK-NEXT: <dict>
806// CHECK-NEXT: <key>line</key><integer>33</integer>
807// CHECK-NEXT: <key>col</key><integer>3</integer>
808// CHECK-NEXT: <key>file</key><integer>0</integer>
809// CHECK-NEXT: </dict>
810// CHECK-NEXT: <dict>
811// CHECK-NEXT: <key>line</key><integer>33</integer>
812// CHECK-NEXT: <key>col</key><integer>3</integer>
813// CHECK-NEXT: <key>file</key><integer>0</integer>
814// CHECK-NEXT: </dict>
815// CHECK-NEXT: </array>
816// CHECK-NEXT: <key>end</key>
817// CHECK-NEXT: <array>
818// CHECK-NEXT: <dict>
819// CHECK-NEXT: <key>line</key><integer>33</integer>
820// CHECK-NEXT: <key>col</key><integer>6</integer>
821// CHECK-NEXT: <key>file</key><integer>0</integer>
822// CHECK-NEXT: </dict>
823// CHECK-NEXT: <dict>
824// CHECK-NEXT: <key>line</key><integer>33</integer>
825// CHECK-NEXT: <key>col</key><integer>6</integer>
826// CHECK-NEXT: <key>file</key><integer>0</integer>
827// CHECK-NEXT: </dict>
828// CHECK-NEXT: </array>
829// CHECK-NEXT: </dict>
830// CHECK-NEXT: </array>
831// CHECK-NEXT: </dict>
832// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000833// CHECK-NEXT: <key>kind</key><string>event</string>
834// CHECK-NEXT: <key>location</key>
835// CHECK-NEXT: <dict>
836// CHECK-NEXT: <key>line</key><integer>33</integer>
Anna Zaks0f857922013-04-23 23:57:43 +0000837// CHECK-NEXT: <key>col</key><integer>6</integer>
Jordan Rose85e99372012-09-22 01:24:46 +0000838// CHECK-NEXT: <key>file</key><integer>0</integer>
839// CHECK-NEXT: </dict>
840// CHECK-NEXT: <key>ranges</key>
841// CHECK-NEXT: <array>
842// CHECK-NEXT: <array>
843// CHECK-NEXT: <dict>
844// CHECK-NEXT: <key>line</key><integer>33</integer>
845// CHECK-NEXT: <key>col</key><integer>4</integer>
846// CHECK-NEXT: <key>file</key><integer>0</integer>
847// CHECK-NEXT: </dict>
848// CHECK-NEXT: <dict>
849// CHECK-NEXT: <key>line</key><integer>33</integer>
850// CHECK-NEXT: <key>col</key><integer>4</integer>
851// CHECK-NEXT: <key>file</key><integer>0</integer>
852// CHECK-NEXT: </dict>
853// CHECK-NEXT: </array>
854// CHECK-NEXT: </array>
855// CHECK-NEXT: <key>depth</key><integer>1</integer>
856// CHECK-NEXT: <key>extended_message</key>
857// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
858// CHECK-NEXT: <key>message</key>
859// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000860// CHECK-NEXT: </dict>
861// CHECK-NEXT: </array>
862// CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
863// CHECK-NEXT: <key>category</key><string>Logic error</string>
864// CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string>
Stephen Hines0e2c34f2015-03-23 12:09:02 -0700865// CHECK-NEXT: <key>check_name</key><string>core.NullDereference</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000866// CHECK-NEXT: <key>issue_context_kind</key><string>function</string>
867// CHECK-NEXT: <key>issue_context</key><string>triggers_bug</string>
Anna Zaksc1c6a492013-01-08 00:25:22 +0000868// CHECK-NEXT: <key>issue_hash</key><string>1</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000869// CHECK-NEXT: <key>location</key>
870// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +0000871// CHECK-NEXT: <key>line</key><integer>33</integer>
Anna Zaks0f857922013-04-23 23:57:43 +0000872// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000873// CHECK-NEXT: <key>file</key><integer>0</integer>
874// CHECK-NEXT: </dict>
875// CHECK-NEXT: </dict>
876// CHECK-NEXT: <dict>
877// CHECK-NEXT: <key>path</key>
878// CHECK-NEXT: <array>
879// CHECK-NEXT: <dict>
880// CHECK-NEXT: <key>kind</key><string>event</string>
881// CHECK-NEXT: <key>location</key>
882// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000883// CHECK-NEXT: <key>line</key><integer>58</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000884// CHECK-NEXT: <key>col</key><integer>3</integer>
885// CHECK-NEXT: <key>file</key><integer>0</integer>
886// CHECK-NEXT: </dict>
887// CHECK-NEXT: <key>ranges</key>
888// CHECK-NEXT: <array>
889// CHECK-NEXT: <array>
890// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000891// CHECK-NEXT: <key>line</key><integer>58</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000892// CHECK-NEXT: <key>col</key><integer>3</integer>
893// CHECK-NEXT: <key>file</key><integer>0</integer>
894// CHECK-NEXT: </dict>
895// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000896// CHECK-NEXT: <key>line</key><integer>58</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000897// CHECK-NEXT: <key>col</key><integer>8</integer>
898// CHECK-NEXT: <key>file</key><integer>0</integer>
899// CHECK-NEXT: </dict>
900// CHECK-NEXT: </array>
901// CHECK-NEXT: </array>
902// CHECK-NEXT: <key>depth</key><integer>0</integer>
903// CHECK-NEXT: <key>extended_message</key>
Ted Kremenek4238f412013-02-26 19:44:38 +0000904// CHECK-NEXT: <string>&apos;p&apos; initialized to a null pointer value</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000905// CHECK-NEXT: <key>message</key>
Ted Kremenek4238f412013-02-26 19:44:38 +0000906// CHECK-NEXT: <string>&apos;p&apos; initialized to a null pointer value</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000907// CHECK-NEXT: </dict>
908// CHECK-NEXT: <dict>
909// CHECK-NEXT: <key>kind</key><string>control</string>
910// CHECK-NEXT: <key>edges</key>
911// CHECK-NEXT: <array>
912// CHECK-NEXT: <dict>
913// CHECK-NEXT: <key>start</key>
914// CHECK-NEXT: <array>
915// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000916// CHECK-NEXT: <key>line</key><integer>58</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000917// CHECK-NEXT: <key>col</key><integer>3</integer>
918// CHECK-NEXT: <key>file</key><integer>0</integer>
919// CHECK-NEXT: </dict>
920// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000921// CHECK-NEXT: <key>line</key><integer>58</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000922// CHECK-NEXT: <key>col</key><integer>5</integer>
923// CHECK-NEXT: <key>file</key><integer>0</integer>
924// CHECK-NEXT: </dict>
925// CHECK-NEXT: </array>
926// CHECK-NEXT: <key>end</key>
927// CHECK-NEXT: <array>
928// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000929// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000930// CHECK-NEXT: <key>col</key><integer>3</integer>
931// CHECK-NEXT: <key>file</key><integer>0</integer>
932// CHECK-NEXT: </dict>
933// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000934// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000935// CHECK-NEXT: <key>col</key><integer>3</integer>
936// CHECK-NEXT: <key>file</key><integer>0</integer>
937// CHECK-NEXT: </dict>
938// CHECK-NEXT: </array>
939// CHECK-NEXT: </dict>
940// CHECK-NEXT: </array>
941// CHECK-NEXT: </dict>
942// CHECK-NEXT: <dict>
943// CHECK-NEXT: <key>kind</key><string>event</string>
944// CHECK-NEXT: <key>location</key>
945// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000946// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000947// CHECK-NEXT: <key>col</key><integer>3</integer>
948// CHECK-NEXT: <key>file</key><integer>0</integer>
949// CHECK-NEXT: </dict>
950// CHECK-NEXT: <key>ranges</key>
951// CHECK-NEXT: <array>
952// CHECK-NEXT: <array>
953// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000954// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000955// CHECK-NEXT: <key>col</key><integer>3</integer>
956// CHECK-NEXT: <key>file</key><integer>0</integer>
957// CHECK-NEXT: </dict>
958// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000959// CHECK-NEXT: <key>line</key><integer>61</integer>
Jordan Rose85e99372012-09-22 01:24:46 +0000960// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000961// CHECK-NEXT: <key>file</key><integer>0</integer>
962// CHECK-NEXT: </dict>
963// CHECK-NEXT: </array>
964// CHECK-NEXT: </array>
965// CHECK-NEXT: <key>depth</key><integer>0</integer>
966// CHECK-NEXT: <key>extended_message</key>
967// CHECK-NEXT: <string>Calling anonymous block</string>
968// CHECK-NEXT: <key>message</key>
Jordan Rose85e99372012-09-22 01:24:46 +0000969// CHECK-NEXT: <string>Calling anonymous block</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000970// CHECK-NEXT: </dict>
971// CHECK-NEXT: <dict>
972// CHECK-NEXT: <key>kind</key><string>event</string>
973// CHECK-NEXT: <key>location</key>
974// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000975// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000976// CHECK-NEXT: <key>col</key><integer>3</integer>
977// CHECK-NEXT: <key>file</key><integer>0</integer>
978// CHECK-NEXT: </dict>
979// CHECK-NEXT: <key>depth</key><integer>1</integer>
980// CHECK-NEXT: <key>extended_message</key>
981// CHECK-NEXT: <string>Entered call from &apos;test_block__capture_null&apos;</string>
982// CHECK-NEXT: <key>message</key>
Jordan Rose85e99372012-09-22 01:24:46 +0000983// CHECK-NEXT: <string>Entered call from &apos;test_block__capture_null&apos;</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000984// CHECK-NEXT: </dict>
985// CHECK-NEXT: <dict>
986// CHECK-NEXT: <key>kind</key><string>control</string>
987// CHECK-NEXT: <key>edges</key>
988// CHECK-NEXT: <array>
989// CHECK-NEXT: <dict>
990// CHECK-NEXT: <key>start</key>
991// CHECK-NEXT: <array>
992// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000993// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000994// CHECK-NEXT: <key>col</key><integer>3</integer>
995// CHECK-NEXT: <key>file</key><integer>0</integer>
996// CHECK-NEXT: </dict>
997// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +0000998// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +0000999// CHECK-NEXT: <key>col</key><integer>3</integer>
1000// CHECK-NEXT: <key>file</key><integer>0</integer>
1001// CHECK-NEXT: </dict>
1002// CHECK-NEXT: </array>
1003// CHECK-NEXT: <key>end</key>
1004// CHECK-NEXT: <array>
1005// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001006// CHECK-NEXT: <key>line</key><integer>60</integer>
Jordan Rose85e99372012-09-22 01:24:46 +00001007// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001008// CHECK-NEXT: <key>file</key><integer>0</integer>
1009// CHECK-NEXT: </dict>
1010// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001011// CHECK-NEXT: <key>line</key><integer>60</integer>
Jordan Rose85e99372012-09-22 01:24:46 +00001012// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001013// CHECK-NEXT: <key>file</key><integer>0</integer>
1014// CHECK-NEXT: </dict>
1015// CHECK-NEXT: </array>
1016// CHECK-NEXT: </dict>
1017// CHECK-NEXT: </array>
1018// CHECK-NEXT: </dict>
1019// CHECK-NEXT: <dict>
Anna Zaks0f857922013-04-23 23:57:43 +00001020// CHECK-NEXT: <key>kind</key><string>control</string>
1021// CHECK-NEXT: <key>edges</key>
1022// CHECK-NEXT: <array>
1023// CHECK-NEXT: <dict>
1024// CHECK-NEXT: <key>start</key>
1025// CHECK-NEXT: <array>
1026// CHECK-NEXT: <dict>
1027// CHECK-NEXT: <key>line</key><integer>60</integer>
1028// CHECK-NEXT: <key>col</key><integer>5</integer>
1029// CHECK-NEXT: <key>file</key><integer>0</integer>
1030// CHECK-NEXT: </dict>
1031// CHECK-NEXT: <dict>
1032// CHECK-NEXT: <key>line</key><integer>60</integer>
1033// CHECK-NEXT: <key>col</key><integer>5</integer>
1034// CHECK-NEXT: <key>file</key><integer>0</integer>
1035// CHECK-NEXT: </dict>
1036// CHECK-NEXT: </array>
1037// CHECK-NEXT: <key>end</key>
1038// CHECK-NEXT: <array>
1039// CHECK-NEXT: <dict>
1040// CHECK-NEXT: <key>line</key><integer>60</integer>
1041// CHECK-NEXT: <key>col</key><integer>8</integer>
1042// CHECK-NEXT: <key>file</key><integer>0</integer>
1043// CHECK-NEXT: </dict>
1044// CHECK-NEXT: <dict>
1045// CHECK-NEXT: <key>line</key><integer>60</integer>
1046// CHECK-NEXT: <key>col</key><integer>8</integer>
1047// CHECK-NEXT: <key>file</key><integer>0</integer>
1048// CHECK-NEXT: </dict>
1049// CHECK-NEXT: </array>
1050// CHECK-NEXT: </dict>
1051// CHECK-NEXT: </array>
1052// CHECK-NEXT: </dict>
1053// CHECK-NEXT: <dict>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001054// CHECK-NEXT: <key>kind</key><string>event</string>
1055// CHECK-NEXT: <key>location</key>
1056// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001057// CHECK-NEXT: <key>line</key><integer>60</integer>
Anna Zaks0f857922013-04-23 23:57:43 +00001058// CHECK-NEXT: <key>col</key><integer>8</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001059// CHECK-NEXT: <key>file</key><integer>0</integer>
1060// CHECK-NEXT: </dict>
1061// CHECK-NEXT: <key>ranges</key>
1062// CHECK-NEXT: <array>
1063// CHECK-NEXT: <array>
1064// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001065// CHECK-NEXT: <key>line</key><integer>60</integer>
Jordan Rose85e99372012-09-22 01:24:46 +00001066// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001067// CHECK-NEXT: <key>file</key><integer>0</integer>
1068// CHECK-NEXT: </dict>
1069// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001070// CHECK-NEXT: <key>line</key><integer>60</integer>
Jordan Rose85e99372012-09-22 01:24:46 +00001071// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001072// CHECK-NEXT: <key>file</key><integer>0</integer>
1073// CHECK-NEXT: </dict>
1074// CHECK-NEXT: </array>
1075// CHECK-NEXT: </array>
1076// CHECK-NEXT: <key>depth</key><integer>1</integer>
1077// CHECK-NEXT: <key>extended_message</key>
1078// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1079// CHECK-NEXT: <key>message</key>
Jordan Rose85e99372012-09-22 01:24:46 +00001080// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001081// CHECK-NEXT: </dict>
1082// CHECK-NEXT: </array>
1083// CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1084// CHECK-NEXT: <key>category</key><string>Logic error</string>
1085// CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string>
Stephen Hines0e2c34f2015-03-23 12:09:02 -07001086// CHECK-NEXT: <key>check_name</key><string>core.NullDereference</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001087// CHECK-NEXT: <key>location</key>
1088// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001089// CHECK-NEXT: <key>line</key><integer>60</integer>
Anna Zaks0f857922013-04-23 23:57:43 +00001090// CHECK-NEXT: <key>col</key><integer>8</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001091// CHECK-NEXT: <key>file</key><integer>0</integer>
1092// CHECK-NEXT: </dict>
1093// CHECK-NEXT: </dict>
1094// CHECK-NEXT: <dict>
1095// CHECK-NEXT: <key>path</key>
1096// CHECK-NEXT: <array>
1097// CHECK-NEXT: <dict>
1098// CHECK-NEXT: <key>kind</key><string>control</string>
1099// CHECK-NEXT: <key>edges</key>
1100// CHECK-NEXT: <array>
1101// CHECK-NEXT: <dict>
1102// CHECK-NEXT: <key>start</key>
1103// CHECK-NEXT: <array>
1104// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001105// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001106// CHECK-NEXT: <key>col</key><integer>3</integer>
1107// CHECK-NEXT: <key>file</key><integer>0</integer>
1108// CHECK-NEXT: </dict>
1109// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001110// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001111// CHECK-NEXT: <key>col</key><integer>5</integer>
1112// CHECK-NEXT: <key>file</key><integer>0</integer>
1113// CHECK-NEXT: </dict>
1114// CHECK-NEXT: </array>
1115// CHECK-NEXT: <key>end</key>
1116// CHECK-NEXT: <array>
1117// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001118// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001119// CHECK-NEXT: <key>col</key><integer>12</integer>
1120// CHECK-NEXT: <key>file</key><integer>0</integer>
1121// CHECK-NEXT: </dict>
1122// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001123// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001124// CHECK-NEXT: <key>col</key><integer>12</integer>
1125// CHECK-NEXT: <key>file</key><integer>0</integer>
1126// CHECK-NEXT: </dict>
1127// CHECK-NEXT: </array>
1128// CHECK-NEXT: </dict>
1129// CHECK-NEXT: </array>
1130// CHECK-NEXT: </dict>
1131// CHECK-NEXT: <dict>
1132// CHECK-NEXT: <key>kind</key><string>event</string>
1133// CHECK-NEXT: <key>location</key>
1134// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001135// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001136// CHECK-NEXT: <key>col</key><integer>12</integer>
1137// CHECK-NEXT: <key>file</key><integer>0</integer>
1138// CHECK-NEXT: </dict>
1139// CHECK-NEXT: <key>ranges</key>
1140// CHECK-NEXT: <array>
1141// CHECK-NEXT: <array>
1142// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001143// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001144// CHECK-NEXT: <key>col</key><integer>12</integer>
1145// CHECK-NEXT: <key>file</key><integer>0</integer>
1146// CHECK-NEXT: </dict>
1147// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001148// CHECK-NEXT: <key>line</key><integer>69</integer>
Jordan Rose85e99372012-09-22 01:24:46 +00001149// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001150// CHECK-NEXT: <key>file</key><integer>0</integer>
1151// CHECK-NEXT: </dict>
1152// CHECK-NEXT: </array>
1153// CHECK-NEXT: </array>
1154// CHECK-NEXT: <key>depth</key><integer>0</integer>
1155// CHECK-NEXT: <key>extended_message</key>
1156// CHECK-NEXT: <string>Calling anonymous block</string>
1157// CHECK-NEXT: <key>message</key>
Jordan Rose85e99372012-09-22 01:24:46 +00001158// CHECK-NEXT: <string>Calling anonymous block</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001159// CHECK-NEXT: </dict>
1160// CHECK-NEXT: <dict>
1161// CHECK-NEXT: <key>kind</key><string>event</string>
1162// CHECK-NEXT: <key>location</key>
1163// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001164// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001165// CHECK-NEXT: <key>col</key><integer>12</integer>
1166// CHECK-NEXT: <key>file</key><integer>0</integer>
1167// CHECK-NEXT: </dict>
1168// CHECK-NEXT: <key>depth</key><integer>1</integer>
1169// CHECK-NEXT: <key>extended_message</key>
1170// CHECK-NEXT: <string>Entered call from &apos;test_block_ret&apos;</string>
1171// CHECK-NEXT: <key>message</key>
Jordan Rose85e99372012-09-22 01:24:46 +00001172// CHECK-NEXT: <string>Entered call from &apos;test_block_ret&apos;</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001173// CHECK-NEXT: </dict>
1174// CHECK-NEXT: <dict>
1175// CHECK-NEXT: <key>kind</key><string>control</string>
1176// CHECK-NEXT: <key>edges</key>
1177// CHECK-NEXT: <array>
1178// CHECK-NEXT: <dict>
1179// CHECK-NEXT: <key>start</key>
1180// CHECK-NEXT: <array>
1181// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001182// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001183// CHECK-NEXT: <key>col</key><integer>12</integer>
1184// CHECK-NEXT: <key>file</key><integer>0</integer>
1185// CHECK-NEXT: </dict>
1186// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001187// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001188// CHECK-NEXT: <key>col</key><integer>12</integer>
1189// CHECK-NEXT: <key>file</key><integer>0</integer>
1190// CHECK-NEXT: </dict>
1191// CHECK-NEXT: </array>
1192// CHECK-NEXT: <key>end</key>
1193// CHECK-NEXT: <array>
1194// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001195// CHECK-NEXT: <key>line</key><integer>67</integer>
1196// CHECK-NEXT: <key>col</key><integer>5</integer>
1197// CHECK-NEXT: <key>file</key><integer>0</integer>
1198// CHECK-NEXT: </dict>
1199// CHECK-NEXT: <dict>
1200// CHECK-NEXT: <key>line</key><integer>67</integer>
1201// CHECK-NEXT: <key>col</key><integer>7</integer>
1202// CHECK-NEXT: <key>file</key><integer>0</integer>
1203// CHECK-NEXT: </dict>
1204// CHECK-NEXT: </array>
1205// CHECK-NEXT: </dict>
1206// CHECK-NEXT: </array>
1207// CHECK-NEXT: </dict>
1208// CHECK-NEXT: <dict>
1209// CHECK-NEXT: <key>kind</key><string>event</string>
1210// CHECK-NEXT: <key>location</key>
1211// CHECK-NEXT: <dict>
1212// CHECK-NEXT: <key>line</key><integer>67</integer>
1213// CHECK-NEXT: <key>col</key><integer>5</integer>
1214// CHECK-NEXT: <key>file</key><integer>0</integer>
1215// CHECK-NEXT: </dict>
1216// CHECK-NEXT: <key>ranges</key>
1217// CHECK-NEXT: <array>
1218// CHECK-NEXT: <array>
1219// CHECK-NEXT: <dict>
1220// CHECK-NEXT: <key>line</key><integer>67</integer>
1221// CHECK-NEXT: <key>col</key><integer>5</integer>
1222// CHECK-NEXT: <key>file</key><integer>0</integer>
1223// CHECK-NEXT: </dict>
1224// CHECK-NEXT: <dict>
1225// CHECK-NEXT: <key>line</key><integer>67</integer>
1226// CHECK-NEXT: <key>col</key><integer>10</integer>
1227// CHECK-NEXT: <key>file</key><integer>0</integer>
1228// CHECK-NEXT: </dict>
1229// CHECK-NEXT: </array>
1230// CHECK-NEXT: </array>
1231// CHECK-NEXT: <key>depth</key><integer>1</integer>
1232// CHECK-NEXT: <key>extended_message</key>
Ted Kremenek4238f412013-02-26 19:44:38 +00001233// CHECK-NEXT: <string>&apos;q&apos; initialized to a null pointer value</string>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001234// CHECK-NEXT: <key>message</key>
Ted Kremenek4238f412013-02-26 19:44:38 +00001235// CHECK-NEXT: <string>&apos;q&apos; initialized to a null pointer value</string>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001236// CHECK-NEXT: </dict>
1237// CHECK-NEXT: <dict>
1238// CHECK-NEXT: <key>kind</key><string>control</string>
1239// CHECK-NEXT: <key>edges</key>
1240// CHECK-NEXT: <array>
1241// CHECK-NEXT: <dict>
1242// CHECK-NEXT: <key>start</key>
1243// CHECK-NEXT: <array>
1244// CHECK-NEXT: <dict>
1245// CHECK-NEXT: <key>line</key><integer>67</integer>
1246// CHECK-NEXT: <key>col</key><integer>5</integer>
1247// CHECK-NEXT: <key>file</key><integer>0</integer>
1248// CHECK-NEXT: </dict>
1249// CHECK-NEXT: <dict>
1250// CHECK-NEXT: <key>line</key><integer>67</integer>
1251// CHECK-NEXT: <key>col</key><integer>7</integer>
1252// CHECK-NEXT: <key>file</key><integer>0</integer>
1253// CHECK-NEXT: </dict>
1254// CHECK-NEXT: </array>
1255// CHECK-NEXT: <key>end</key>
1256// CHECK-NEXT: <array>
1257// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +00001258// CHECK-NEXT: <key>line</key><integer>68</integer>
1259// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001260// CHECK-NEXT: <key>file</key><integer>0</integer>
1261// CHECK-NEXT: </dict>
1262// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +00001263// CHECK-NEXT: <key>line</key><integer>68</integer>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001264// CHECK-NEXT: <key>col</key><integer>10</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001265// CHECK-NEXT: <key>file</key><integer>0</integer>
1266// CHECK-NEXT: </dict>
1267// CHECK-NEXT: </array>
1268// CHECK-NEXT: </dict>
1269// CHECK-NEXT: </array>
1270// CHECK-NEXT: </dict>
1271// CHECK-NEXT: <dict>
1272// CHECK-NEXT: <key>kind</key><string>event</string>
1273// CHECK-NEXT: <key>location</key>
1274// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +00001275// CHECK-NEXT: <key>line</key><integer>68</integer>
1276// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001277// CHECK-NEXT: <key>file</key><integer>0</integer>
1278// CHECK-NEXT: </dict>
1279// CHECK-NEXT: <key>ranges</key>
1280// CHECK-NEXT: <array>
1281// CHECK-NEXT: <array>
1282// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +00001283// CHECK-NEXT: <key>line</key><integer>68</integer>
1284// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001285// CHECK-NEXT: <key>file</key><integer>0</integer>
1286// CHECK-NEXT: </dict>
1287// CHECK-NEXT: <dict>
Jordan Rose85e99372012-09-22 01:24:46 +00001288// CHECK-NEXT: <key>line</key><integer>68</integer>
1289// CHECK-NEXT: <key>col</key><integer>12</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001290// CHECK-NEXT: <key>file</key><integer>0</integer>
1291// CHECK-NEXT: </dict>
1292// CHECK-NEXT: </array>
1293// CHECK-NEXT: </array>
1294// CHECK-NEXT: <key>depth</key><integer>1</integer>
1295// CHECK-NEXT: <key>extended_message</key>
1296// CHECK-NEXT: <string>Returning null pointer (loaded from &apos;q&apos;)</string>
1297// CHECK-NEXT: <key>message</key>
Jordan Rose85e99372012-09-22 01:24:46 +00001298// CHECK-NEXT: <string>Returning null pointer (loaded from &apos;q&apos;)</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001299// CHECK-NEXT: </dict>
1300// CHECK-NEXT: <dict>
1301// CHECK-NEXT: <key>kind</key><string>event</string>
1302// CHECK-NEXT: <key>location</key>
1303// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001304// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001305// CHECK-NEXT: <key>col</key><integer>12</integer>
1306// CHECK-NEXT: <key>file</key><integer>0</integer>
1307// CHECK-NEXT: </dict>
1308// CHECK-NEXT: <key>ranges</key>
1309// CHECK-NEXT: <array>
1310// CHECK-NEXT: <array>
1311// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001312// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001313// CHECK-NEXT: <key>col</key><integer>12</integer>
1314// CHECK-NEXT: <key>file</key><integer>0</integer>
1315// CHECK-NEXT: </dict>
1316// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001317// CHECK-NEXT: <key>line</key><integer>69</integer>
Jordan Rose85e99372012-09-22 01:24:46 +00001318// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001319// CHECK-NEXT: <key>file</key><integer>0</integer>
1320// CHECK-NEXT: </dict>
1321// CHECK-NEXT: </array>
1322// CHECK-NEXT: </array>
Jordan Rose7be22452013-04-12 00:44:17 +00001323// CHECK-NEXT: <key>depth</key><integer>0</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001324// CHECK-NEXT: <key>extended_message</key>
1325// CHECK-NEXT: <string>Returning to caller</string>
1326// CHECK-NEXT: <key>message</key>
Jordan Rose85e99372012-09-22 01:24:46 +00001327// CHECK-NEXT: <string>Returning to caller</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001328// CHECK-NEXT: </dict>
1329// CHECK-NEXT: <dict>
1330// CHECK-NEXT: <key>kind</key><string>control</string>
1331// CHECK-NEXT: <key>edges</key>
1332// CHECK-NEXT: <array>
1333// CHECK-NEXT: <dict>
1334// CHECK-NEXT: <key>start</key>
1335// CHECK-NEXT: <array>
1336// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001337// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001338// CHECK-NEXT: <key>col</key><integer>12</integer>
1339// CHECK-NEXT: <key>file</key><integer>0</integer>
1340// CHECK-NEXT: </dict>
1341// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001342// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001343// CHECK-NEXT: <key>col</key><integer>12</integer>
1344// CHECK-NEXT: <key>file</key><integer>0</integer>
1345// CHECK-NEXT: </dict>
1346// CHECK-NEXT: </array>
1347// CHECK-NEXT: <key>end</key>
1348// CHECK-NEXT: <array>
1349// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001350// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001351// CHECK-NEXT: <key>col</key><integer>3</integer>
1352// CHECK-NEXT: <key>file</key><integer>0</integer>
1353// CHECK-NEXT: </dict>
1354// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001355// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001356// CHECK-NEXT: <key>col</key><integer>5</integer>
1357// CHECK-NEXT: <key>file</key><integer>0</integer>
1358// CHECK-NEXT: </dict>
1359// CHECK-NEXT: </array>
1360// CHECK-NEXT: </dict>
1361// CHECK-NEXT: </array>
1362// CHECK-NEXT: </dict>
1363// CHECK-NEXT: <dict>
1364// CHECK-NEXT: <key>kind</key><string>event</string>
1365// CHECK-NEXT: <key>location</key>
1366// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001367// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001368// CHECK-NEXT: <key>col</key><integer>3</integer>
1369// CHECK-NEXT: <key>file</key><integer>0</integer>
1370// CHECK-NEXT: </dict>
1371// CHECK-NEXT: <key>ranges</key>
1372// CHECK-NEXT: <array>
1373// CHECK-NEXT: <array>
1374// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001375// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001376// CHECK-NEXT: <key>col</key><integer>3</integer>
1377// CHECK-NEXT: <key>file</key><integer>0</integer>
1378// CHECK-NEXT: </dict>
1379// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001380// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001381// CHECK-NEXT: <key>col</key><integer>8</integer>
1382// CHECK-NEXT: <key>file</key><integer>0</integer>
1383// CHECK-NEXT: </dict>
1384// CHECK-NEXT: </array>
1385// CHECK-NEXT: </array>
1386// CHECK-NEXT: <key>depth</key><integer>0</integer>
1387// CHECK-NEXT: <key>extended_message</key>
Ted Kremenek4238f412013-02-26 19:44:38 +00001388// CHECK-NEXT: <string>&apos;p&apos; initialized to a null pointer value</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001389// CHECK-NEXT: <key>message</key>
Ted Kremenek4238f412013-02-26 19:44:38 +00001390// CHECK-NEXT: <string>&apos;p&apos; initialized to a null pointer value</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001391// CHECK-NEXT: </dict>
1392// CHECK-NEXT: <dict>
1393// CHECK-NEXT: <key>kind</key><string>control</string>
1394// CHECK-NEXT: <key>edges</key>
1395// CHECK-NEXT: <array>
1396// CHECK-NEXT: <dict>
1397// CHECK-NEXT: <key>start</key>
1398// CHECK-NEXT: <array>
1399// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001400// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001401// CHECK-NEXT: <key>col</key><integer>3</integer>
1402// CHECK-NEXT: <key>file</key><integer>0</integer>
1403// CHECK-NEXT: </dict>
1404// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001405// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001406// CHECK-NEXT: <key>col</key><integer>5</integer>
1407// CHECK-NEXT: <key>file</key><integer>0</integer>
1408// CHECK-NEXT: </dict>
1409// CHECK-NEXT: </array>
1410// CHECK-NEXT: <key>end</key>
1411// CHECK-NEXT: <array>
1412// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001413// CHECK-NEXT: <key>line</key><integer>70</integer>
Anna Zaks0f857922013-04-23 23:57:43 +00001414// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001415// CHECK-NEXT: <key>file</key><integer>0</integer>
1416// CHECK-NEXT: </dict>
1417// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001418// CHECK-NEXT: <key>line</key><integer>70</integer>
Anna Zaks0f857922013-04-23 23:57:43 +00001419// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001420// CHECK-NEXT: <key>file</key><integer>0</integer>
1421// CHECK-NEXT: </dict>
1422// CHECK-NEXT: </array>
1423// CHECK-NEXT: </dict>
1424// CHECK-NEXT: </array>
1425// CHECK-NEXT: </dict>
1426// CHECK-NEXT: <dict>
1427// CHECK-NEXT: <key>kind</key><string>event</string>
1428// CHECK-NEXT: <key>location</key>
1429// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001430// CHECK-NEXT: <key>line</key><integer>70</integer>
Anna Zaks0f857922013-04-23 23:57:43 +00001431// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001432// CHECK-NEXT: <key>file</key><integer>0</integer>
1433// CHECK-NEXT: </dict>
1434// CHECK-NEXT: <key>ranges</key>
1435// CHECK-NEXT: <array>
1436// CHECK-NEXT: <array>
1437// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001438// CHECK-NEXT: <key>line</key><integer>70</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001439// CHECK-NEXT: <key>col</key><integer>4</integer>
1440// CHECK-NEXT: <key>file</key><integer>0</integer>
1441// CHECK-NEXT: </dict>
1442// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001443// CHECK-NEXT: <key>line</key><integer>70</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001444// CHECK-NEXT: <key>col</key><integer>4</integer>
1445// CHECK-NEXT: <key>file</key><integer>0</integer>
1446// CHECK-NEXT: </dict>
1447// CHECK-NEXT: </array>
1448// CHECK-NEXT: </array>
1449// CHECK-NEXT: <key>depth</key><integer>0</integer>
1450// CHECK-NEXT: <key>extended_message</key>
1451// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1452// CHECK-NEXT: <key>message</key>
Jordan Rose85e99372012-09-22 01:24:46 +00001453// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001454// CHECK-NEXT: </dict>
1455// CHECK-NEXT: </array>
1456// CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1457// CHECK-NEXT: <key>category</key><string>Logic error</string>
1458// CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string>
Stephen Hines0e2c34f2015-03-23 12:09:02 -07001459// CHECK-NEXT: <key>check_name</key><string>core.NullDereference</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001460// CHECK-NEXT: <key>issue_context_kind</key><string>function</string>
1461// CHECK-NEXT: <key>issue_context</key><string>test_block_ret</string>
Anna Zaksc1c6a492013-01-08 00:25:22 +00001462// CHECK-NEXT: <key>issue_hash</key><string>5</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001463// CHECK-NEXT: <key>location</key>
1464// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001465// CHECK-NEXT: <key>line</key><integer>70</integer>
Anna Zaks0f857922013-04-23 23:57:43 +00001466// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001467// CHECK-NEXT: <key>file</key><integer>0</integer>
1468// CHECK-NEXT: </dict>
1469// CHECK-NEXT: </dict>
1470// CHECK-NEXT: <dict>
1471// CHECK-NEXT: <key>path</key>
1472// CHECK-NEXT: <array>
1473// CHECK-NEXT: <dict>
1474// CHECK-NEXT: <key>kind</key><string>control</string>
1475// CHECK-NEXT: <key>edges</key>
1476// CHECK-NEXT: <array>
1477// CHECK-NEXT: <dict>
1478// CHECK-NEXT: <key>start</key>
1479// CHECK-NEXT: <array>
1480// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001481// CHECK-NEXT: <key>line</key><integer>74</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001482// CHECK-NEXT: <key>col</key><integer>3</integer>
1483// CHECK-NEXT: <key>file</key><integer>0</integer>
1484// CHECK-NEXT: </dict>
1485// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001486// CHECK-NEXT: <key>line</key><integer>74</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001487// CHECK-NEXT: <key>col</key><integer>9</integer>
1488// CHECK-NEXT: <key>file</key><integer>0</integer>
1489// CHECK-NEXT: </dict>
1490// CHECK-NEXT: </array>
1491// CHECK-NEXT: <key>end</key>
1492// CHECK-NEXT: <array>
1493// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001494// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001495// CHECK-NEXT: <key>col</key><integer>3</integer>
1496// CHECK-NEXT: <key>file</key><integer>0</integer>
1497// CHECK-NEXT: </dict>
1498// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001499// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001500// CHECK-NEXT: <key>col</key><integer>3</integer>
1501// CHECK-NEXT: <key>file</key><integer>0</integer>
1502// CHECK-NEXT: </dict>
1503// CHECK-NEXT: </array>
1504// CHECK-NEXT: </dict>
1505// CHECK-NEXT: </array>
1506// CHECK-NEXT: </dict>
1507// CHECK-NEXT: <dict>
1508// CHECK-NEXT: <key>kind</key><string>event</string>
1509// CHECK-NEXT: <key>location</key>
1510// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001511// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001512// CHECK-NEXT: <key>col</key><integer>3</integer>
1513// CHECK-NEXT: <key>file</key><integer>0</integer>
1514// CHECK-NEXT: </dict>
1515// CHECK-NEXT: <key>ranges</key>
1516// CHECK-NEXT: <array>
1517// CHECK-NEXT: <array>
1518// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001519// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001520// CHECK-NEXT: <key>col</key><integer>3</integer>
1521// CHECK-NEXT: <key>file</key><integer>0</integer>
1522// CHECK-NEXT: </dict>
1523// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001524// CHECK-NEXT: <key>line</key><integer>77</integer>
Jordan Rose85e99372012-09-22 01:24:46 +00001525// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001526// CHECK-NEXT: <key>file</key><integer>0</integer>
1527// CHECK-NEXT: </dict>
1528// CHECK-NEXT: </array>
1529// CHECK-NEXT: </array>
1530// CHECK-NEXT: <key>depth</key><integer>0</integer>
1531// CHECK-NEXT: <key>extended_message</key>
1532// CHECK-NEXT: <string>Calling anonymous block</string>
1533// CHECK-NEXT: <key>message</key>
Jordan Rose85e99372012-09-22 01:24:46 +00001534// CHECK-NEXT: <string>Calling anonymous block</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001535// CHECK-NEXT: </dict>
1536// CHECK-NEXT: <dict>
1537// CHECK-NEXT: <key>kind</key><string>event</string>
1538// CHECK-NEXT: <key>location</key>
1539// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001540// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001541// CHECK-NEXT: <key>col</key><integer>3</integer>
1542// CHECK-NEXT: <key>file</key><integer>0</integer>
1543// CHECK-NEXT: </dict>
1544// CHECK-NEXT: <key>depth</key><integer>1</integer>
1545// CHECK-NEXT: <key>extended_message</key>
1546// CHECK-NEXT: <string>Entered call from &apos;test_block_blockvar&apos;</string>
1547// CHECK-NEXT: <key>message</key>
Jordan Rose85e99372012-09-22 01:24:46 +00001548// CHECK-NEXT: <string>Entered call from &apos;test_block_blockvar&apos;</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001549// CHECK-NEXT: </dict>
1550// CHECK-NEXT: <dict>
1551// CHECK-NEXT: <key>kind</key><string>control</string>
1552// CHECK-NEXT: <key>edges</key>
1553// CHECK-NEXT: <array>
1554// CHECK-NEXT: <dict>
1555// CHECK-NEXT: <key>start</key>
1556// CHECK-NEXT: <array>
1557// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001558// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001559// CHECK-NEXT: <key>col</key><integer>3</integer>
1560// CHECK-NEXT: <key>file</key><integer>0</integer>
1561// CHECK-NEXT: </dict>
1562// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001563// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001564// CHECK-NEXT: <key>col</key><integer>3</integer>
1565// CHECK-NEXT: <key>file</key><integer>0</integer>
1566// CHECK-NEXT: </dict>
1567// CHECK-NEXT: </array>
1568// CHECK-NEXT: <key>end</key>
1569// CHECK-NEXT: <array>
1570// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001571// CHECK-NEXT: <key>line</key><integer>76</integer>
Jordan Rose85e99372012-09-22 01:24:46 +00001572// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001573// CHECK-NEXT: <key>file</key><integer>0</integer>
1574// CHECK-NEXT: </dict>
1575// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001576// CHECK-NEXT: <key>line</key><integer>76</integer>
Jordan Rose85e99372012-09-22 01:24:46 +00001577// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001578// CHECK-NEXT: <key>file</key><integer>0</integer>
1579// CHECK-NEXT: </dict>
1580// CHECK-NEXT: </array>
1581// CHECK-NEXT: </dict>
1582// CHECK-NEXT: </array>
1583// CHECK-NEXT: </dict>
1584// CHECK-NEXT: <dict>
1585// CHECK-NEXT: <key>kind</key><string>event</string>
1586// CHECK-NEXT: <key>location</key>
1587// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001588// CHECK-NEXT: <key>line</key><integer>76</integer>
Jordan Rose85e99372012-09-22 01:24:46 +00001589// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001590// CHECK-NEXT: <key>file</key><integer>0</integer>
1591// CHECK-NEXT: </dict>
1592// CHECK-NEXT: <key>ranges</key>
1593// CHECK-NEXT: <array>
1594// CHECK-NEXT: <array>
1595// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001596// CHECK-NEXT: <key>line</key><integer>76</integer>
Jordan Rose85e99372012-09-22 01:24:46 +00001597// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001598// CHECK-NEXT: <key>file</key><integer>0</integer>
1599// CHECK-NEXT: </dict>
1600// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001601// CHECK-NEXT: <key>line</key><integer>76</integer>
Jordan Rose85e99372012-09-22 01:24:46 +00001602// CHECK-NEXT: <key>col</key><integer>9</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001603// CHECK-NEXT: <key>file</key><integer>0</integer>
1604// CHECK-NEXT: </dict>
1605// CHECK-NEXT: </array>
1606// CHECK-NEXT: </array>
1607// CHECK-NEXT: <key>depth</key><integer>1</integer>
1608// CHECK-NEXT: <key>extended_message</key>
1609// CHECK-NEXT: <string>Null pointer value stored to &apos;p&apos;</string>
1610// CHECK-NEXT: <key>message</key>
Jordan Rose85e99372012-09-22 01:24:46 +00001611// CHECK-NEXT: <string>Null pointer value stored to &apos;p&apos;</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001612// CHECK-NEXT: </dict>
1613// CHECK-NEXT: <dict>
1614// CHECK-NEXT: <key>kind</key><string>event</string>
1615// CHECK-NEXT: <key>location</key>
1616// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001617// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001618// CHECK-NEXT: <key>col</key><integer>3</integer>
1619// CHECK-NEXT: <key>file</key><integer>0</integer>
1620// CHECK-NEXT: </dict>
1621// CHECK-NEXT: <key>ranges</key>
1622// CHECK-NEXT: <array>
1623// CHECK-NEXT: <array>
1624// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001625// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001626// CHECK-NEXT: <key>col</key><integer>3</integer>
1627// CHECK-NEXT: <key>file</key><integer>0</integer>
1628// CHECK-NEXT: </dict>
1629// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001630// CHECK-NEXT: <key>line</key><integer>77</integer>
Jordan Rose85e99372012-09-22 01:24:46 +00001631// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001632// CHECK-NEXT: <key>file</key><integer>0</integer>
1633// CHECK-NEXT: </dict>
1634// CHECK-NEXT: </array>
1635// CHECK-NEXT: </array>
Jordan Rose7be22452013-04-12 00:44:17 +00001636// CHECK-NEXT: <key>depth</key><integer>0</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001637// CHECK-NEXT: <key>extended_message</key>
1638// CHECK-NEXT: <string>Returning to caller</string>
1639// CHECK-NEXT: <key>message</key>
Jordan Rose85e99372012-09-22 01:24:46 +00001640// CHECK-NEXT: <string>Returning to caller</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001641// CHECK-NEXT: </dict>
1642// CHECK-NEXT: <dict>
1643// CHECK-NEXT: <key>kind</key><string>control</string>
1644// CHECK-NEXT: <key>edges</key>
1645// CHECK-NEXT: <array>
1646// CHECK-NEXT: <dict>
1647// CHECK-NEXT: <key>start</key>
1648// CHECK-NEXT: <array>
1649// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001650// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001651// CHECK-NEXT: <key>col</key><integer>3</integer>
1652// CHECK-NEXT: <key>file</key><integer>0</integer>
1653// CHECK-NEXT: </dict>
1654// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001655// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001656// CHECK-NEXT: <key>col</key><integer>3</integer>
1657// CHECK-NEXT: <key>file</key><integer>0</integer>
1658// CHECK-NEXT: </dict>
1659// CHECK-NEXT: </array>
1660// CHECK-NEXT: <key>end</key>
1661// CHECK-NEXT: <array>
1662// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001663// CHECK-NEXT: <key>line</key><integer>78</integer>
Anna Zaks0f857922013-04-23 23:57:43 +00001664// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001665// CHECK-NEXT: <key>file</key><integer>0</integer>
1666// CHECK-NEXT: </dict>
1667// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001668// CHECK-NEXT: <key>line</key><integer>78</integer>
Anna Zaks0f857922013-04-23 23:57:43 +00001669// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001670// CHECK-NEXT: <key>file</key><integer>0</integer>
1671// CHECK-NEXT: </dict>
1672// CHECK-NEXT: </array>
1673// CHECK-NEXT: </dict>
1674// CHECK-NEXT: </array>
1675// CHECK-NEXT: </dict>
1676// CHECK-NEXT: <dict>
1677// CHECK-NEXT: <key>kind</key><string>event</string>
1678// CHECK-NEXT: <key>location</key>
1679// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001680// CHECK-NEXT: <key>line</key><integer>78</integer>
Anna Zaks0f857922013-04-23 23:57:43 +00001681// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001682// CHECK-NEXT: <key>file</key><integer>0</integer>
1683// CHECK-NEXT: </dict>
1684// CHECK-NEXT: <key>ranges</key>
1685// CHECK-NEXT: <array>
1686// CHECK-NEXT: <array>
1687// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001688// CHECK-NEXT: <key>line</key><integer>78</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001689// CHECK-NEXT: <key>col</key><integer>4</integer>
1690// CHECK-NEXT: <key>file</key><integer>0</integer>
1691// CHECK-NEXT: </dict>
1692// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001693// CHECK-NEXT: <key>line</key><integer>78</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001694// CHECK-NEXT: <key>col</key><integer>4</integer>
1695// CHECK-NEXT: <key>file</key><integer>0</integer>
1696// CHECK-NEXT: </dict>
1697// CHECK-NEXT: </array>
1698// CHECK-NEXT: </array>
1699// CHECK-NEXT: <key>depth</key><integer>0</integer>
1700// CHECK-NEXT: <key>extended_message</key>
1701// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1702// CHECK-NEXT: <key>message</key>
Jordan Rose85e99372012-09-22 01:24:46 +00001703// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001704// CHECK-NEXT: </dict>
1705// CHECK-NEXT: </array>
1706// CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1707// CHECK-NEXT: <key>category</key><string>Logic error</string>
1708// CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string>
Stephen Hines0e2c34f2015-03-23 12:09:02 -07001709// CHECK-NEXT: <key>check_name</key><string>core.NullDereference</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001710// CHECK-NEXT: <key>issue_context_kind</key><string>function</string>
1711// CHECK-NEXT: <key>issue_context</key><string>test_block_blockvar</string>
Anna Zaksc1c6a492013-01-08 00:25:22 +00001712// CHECK-NEXT: <key>issue_hash</key><string>5</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001713// CHECK-NEXT: <key>location</key>
1714// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001715// CHECK-NEXT: <key>line</key><integer>78</integer>
Anna Zaks0f857922013-04-23 23:57:43 +00001716// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001717// CHECK-NEXT: <key>file</key><integer>0</integer>
1718// CHECK-NEXT: </dict>
1719// CHECK-NEXT: </dict>
1720// CHECK-NEXT: <dict>
1721// CHECK-NEXT: <key>path</key>
1722// CHECK-NEXT: <array>
1723// CHECK-NEXT: <dict>
1724// CHECK-NEXT: <key>kind</key><string>control</string>
1725// CHECK-NEXT: <key>edges</key>
1726// CHECK-NEXT: <array>
1727// CHECK-NEXT: <dict>
1728// CHECK-NEXT: <key>start</key>
1729// CHECK-NEXT: <array>
1730// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001731// CHECK-NEXT: <key>line</key><integer>82</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001732// CHECK-NEXT: <key>col</key><integer>3</integer>
1733// CHECK-NEXT: <key>file</key><integer>0</integer>
1734// CHECK-NEXT: </dict>
1735// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001736// CHECK-NEXT: <key>line</key><integer>82</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001737// CHECK-NEXT: <key>col</key><integer>5</integer>
1738// CHECK-NEXT: <key>file</key><integer>0</integer>
1739// CHECK-NEXT: </dict>
1740// CHECK-NEXT: </array>
1741// CHECK-NEXT: <key>end</key>
1742// CHECK-NEXT: <array>
1743// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001744// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001745// CHECK-NEXT: <key>col</key><integer>3</integer>
1746// CHECK-NEXT: <key>file</key><integer>0</integer>
1747// CHECK-NEXT: </dict>
1748// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001749// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001750// CHECK-NEXT: <key>col</key><integer>3</integer>
1751// CHECK-NEXT: <key>file</key><integer>0</integer>
1752// CHECK-NEXT: </dict>
1753// CHECK-NEXT: </array>
1754// CHECK-NEXT: </dict>
1755// CHECK-NEXT: </array>
1756// CHECK-NEXT: </dict>
1757// CHECK-NEXT: <dict>
1758// CHECK-NEXT: <key>kind</key><string>event</string>
1759// CHECK-NEXT: <key>location</key>
1760// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001761// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001762// CHECK-NEXT: <key>col</key><integer>3</integer>
1763// CHECK-NEXT: <key>file</key><integer>0</integer>
1764// CHECK-NEXT: </dict>
1765// CHECK-NEXT: <key>ranges</key>
1766// CHECK-NEXT: <array>
1767// CHECK-NEXT: <array>
1768// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001769// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001770// CHECK-NEXT: <key>col</key><integer>3</integer>
1771// CHECK-NEXT: <key>file</key><integer>0</integer>
1772// CHECK-NEXT: </dict>
1773// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001774// CHECK-NEXT: <key>line</key><integer>85</integer>
Jordan Rose85e99372012-09-22 01:24:46 +00001775// CHECK-NEXT: <key>col</key><integer>7</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001776// CHECK-NEXT: <key>file</key><integer>0</integer>
1777// CHECK-NEXT: </dict>
1778// CHECK-NEXT: </array>
1779// CHECK-NEXT: </array>
1780// CHECK-NEXT: <key>depth</key><integer>0</integer>
1781// CHECK-NEXT: <key>extended_message</key>
1782// CHECK-NEXT: <string>Calling anonymous block</string>
1783// CHECK-NEXT: <key>message</key>
Jordan Rose85e99372012-09-22 01:24:46 +00001784// CHECK-NEXT: <string>Calling anonymous block</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001785// CHECK-NEXT: </dict>
1786// CHECK-NEXT: <dict>
1787// CHECK-NEXT: <key>kind</key><string>event</string>
1788// CHECK-NEXT: <key>location</key>
1789// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001790// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001791// CHECK-NEXT: <key>col</key><integer>3</integer>
1792// CHECK-NEXT: <key>file</key><integer>0</integer>
1793// CHECK-NEXT: </dict>
1794// CHECK-NEXT: <key>depth</key><integer>1</integer>
1795// CHECK-NEXT: <key>extended_message</key>
1796// CHECK-NEXT: <string>Entered call from &apos;test_block_arg&apos;</string>
1797// CHECK-NEXT: <key>message</key>
Jordan Rose85e99372012-09-22 01:24:46 +00001798// CHECK-NEXT: <string>Entered call from &apos;test_block_arg&apos;</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001799// CHECK-NEXT: </dict>
1800// CHECK-NEXT: <dict>
1801// CHECK-NEXT: <key>kind</key><string>control</string>
1802// CHECK-NEXT: <key>edges</key>
1803// CHECK-NEXT: <array>
1804// CHECK-NEXT: <dict>
1805// CHECK-NEXT: <key>start</key>
1806// CHECK-NEXT: <array>
1807// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001808// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001809// CHECK-NEXT: <key>col</key><integer>3</integer>
1810// CHECK-NEXT: <key>file</key><integer>0</integer>
1811// CHECK-NEXT: </dict>
1812// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001813// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001814// CHECK-NEXT: <key>col</key><integer>3</integer>
1815// CHECK-NEXT: <key>file</key><integer>0</integer>
1816// CHECK-NEXT: </dict>
1817// CHECK-NEXT: </array>
1818// CHECK-NEXT: <key>end</key>
1819// CHECK-NEXT: <array>
1820// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001821// CHECK-NEXT: <key>line</key><integer>84</integer>
Jordan Rose85e99372012-09-22 01:24:46 +00001822// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001823// CHECK-NEXT: <key>file</key><integer>0</integer>
1824// CHECK-NEXT: </dict>
1825// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001826// CHECK-NEXT: <key>line</key><integer>84</integer>
Jordan Rose85e99372012-09-22 01:24:46 +00001827// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001828// CHECK-NEXT: <key>file</key><integer>0</integer>
1829// CHECK-NEXT: </dict>
1830// CHECK-NEXT: </array>
1831// CHECK-NEXT: </dict>
1832// CHECK-NEXT: </array>
1833// CHECK-NEXT: </dict>
1834// CHECK-NEXT: <dict>
1835// CHECK-NEXT: <key>kind</key><string>event</string>
1836// CHECK-NEXT: <key>location</key>
1837// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001838// CHECK-NEXT: <key>line</key><integer>84</integer>
Jordan Rose85e99372012-09-22 01:24:46 +00001839// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001840// CHECK-NEXT: <key>file</key><integer>0</integer>
1841// CHECK-NEXT: </dict>
1842// CHECK-NEXT: <key>ranges</key>
1843// CHECK-NEXT: <array>
1844// CHECK-NEXT: <array>
1845// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001846// CHECK-NEXT: <key>line</key><integer>84</integer>
Jordan Rose85e99372012-09-22 01:24:46 +00001847// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001848// CHECK-NEXT: <key>file</key><integer>0</integer>
1849// CHECK-NEXT: </dict>
1850// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001851// CHECK-NEXT: <key>line</key><integer>84</integer>
Jordan Rose85e99372012-09-22 01:24:46 +00001852// CHECK-NEXT: <key>col</key><integer>10</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001853// CHECK-NEXT: <key>file</key><integer>0</integer>
1854// CHECK-NEXT: </dict>
1855// CHECK-NEXT: </array>
1856// CHECK-NEXT: </array>
1857// CHECK-NEXT: <key>depth</key><integer>1</integer>
1858// CHECK-NEXT: <key>extended_message</key>
1859// CHECK-NEXT: <string>Null pointer value stored to &apos;p&apos;</string>
1860// CHECK-NEXT: <key>message</key>
Jordan Rose85e99372012-09-22 01:24:46 +00001861// CHECK-NEXT: <string>Null pointer value stored to &apos;p&apos;</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001862// CHECK-NEXT: </dict>
1863// CHECK-NEXT: <dict>
1864// CHECK-NEXT: <key>kind</key><string>event</string>
1865// CHECK-NEXT: <key>location</key>
1866// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001867// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001868// CHECK-NEXT: <key>col</key><integer>3</integer>
1869// CHECK-NEXT: <key>file</key><integer>0</integer>
1870// CHECK-NEXT: </dict>
1871// CHECK-NEXT: <key>ranges</key>
1872// CHECK-NEXT: <array>
1873// CHECK-NEXT: <array>
1874// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001875// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001876// CHECK-NEXT: <key>col</key><integer>3</integer>
1877// CHECK-NEXT: <key>file</key><integer>0</integer>
1878// CHECK-NEXT: </dict>
1879// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001880// CHECK-NEXT: <key>line</key><integer>85</integer>
Jordan Rose85e99372012-09-22 01:24:46 +00001881// CHECK-NEXT: <key>col</key><integer>7</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001882// CHECK-NEXT: <key>file</key><integer>0</integer>
1883// CHECK-NEXT: </dict>
1884// CHECK-NEXT: </array>
1885// CHECK-NEXT: </array>
Jordan Rose7be22452013-04-12 00:44:17 +00001886// CHECK-NEXT: <key>depth</key><integer>0</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001887// CHECK-NEXT: <key>extended_message</key>
1888// CHECK-NEXT: <string>Returning to caller</string>
1889// CHECK-NEXT: <key>message</key>
Jordan Rose85e99372012-09-22 01:24:46 +00001890// CHECK-NEXT: <string>Returning to caller</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001891// CHECK-NEXT: </dict>
1892// CHECK-NEXT: <dict>
1893// CHECK-NEXT: <key>kind</key><string>control</string>
1894// CHECK-NEXT: <key>edges</key>
1895// CHECK-NEXT: <array>
1896// CHECK-NEXT: <dict>
1897// CHECK-NEXT: <key>start</key>
1898// CHECK-NEXT: <array>
1899// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001900// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001901// CHECK-NEXT: <key>col</key><integer>3</integer>
1902// CHECK-NEXT: <key>file</key><integer>0</integer>
1903// CHECK-NEXT: </dict>
1904// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001905// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001906// CHECK-NEXT: <key>col</key><integer>3</integer>
1907// CHECK-NEXT: <key>file</key><integer>0</integer>
1908// CHECK-NEXT: </dict>
1909// CHECK-NEXT: </array>
1910// CHECK-NEXT: <key>end</key>
1911// CHECK-NEXT: <array>
1912// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001913// CHECK-NEXT: <key>line</key><integer>86</integer>
Anna Zaks0f857922013-04-23 23:57:43 +00001914// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001915// CHECK-NEXT: <key>file</key><integer>0</integer>
1916// CHECK-NEXT: </dict>
1917// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001918// CHECK-NEXT: <key>line</key><integer>86</integer>
Anna Zaks0f857922013-04-23 23:57:43 +00001919// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001920// CHECK-NEXT: <key>file</key><integer>0</integer>
1921// CHECK-NEXT: </dict>
1922// CHECK-NEXT: </array>
1923// CHECK-NEXT: </dict>
1924// CHECK-NEXT: </array>
1925// CHECK-NEXT: </dict>
1926// CHECK-NEXT: <dict>
1927// CHECK-NEXT: <key>kind</key><string>event</string>
1928// CHECK-NEXT: <key>location</key>
1929// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001930// CHECK-NEXT: <key>line</key><integer>86</integer>
Anna Zaks0f857922013-04-23 23:57:43 +00001931// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001932// CHECK-NEXT: <key>file</key><integer>0</integer>
1933// CHECK-NEXT: </dict>
1934// CHECK-NEXT: <key>ranges</key>
1935// CHECK-NEXT: <array>
1936// CHECK-NEXT: <array>
1937// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001938// CHECK-NEXT: <key>line</key><integer>86</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001939// CHECK-NEXT: <key>col</key><integer>4</integer>
1940// CHECK-NEXT: <key>file</key><integer>0</integer>
1941// CHECK-NEXT: </dict>
1942// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001943// CHECK-NEXT: <key>line</key><integer>86</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001944// CHECK-NEXT: <key>col</key><integer>4</integer>
1945// CHECK-NEXT: <key>file</key><integer>0</integer>
1946// CHECK-NEXT: </dict>
1947// CHECK-NEXT: </array>
1948// CHECK-NEXT: </array>
1949// CHECK-NEXT: <key>depth</key><integer>0</integer>
1950// CHECK-NEXT: <key>extended_message</key>
1951// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1952// CHECK-NEXT: <key>message</key>
Jordan Rose85e99372012-09-22 01:24:46 +00001953// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001954// CHECK-NEXT: </dict>
1955// CHECK-NEXT: </array>
1956// CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1957// CHECK-NEXT: <key>category</key><string>Logic error</string>
1958// CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string>
Stephen Hines0e2c34f2015-03-23 12:09:02 -07001959// CHECK-NEXT: <key>check_name</key><string>core.NullDereference</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001960// CHECK-NEXT: <key>issue_context_kind</key><string>function</string>
1961// CHECK-NEXT: <key>issue_context</key><string>test_block_arg</string>
Anna Zaksc1c6a492013-01-08 00:25:22 +00001962// CHECK-NEXT: <key>issue_hash</key><string>5</string>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001963// CHECK-NEXT: <key>location</key>
1964// CHECK-NEXT: <dict>
Ted Kremenekb85cce02012-10-25 22:07:10 +00001965// CHECK-NEXT: <key>line</key><integer>86</integer>
Anna Zaks0f857922013-04-23 23:57:43 +00001966// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenek0187a1b2012-09-08 04:26:37 +00001967// CHECK-NEXT: <key>file</key><integer>0</integer>
1968// CHECK-NEXT: </dict>
1969// CHECK-NEXT: </dict>
1970// CHECK-NEXT: </array>