blob: bccf219d31e5a8abd93cc0d87749db88100c92bd [file] [log] [blame]
Jordan Rose52de8ee2012-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 Rose5e2b3a32013-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 Kremenekaa1f96a2012-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 Rose106b037a2012-09-22 01:24:46 +00008 y++;
Ted Kremenekaa1f96a2012-03-02 21:16:22 +00009}
10
11int foo(int x, int y) {
Jordan Rose106b037a2012-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 Kremenekaa1f96a2012-03-02 21:16:22 +000019}
20
Ted Kremenek487cdbf2012-03-12 22:10:57 +000021// Test a bug triggering only when inlined.
22void has_bug(int *p) {
Jordan Rose106b037a2012-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 Kremenek487cdbf2012-03-12 22:10:57 +000024}
25
26void test_has_bug() {
27 has_bug(0);
Jordan Rose106b037a2012-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 Kremenek487cdbf2012-03-12 22:10:57 +000030}
31
Ted Kremenek170641b2012-05-02 00:31:29 +000032void triggers_bug(int *p) {
Jordan Rose106b037a2012-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 Kremenek170641b2012-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 Rose106b037a2012-09-22 01:24:46 +000039 if (!!p) {
40 // expected-note@-1 {{Assuming 'p' is null}}
Ted Kremeneka5958862012-10-25 22:07:10 +000041 // expected-note@-2 {{Taking false branch}}
Ted Kremenek170641b2012-05-02 00:31:29 +000042 return;
Jordan Rose106b037a2012-09-22 01:24:46 +000043 }
Ted Kremenek170641b2012-05-02 00:31:29 +000044
Jordan Rose106b037a2012-09-22 01:24:46 +000045 if (p == 0) {
46 // expected-note@-1 {{Taking true branch}}
Ted Kremenek170641b2012-05-02 00:31:29 +000047 triggers_bug(p);
Jordan Rose106b037a2012-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 Kremenek170641b2012-05-02 00:31:29 +000051}
Ted Kremeneka85f38b2012-04-06 22:10:18 +000052
Ted Kremenekc3da3762012-06-01 20:04:04 +000053// ========================================================================== //
54// Test inlining of blocks.
55// ========================================================================== //
56
57void test_block__capture_null() {
Ted Kremenek37c777e2013-02-26 19:44:38 +000058 int *p = 0; // expected-note{{'p' initialized to a null pointer value}}
Jordan Rose106b037a2012-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 Kremenekc3da3762012-06-01 20:04:04 +000063}
64
65void test_block_ret() {
Jordan Rose801916b2013-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 Kremenek37c777e2013-02-26 19:44:38 +000067 int *q = 0; // expected-note {{'q' initialized to a null pointer value}}
Jordan Rose106b037a2012-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 Kremenekc3da3762012-06-01 20:04:04 +000071}
72
73void test_block_blockvar() {
74 __block int *p;
Jordan Rose106b037a2012-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 Kremenekc3da3762012-06-01 20:04:04 +000079}
80
81void test_block_arg() {
82 int *p;
Jordan Rose106b037a2012-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 Kremenekc3da3762012-06-01 20:04:04 +000087}
88
Ted Kremenekaa1f96a2012-03-02 21:16:22 +000089// CHECK: <key>diagnostics</key>
Ted Kremenekb0d1c702012-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 Rose106b037a2012-09-22 01:24:46 +0000102// CHECK-NEXT: <key>line</key><integer>12</integer>
103// CHECK-NEXT: <key>col</key><integer>3</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000104// CHECK-NEXT: <key>file</key><integer>0</integer>
105// CHECK-NEXT: </dict>
106// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +0000107// CHECK-NEXT: <key>line</key><integer>12</integer>
108// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-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 Rose106b037a2012-09-22 01:24:46 +0000115// CHECK-NEXT: <key>line</key><integer>13</integer>
116// CHECK-NEXT: <key>col</key><integer>3</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000117// CHECK-NEXT: <key>file</key><integer>0</integer>
118// CHECK-NEXT: </dict>
119// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +0000120// CHECK-NEXT: <key>line</key><integer>13</integer>
121// CHECK-NEXT: <key>col</key><integer>4</integer>
Ted Kremenekb0d1c702012-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 Rose106b037a2012-09-22 01:24:46 +0000136// CHECK-NEXT: <key>line</key><integer>13</integer>
137// CHECK-NEXT: <key>col</key><integer>3</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000138// CHECK-NEXT: <key>file</key><integer>0</integer>
139// CHECK-NEXT: </dict>
140// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +0000141// CHECK-NEXT: <key>line</key><integer>13</integer>
142// CHECK-NEXT: <key>col</key><integer>4</integer>
Ted Kremenekb0d1c702012-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 Rose106b037a2012-09-22 01:24:46 +0000149// CHECK-NEXT: <key>line</key><integer>13</integer>
150// CHECK-NEXT: <key>col</key><integer>7</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000151// CHECK-NEXT: <key>file</key><integer>0</integer>
152// CHECK-NEXT: </dict>
153// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +0000154// CHECK-NEXT: <key>line</key><integer>13</integer>
155// CHECK-NEXT: <key>col</key><integer>7</integer>
Ted Kremenekb0d1c702012-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 Rose106b037a2012-09-22 01:24:46 +0000166// CHECK-NEXT: <key>line</key><integer>13</integer>
167// CHECK-NEXT: <key>col</key><integer>7</integer>
Ted Kremenekb0d1c702012-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 Rose106b037a2012-09-22 01:24:46 +0000174// CHECK-NEXT: <key>line</key><integer>13</integer>
175// CHECK-NEXT: <key>col</key><integer>7</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000176// CHECK-NEXT: <key>file</key><integer>0</integer>
177// CHECK-NEXT: </dict>
178// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +0000179// CHECK-NEXT: <key>line</key><integer>13</integer>
180// CHECK-NEXT: <key>col</key><integer>12</integer>
Ted Kremenekb0d1c702012-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 Rose106b037a2012-09-22 01:24:46 +0000189// CHECK-NEXT: <string>Assuming &apos;x&apos; is equal to 0</string>
Ted Kremenekb0d1c702012-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 Rose106b037a2012-09-22 01:24:46 +0000199// CHECK-NEXT: <key>line</key><integer>13</integer>
200// CHECK-NEXT: <key>col</key><integer>7</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000201// CHECK-NEXT: <key>file</key><integer>0</integer>
202// CHECK-NEXT: </dict>
203// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +0000204// CHECK-NEXT: <key>line</key><integer>13</integer>
205// CHECK-NEXT: <key>col</key><integer>7</integer>
Ted Kremenekb0d1c702012-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 Rose106b037a2012-09-22 01:24:46 +0000212// CHECK-NEXT: <key>line</key><integer>18</integer>
213// CHECK-NEXT: <key>col</key><integer>3</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000214// CHECK-NEXT: <key>file</key><integer>0</integer>
215// CHECK-NEXT: </dict>
216// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +0000217// CHECK-NEXT: <key>line</key><integer>18</integer>
218// CHECK-NEXT: <key>col</key><integer>8</integer>
Ted Kremenekb0d1c702012-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 Rose106b037a2012-09-22 01:24:46 +0000233// CHECK-NEXT: <key>line</key><integer>18</integer>
234// CHECK-NEXT: <key>col</key><integer>3</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000235// CHECK-NEXT: <key>file</key><integer>0</integer>
236// CHECK-NEXT: </dict>
237// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +0000238// CHECK-NEXT: <key>line</key><integer>18</integer>
239// CHECK-NEXT: <key>col</key><integer>8</integer>
Ted Kremenekb0d1c702012-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 Rose106b037a2012-09-22 01:24:46 +0000246// CHECK-NEXT: <key>line</key><integer>18</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +0000247// CHECK-NEXT: <key>col</key><integer>11</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000248// CHECK-NEXT: <key>file</key><integer>0</integer>
249// CHECK-NEXT: </dict>
250// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +0000251// CHECK-NEXT: <key>line</key><integer>18</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +0000252// CHECK-NEXT: <key>col</key><integer>11</integer>
Ted Kremenekb0d1c702012-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 Rose106b037a2012-09-22 01:24:46 +0000263// CHECK-NEXT: <key>line</key><integer>18</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +0000264// CHECK-NEXT: <key>col</key><integer>11</integer>
Ted Kremenekb0d1c702012-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 Rose106b037a2012-09-22 01:24:46 +0000271// CHECK-NEXT: <key>line</key><integer>18</integer>
272// CHECK-NEXT: <key>col</key><integer>10</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000273// CHECK-NEXT: <key>file</key><integer>0</integer>
274// CHECK-NEXT: </dict>
275// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +0000276// CHECK-NEXT: <key>line</key><integer>18</integer>
277// CHECK-NEXT: <key>col</key><integer>12</integer>
Ted Kremenekb0d1c702012-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 Rose106b037a2012-09-22 01:24:46 +0000286// CHECK-NEXT: <string>Division by zero</string>
Ted Kremenekb0d1c702012-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>
Gabor Horvathc18a1132015-02-09 22:52:26 +0000292// CHECK-NEXT: <key>check_name</key><string>core.DivideZero</string>
Gabor Horvathefec1632015-10-22 11:53:04 +0000293// CHECK-NEXT: <!-- This hash is experimental and going to change! -->
294// CHECK-NEXT: <key>issue_hash_content_of_line_in_context</key><string>8bca94f2f862468bb877fb70e66a3304</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000295// CHECK-NEXT: <key>issue_context_kind</key><string>function</string>
296// CHECK-NEXT: <key>issue_context</key><string>foo</string>
Gabor Horvathefec1632015-10-22 11:53:04 +0000297// CHECK-NEXT: <key>issue_hash_function_offset</key><string>7</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000298// CHECK-NEXT: <key>location</key>
299// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +0000300// CHECK-NEXT: <key>line</key><integer>18</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +0000301// CHECK-NEXT: <key>col</key><integer>11</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000302// CHECK-NEXT: <key>file</key><integer>0</integer>
303// CHECK-NEXT: </dict>
304// CHECK-NEXT: </dict>
305// CHECK-NEXT: <dict>
306// CHECK-NEXT: <key>path</key>
307// CHECK-NEXT: <array>
308// CHECK-NEXT: <dict>
309// CHECK-NEXT: <key>kind</key><string>control</string>
310// CHECK-NEXT: <key>edges</key>
311// CHECK-NEXT: <array>
312// CHECK-NEXT: <dict>
313// CHECK-NEXT: <key>start</key>
314// CHECK-NEXT: <array>
315// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +0000316// CHECK-NEXT: <key>line</key><integer>27</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000317// CHECK-NEXT: <key>col</key><integer>3</integer>
318// CHECK-NEXT: <key>file</key><integer>0</integer>
319// CHECK-NEXT: </dict>
320// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +0000321// CHECK-NEXT: <key>line</key><integer>27</integer>
322// CHECK-NEXT: <key>col</key><integer>9</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000323// CHECK-NEXT: <key>file</key><integer>0</integer>
324// CHECK-NEXT: </dict>
325// CHECK-NEXT: </array>
326// CHECK-NEXT: <key>end</key>
327// CHECK-NEXT: <array>
328// CHECK-NEXT: <dict>
329// CHECK-NEXT: <key>line</key><integer>27</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000330// CHECK-NEXT: <key>col</key><integer>11</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000331// CHECK-NEXT: <key>file</key><integer>0</integer>
332// CHECK-NEXT: </dict>
333// CHECK-NEXT: <dict>
334// CHECK-NEXT: <key>line</key><integer>27</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000335// CHECK-NEXT: <key>col</key><integer>11</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000336// CHECK-NEXT: <key>file</key><integer>0</integer>
337// CHECK-NEXT: </dict>
338// CHECK-NEXT: </array>
339// CHECK-NEXT: </dict>
340// CHECK-NEXT: </array>
341// CHECK-NEXT: </dict>
342// CHECK-NEXT: <dict>
343// CHECK-NEXT: <key>kind</key><string>event</string>
344// CHECK-NEXT: <key>location</key>
345// CHECK-NEXT: <dict>
346// CHECK-NEXT: <key>line</key><integer>27</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000347// CHECK-NEXT: <key>col</key><integer>11</integer>
348// CHECK-NEXT: <key>file</key><integer>0</integer>
349// CHECK-NEXT: </dict>
350// CHECK-NEXT: <key>ranges</key>
351// CHECK-NEXT: <array>
352// CHECK-NEXT: <array>
353// CHECK-NEXT: <dict>
354// CHECK-NEXT: <key>line</key><integer>27</integer>
355// CHECK-NEXT: <key>col</key><integer>11</integer>
356// CHECK-NEXT: <key>file</key><integer>0</integer>
357// CHECK-NEXT: </dict>
358// CHECK-NEXT: <dict>
359// CHECK-NEXT: <key>line</key><integer>27</integer>
360// CHECK-NEXT: <key>col</key><integer>11</integer>
361// CHECK-NEXT: <key>file</key><integer>0</integer>
362// CHECK-NEXT: </dict>
363// CHECK-NEXT: </array>
364// CHECK-NEXT: </array>
365// CHECK-NEXT: <key>depth</key><integer>0</integer>
366// CHECK-NEXT: <key>extended_message</key>
367// CHECK-NEXT: <string>Passing null pointer value via 1st parameter &apos;p&apos;</string>
368// CHECK-NEXT: <key>message</key>
369// CHECK-NEXT: <string>Passing null pointer value via 1st parameter &apos;p&apos;</string>
370// CHECK-NEXT: </dict>
371// CHECK-NEXT: <dict>
372// CHECK-NEXT: <key>kind</key><string>event</string>
373// CHECK-NEXT: <key>location</key>
374// CHECK-NEXT: <dict>
375// CHECK-NEXT: <key>line</key><integer>27</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000376// CHECK-NEXT: <key>col</key><integer>3</integer>
377// CHECK-NEXT: <key>file</key><integer>0</integer>
378// CHECK-NEXT: </dict>
379// CHECK-NEXT: <key>ranges</key>
380// CHECK-NEXT: <array>
381// CHECK-NEXT: <array>
382// CHECK-NEXT: <dict>
383// CHECK-NEXT: <key>line</key><integer>27</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000384// CHECK-NEXT: <key>col</key><integer>3</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000385// CHECK-NEXT: <key>file</key><integer>0</integer>
386// CHECK-NEXT: </dict>
387// CHECK-NEXT: <dict>
388// CHECK-NEXT: <key>line</key><integer>27</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000389// CHECK-NEXT: <key>col</key><integer>12</integer>
390// CHECK-NEXT: <key>file</key><integer>0</integer>
391// CHECK-NEXT: </dict>
392// CHECK-NEXT: </array>
393// CHECK-NEXT: </array>
394// CHECK-NEXT: <key>depth</key><integer>0</integer>
395// CHECK-NEXT: <key>extended_message</key>
396// CHECK-NEXT: <string>Calling &apos;has_bug&apos;</string>
397// CHECK-NEXT: <key>message</key>
398// CHECK-NEXT: <string>Calling &apos;has_bug&apos;</string>
399// CHECK-NEXT: </dict>
400// CHECK-NEXT: <dict>
401// CHECK-NEXT: <key>kind</key><string>event</string>
402// CHECK-NEXT: <key>location</key>
403// CHECK-NEXT: <dict>
404// CHECK-NEXT: <key>line</key><integer>22</integer>
405// CHECK-NEXT: <key>col</key><integer>1</integer>
406// CHECK-NEXT: <key>file</key><integer>0</integer>
407// CHECK-NEXT: </dict>
408// CHECK-NEXT: <key>depth</key><integer>1</integer>
409// CHECK-NEXT: <key>extended_message</key>
410// CHECK-NEXT: <string>Entered call from &apos;test_has_bug&apos;</string>
411// CHECK-NEXT: <key>message</key>
412// CHECK-NEXT: <string>Entered call from &apos;test_has_bug&apos;</string>
413// CHECK-NEXT: </dict>
414// CHECK-NEXT: <dict>
415// CHECK-NEXT: <key>kind</key><string>control</string>
416// CHECK-NEXT: <key>edges</key>
417// CHECK-NEXT: <array>
418// CHECK-NEXT: <dict>
419// CHECK-NEXT: <key>start</key>
420// CHECK-NEXT: <array>
421// CHECK-NEXT: <dict>
422// CHECK-NEXT: <key>line</key><integer>22</integer>
423// CHECK-NEXT: <key>col</key><integer>1</integer>
424// CHECK-NEXT: <key>file</key><integer>0</integer>
425// CHECK-NEXT: </dict>
426// CHECK-NEXT: <dict>
427// CHECK-NEXT: <key>line</key><integer>22</integer>
428// CHECK-NEXT: <key>col</key><integer>4</integer>
429// CHECK-NEXT: <key>file</key><integer>0</integer>
430// CHECK-NEXT: </dict>
431// CHECK-NEXT: </array>
432// CHECK-NEXT: <key>end</key>
433// CHECK-NEXT: <array>
434// CHECK-NEXT: <dict>
435// CHECK-NEXT: <key>line</key><integer>23</integer>
436// CHECK-NEXT: <key>col</key><integer>3</integer>
437// CHECK-NEXT: <key>file</key><integer>0</integer>
438// CHECK-NEXT: </dict>
439// CHECK-NEXT: <dict>
440// CHECK-NEXT: <key>line</key><integer>23</integer>
441// CHECK-NEXT: <key>col</key><integer>3</integer>
442// CHECK-NEXT: <key>file</key><integer>0</integer>
443// CHECK-NEXT: </dict>
444// CHECK-NEXT: </array>
445// CHECK-NEXT: </dict>
446// CHECK-NEXT: </array>
447// CHECK-NEXT: </dict>
448// CHECK-NEXT: <dict>
Anna Zaks4e16b292013-04-23 23:57:43 +0000449// CHECK-NEXT: <key>kind</key><string>control</string>
450// CHECK-NEXT: <key>edges</key>
451// CHECK-NEXT: <array>
452// CHECK-NEXT: <dict>
453// CHECK-NEXT: <key>start</key>
454// CHECK-NEXT: <array>
455// CHECK-NEXT: <dict>
456// CHECK-NEXT: <key>line</key><integer>23</integer>
457// CHECK-NEXT: <key>col</key><integer>3</integer>
458// CHECK-NEXT: <key>file</key><integer>0</integer>
459// CHECK-NEXT: </dict>
460// CHECK-NEXT: <dict>
461// CHECK-NEXT: <key>line</key><integer>23</integer>
462// CHECK-NEXT: <key>col</key><integer>3</integer>
463// CHECK-NEXT: <key>file</key><integer>0</integer>
464// CHECK-NEXT: </dict>
465// CHECK-NEXT: </array>
466// CHECK-NEXT: <key>end</key>
467// CHECK-NEXT: <array>
468// CHECK-NEXT: <dict>
469// CHECK-NEXT: <key>line</key><integer>23</integer>
470// CHECK-NEXT: <key>col</key><integer>6</integer>
471// CHECK-NEXT: <key>file</key><integer>0</integer>
472// CHECK-NEXT: </dict>
473// CHECK-NEXT: <dict>
474// CHECK-NEXT: <key>line</key><integer>23</integer>
475// CHECK-NEXT: <key>col</key><integer>6</integer>
476// CHECK-NEXT: <key>file</key><integer>0</integer>
477// CHECK-NEXT: </dict>
478// CHECK-NEXT: </array>
479// CHECK-NEXT: </dict>
480// CHECK-NEXT: </array>
481// CHECK-NEXT: </dict>
482// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +0000483// CHECK-NEXT: <key>kind</key><string>event</string>
484// CHECK-NEXT: <key>location</key>
485// CHECK-NEXT: <dict>
486// CHECK-NEXT: <key>line</key><integer>23</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +0000487// CHECK-NEXT: <key>col</key><integer>6</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000488// CHECK-NEXT: <key>file</key><integer>0</integer>
489// CHECK-NEXT: </dict>
490// CHECK-NEXT: <key>ranges</key>
491// CHECK-NEXT: <array>
492// CHECK-NEXT: <array>
493// CHECK-NEXT: <dict>
494// CHECK-NEXT: <key>line</key><integer>23</integer>
495// CHECK-NEXT: <key>col</key><integer>4</integer>
496// CHECK-NEXT: <key>file</key><integer>0</integer>
497// CHECK-NEXT: </dict>
498// CHECK-NEXT: <dict>
499// CHECK-NEXT: <key>line</key><integer>23</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000500// CHECK-NEXT: <key>col</key><integer>4</integer>
501// CHECK-NEXT: <key>file</key><integer>0</integer>
502// CHECK-NEXT: </dict>
503// CHECK-NEXT: </array>
504// CHECK-NEXT: </array>
505// CHECK-NEXT: <key>depth</key><integer>1</integer>
506// CHECK-NEXT: <key>extended_message</key>
507// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
508// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +0000509// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
510// CHECK-NEXT: </dict>
511// CHECK-NEXT: </array>
512// CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
513// CHECK-NEXT: <key>category</key><string>Logic error</string>
514// CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string>
Gabor Horvathc18a1132015-02-09 22:52:26 +0000515// CHECK-NEXT: <key>check_name</key><string>core.NullDereference</string>
Gabor Horvathefec1632015-10-22 11:53:04 +0000516// CHECK-NEXT: <!-- This hash is experimental and going to change! -->
517// CHECK-NEXT: <key>issue_hash_content_of_line_in_context</key><string>62ddaf4e66ff527b230b474b98791ced</string>
Jordan Rose106b037a2012-09-22 01:24:46 +0000518// CHECK-NEXT: <key>issue_context_kind</key><string>function</string>
519// CHECK-NEXT: <key>issue_context</key><string>has_bug</string>
Gabor Horvathefec1632015-10-22 11:53:04 +0000520// CHECK-NEXT: <key>issue_hash_function_offset</key><string>1</string>
Jordan Rose106b037a2012-09-22 01:24:46 +0000521// CHECK-NEXT: <key>location</key>
522// CHECK-NEXT: <dict>
523// CHECK-NEXT: <key>line</key><integer>23</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +0000524// CHECK-NEXT: <key>col</key><integer>6</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000525// CHECK-NEXT: <key>file</key><integer>0</integer>
526// CHECK-NEXT: </dict>
527// CHECK-NEXT: </dict>
528// CHECK-NEXT: <dict>
529// CHECK-NEXT: <key>path</key>
530// CHECK-NEXT: <array>
531// CHECK-NEXT: <dict>
532// CHECK-NEXT: <key>kind</key><string>control</string>
533// CHECK-NEXT: <key>edges</key>
534// CHECK-NEXT: <array>
535// CHECK-NEXT: <dict>
536// CHECK-NEXT: <key>start</key>
537// CHECK-NEXT: <array>
538// CHECK-NEXT: <dict>
539// CHECK-NEXT: <key>line</key><integer>39</integer>
540// CHECK-NEXT: <key>col</key><integer>3</integer>
541// CHECK-NEXT: <key>file</key><integer>0</integer>
542// CHECK-NEXT: </dict>
543// CHECK-NEXT: <dict>
544// CHECK-NEXT: <key>line</key><integer>39</integer>
545// CHECK-NEXT: <key>col</key><integer>4</integer>
546// CHECK-NEXT: <key>file</key><integer>0</integer>
547// CHECK-NEXT: </dict>
548// CHECK-NEXT: </array>
549// CHECK-NEXT: <key>end</key>
550// CHECK-NEXT: <array>
551// CHECK-NEXT: <dict>
552// CHECK-NEXT: <key>line</key><integer>39</integer>
553// CHECK-NEXT: <key>col</key><integer>8</integer>
554// CHECK-NEXT: <key>file</key><integer>0</integer>
555// CHECK-NEXT: </dict>
556// CHECK-NEXT: <dict>
557// CHECK-NEXT: <key>line</key><integer>39</integer>
558// CHECK-NEXT: <key>col</key><integer>8</integer>
559// CHECK-NEXT: <key>file</key><integer>0</integer>
560// CHECK-NEXT: </dict>
561// CHECK-NEXT: </array>
562// CHECK-NEXT: </dict>
563// CHECK-NEXT: </array>
564// CHECK-NEXT: </dict>
565// CHECK-NEXT: <dict>
566// CHECK-NEXT: <key>kind</key><string>event</string>
567// CHECK-NEXT: <key>location</key>
568// CHECK-NEXT: <dict>
569// CHECK-NEXT: <key>line</key><integer>39</integer>
570// CHECK-NEXT: <key>col</key><integer>8</integer>
571// CHECK-NEXT: <key>file</key><integer>0</integer>
572// CHECK-NEXT: </dict>
573// CHECK-NEXT: <key>ranges</key>
574// CHECK-NEXT: <array>
575// CHECK-NEXT: <array>
576// CHECK-NEXT: <dict>
577// CHECK-NEXT: <key>line</key><integer>39</integer>
578// CHECK-NEXT: <key>col</key><integer>8</integer>
579// CHECK-NEXT: <key>file</key><integer>0</integer>
580// CHECK-NEXT: </dict>
581// CHECK-NEXT: <dict>
582// CHECK-NEXT: <key>line</key><integer>39</integer>
583// CHECK-NEXT: <key>col</key><integer>9</integer>
584// CHECK-NEXT: <key>file</key><integer>0</integer>
585// CHECK-NEXT: </dict>
586// CHECK-NEXT: </array>
587// CHECK-NEXT: </array>
588// CHECK-NEXT: <key>depth</key><integer>0</integer>
589// CHECK-NEXT: <key>extended_message</key>
590// CHECK-NEXT: <string>Assuming &apos;p&apos; is null</string>
591// CHECK-NEXT: <key>message</key>
592// CHECK-NEXT: <string>Assuming &apos;p&apos; is null</string>
593// CHECK-NEXT: </dict>
594// CHECK-NEXT: <dict>
595// CHECK-NEXT: <key>kind</key><string>control</string>
596// CHECK-NEXT: <key>edges</key>
597// CHECK-NEXT: <array>
598// CHECK-NEXT: <dict>
599// CHECK-NEXT: <key>start</key>
600// CHECK-NEXT: <array>
601// CHECK-NEXT: <dict>
602// CHECK-NEXT: <key>line</key><integer>39</integer>
603// CHECK-NEXT: <key>col</key><integer>8</integer>
604// CHECK-NEXT: <key>file</key><integer>0</integer>
605// CHECK-NEXT: </dict>
606// CHECK-NEXT: <dict>
607// CHECK-NEXT: <key>line</key><integer>39</integer>
608// CHECK-NEXT: <key>col</key><integer>8</integer>
609// CHECK-NEXT: <key>file</key><integer>0</integer>
610// CHECK-NEXT: </dict>
611// CHECK-NEXT: </array>
612// CHECK-NEXT: <key>end</key>
613// CHECK-NEXT: <array>
614// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000615// CHECK-NEXT: <key>line</key><integer>45</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000616// CHECK-NEXT: <key>col</key><integer>3</integer>
617// CHECK-NEXT: <key>file</key><integer>0</integer>
618// CHECK-NEXT: </dict>
619// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000620// CHECK-NEXT: <key>line</key><integer>45</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000621// CHECK-NEXT: <key>col</key><integer>4</integer>
622// CHECK-NEXT: <key>file</key><integer>0</integer>
623// CHECK-NEXT: </dict>
624// CHECK-NEXT: </array>
625// CHECK-NEXT: </dict>
626// CHECK-NEXT: </array>
627// CHECK-NEXT: </dict>
628// CHECK-NEXT: <dict>
629// CHECK-NEXT: <key>kind</key><string>control</string>
630// CHECK-NEXT: <key>edges</key>
631// CHECK-NEXT: <array>
632// CHECK-NEXT: <dict>
633// CHECK-NEXT: <key>start</key>
634// CHECK-NEXT: <array>
635// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000636// CHECK-NEXT: <key>line</key><integer>45</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000637// CHECK-NEXT: <key>col</key><integer>3</integer>
638// CHECK-NEXT: <key>file</key><integer>0</integer>
639// CHECK-NEXT: </dict>
640// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000641// CHECK-NEXT: <key>line</key><integer>45</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000642// CHECK-NEXT: <key>col</key><integer>4</integer>
643// CHECK-NEXT: <key>file</key><integer>0</integer>
644// CHECK-NEXT: </dict>
645// CHECK-NEXT: </array>
646// CHECK-NEXT: <key>end</key>
647// CHECK-NEXT: <array>
648// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000649// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000650// CHECK-NEXT: <key>col</key><integer>5</integer>
651// CHECK-NEXT: <key>file</key><integer>0</integer>
652// CHECK-NEXT: </dict>
653// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000654// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000655// CHECK-NEXT: <key>col</key><integer>16</integer>
656// CHECK-NEXT: <key>file</key><integer>0</integer>
657// CHECK-NEXT: </dict>
658// CHECK-NEXT: </array>
659// CHECK-NEXT: </dict>
660// CHECK-NEXT: </array>
661// CHECK-NEXT: </dict>
662// CHECK-NEXT: <dict>
663// CHECK-NEXT: <key>kind</key><string>control</string>
664// CHECK-NEXT: <key>edges</key>
665// CHECK-NEXT: <array>
666// CHECK-NEXT: <dict>
667// CHECK-NEXT: <key>start</key>
668// CHECK-NEXT: <array>
669// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000670// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000671// CHECK-NEXT: <key>col</key><integer>5</integer>
672// CHECK-NEXT: <key>file</key><integer>0</integer>
673// CHECK-NEXT: </dict>
674// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000675// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000676// CHECK-NEXT: <key>col</key><integer>16</integer>
677// CHECK-NEXT: <key>file</key><integer>0</integer>
678// CHECK-NEXT: </dict>
679// CHECK-NEXT: </array>
680// CHECK-NEXT: <key>end</key>
681// CHECK-NEXT: <array>
682// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000683// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000684// CHECK-NEXT: <key>col</key><integer>18</integer>
685// CHECK-NEXT: <key>file</key><integer>0</integer>
686// CHECK-NEXT: </dict>
687// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000688// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000689// CHECK-NEXT: <key>col</key><integer>18</integer>
690// CHECK-NEXT: <key>file</key><integer>0</integer>
691// CHECK-NEXT: </dict>
692// CHECK-NEXT: </array>
693// CHECK-NEXT: </dict>
694// CHECK-NEXT: </array>
695// CHECK-NEXT: </dict>
696// CHECK-NEXT: <dict>
697// CHECK-NEXT: <key>kind</key><string>event</string>
698// CHECK-NEXT: <key>location</key>
699// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000700// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000701// CHECK-NEXT: <key>col</key><integer>18</integer>
702// CHECK-NEXT: <key>file</key><integer>0</integer>
703// CHECK-NEXT: </dict>
704// CHECK-NEXT: <key>ranges</key>
705// CHECK-NEXT: <array>
706// CHECK-NEXT: <array>
707// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000708// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000709// CHECK-NEXT: <key>col</key><integer>18</integer>
710// CHECK-NEXT: <key>file</key><integer>0</integer>
711// CHECK-NEXT: </dict>
712// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000713// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000714// CHECK-NEXT: <key>col</key><integer>18</integer>
715// CHECK-NEXT: <key>file</key><integer>0</integer>
716// CHECK-NEXT: </dict>
717// CHECK-NEXT: </array>
718// CHECK-NEXT: </array>
719// CHECK-NEXT: <key>depth</key><integer>0</integer>
720// CHECK-NEXT: <key>extended_message</key>
721// CHECK-NEXT: <string>Passing null pointer value via 1st parameter &apos;p&apos;</string>
722// CHECK-NEXT: <key>message</key>
723// CHECK-NEXT: <string>Passing null pointer value via 1st parameter &apos;p&apos;</string>
724// CHECK-NEXT: </dict>
725// CHECK-NEXT: <dict>
726// CHECK-NEXT: <key>kind</key><string>event</string>
727// CHECK-NEXT: <key>location</key>
728// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000729// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000730// CHECK-NEXT: <key>col</key><integer>5</integer>
731// CHECK-NEXT: <key>file</key><integer>0</integer>
732// CHECK-NEXT: </dict>
733// CHECK-NEXT: <key>ranges</key>
734// CHECK-NEXT: <array>
735// CHECK-NEXT: <array>
736// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000737// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000738// CHECK-NEXT: <key>col</key><integer>5</integer>
739// CHECK-NEXT: <key>file</key><integer>0</integer>
740// CHECK-NEXT: </dict>
741// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000742// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000743// CHECK-NEXT: <key>col</key><integer>19</integer>
744// CHECK-NEXT: <key>file</key><integer>0</integer>
745// CHECK-NEXT: </dict>
746// CHECK-NEXT: </array>
747// CHECK-NEXT: </array>
748// CHECK-NEXT: <key>depth</key><integer>0</integer>
749// CHECK-NEXT: <key>extended_message</key>
750// CHECK-NEXT: <string>Calling &apos;triggers_bug&apos;</string>
751// CHECK-NEXT: <key>message</key>
752// CHECK-NEXT: <string>Calling &apos;triggers_bug&apos;</string>
753// CHECK-NEXT: </dict>
754// CHECK-NEXT: <dict>
755// CHECK-NEXT: <key>kind</key><string>event</string>
756// CHECK-NEXT: <key>location</key>
757// CHECK-NEXT: <dict>
758// CHECK-NEXT: <key>line</key><integer>32</integer>
759// CHECK-NEXT: <key>col</key><integer>1</integer>
760// CHECK-NEXT: <key>file</key><integer>0</integer>
761// CHECK-NEXT: </dict>
762// CHECK-NEXT: <key>depth</key><integer>1</integer>
763// CHECK-NEXT: <key>extended_message</key>
764// CHECK-NEXT: <string>Entered call from &apos;bar&apos;</string>
765// CHECK-NEXT: <key>message</key>
766// CHECK-NEXT: <string>Entered call from &apos;bar&apos;</string>
767// CHECK-NEXT: </dict>
768// CHECK-NEXT: <dict>
769// CHECK-NEXT: <key>kind</key><string>control</string>
770// CHECK-NEXT: <key>edges</key>
771// CHECK-NEXT: <array>
772// CHECK-NEXT: <dict>
773// CHECK-NEXT: <key>start</key>
774// CHECK-NEXT: <array>
775// CHECK-NEXT: <dict>
776// CHECK-NEXT: <key>line</key><integer>32</integer>
777// CHECK-NEXT: <key>col</key><integer>1</integer>
778// CHECK-NEXT: <key>file</key><integer>0</integer>
779// CHECK-NEXT: </dict>
780// CHECK-NEXT: <dict>
781// CHECK-NEXT: <key>line</key><integer>32</integer>
782// CHECK-NEXT: <key>col</key><integer>4</integer>
783// CHECK-NEXT: <key>file</key><integer>0</integer>
784// CHECK-NEXT: </dict>
785// CHECK-NEXT: </array>
786// CHECK-NEXT: <key>end</key>
787// CHECK-NEXT: <array>
788// CHECK-NEXT: <dict>
789// CHECK-NEXT: <key>line</key><integer>33</integer>
790// CHECK-NEXT: <key>col</key><integer>3</integer>
791// CHECK-NEXT: <key>file</key><integer>0</integer>
792// CHECK-NEXT: </dict>
793// CHECK-NEXT: <dict>
794// CHECK-NEXT: <key>line</key><integer>33</integer>
795// CHECK-NEXT: <key>col</key><integer>3</integer>
796// CHECK-NEXT: <key>file</key><integer>0</integer>
797// CHECK-NEXT: </dict>
798// CHECK-NEXT: </array>
799// CHECK-NEXT: </dict>
800// CHECK-NEXT: </array>
801// CHECK-NEXT: </dict>
802// CHECK-NEXT: <dict>
Anna Zaks4e16b292013-04-23 23:57:43 +0000803// CHECK-NEXT: <key>kind</key><string>control</string>
804// CHECK-NEXT: <key>edges</key>
805// CHECK-NEXT: <array>
806// CHECK-NEXT: <dict>
807// CHECK-NEXT: <key>start</key>
808// CHECK-NEXT: <array>
809// CHECK-NEXT: <dict>
810// CHECK-NEXT: <key>line</key><integer>33</integer>
811// CHECK-NEXT: <key>col</key><integer>3</integer>
812// CHECK-NEXT: <key>file</key><integer>0</integer>
813// CHECK-NEXT: </dict>
814// CHECK-NEXT: <dict>
815// CHECK-NEXT: <key>line</key><integer>33</integer>
816// CHECK-NEXT: <key>col</key><integer>3</integer>
817// CHECK-NEXT: <key>file</key><integer>0</integer>
818// CHECK-NEXT: </dict>
819// CHECK-NEXT: </array>
820// CHECK-NEXT: <key>end</key>
821// CHECK-NEXT: <array>
822// CHECK-NEXT: <dict>
823// CHECK-NEXT: <key>line</key><integer>33</integer>
824// CHECK-NEXT: <key>col</key><integer>6</integer>
825// CHECK-NEXT: <key>file</key><integer>0</integer>
826// CHECK-NEXT: </dict>
827// CHECK-NEXT: <dict>
828// CHECK-NEXT: <key>line</key><integer>33</integer>
829// CHECK-NEXT: <key>col</key><integer>6</integer>
830// CHECK-NEXT: <key>file</key><integer>0</integer>
831// CHECK-NEXT: </dict>
832// CHECK-NEXT: </array>
833// CHECK-NEXT: </dict>
834// CHECK-NEXT: </array>
835// CHECK-NEXT: </dict>
836// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +0000837// CHECK-NEXT: <key>kind</key><string>event</string>
838// CHECK-NEXT: <key>location</key>
839// CHECK-NEXT: <dict>
840// CHECK-NEXT: <key>line</key><integer>33</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +0000841// CHECK-NEXT: <key>col</key><integer>6</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000842// CHECK-NEXT: <key>file</key><integer>0</integer>
843// CHECK-NEXT: </dict>
844// CHECK-NEXT: <key>ranges</key>
845// CHECK-NEXT: <array>
846// CHECK-NEXT: <array>
847// CHECK-NEXT: <dict>
848// CHECK-NEXT: <key>line</key><integer>33</integer>
849// CHECK-NEXT: <key>col</key><integer>4</integer>
850// CHECK-NEXT: <key>file</key><integer>0</integer>
851// CHECK-NEXT: </dict>
852// CHECK-NEXT: <dict>
853// CHECK-NEXT: <key>line</key><integer>33</integer>
854// CHECK-NEXT: <key>col</key><integer>4</integer>
855// CHECK-NEXT: <key>file</key><integer>0</integer>
856// CHECK-NEXT: </dict>
857// CHECK-NEXT: </array>
858// CHECK-NEXT: </array>
859// CHECK-NEXT: <key>depth</key><integer>1</integer>
860// CHECK-NEXT: <key>extended_message</key>
861// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
862// CHECK-NEXT: <key>message</key>
863// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000864// CHECK-NEXT: </dict>
865// CHECK-NEXT: </array>
866// CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
867// CHECK-NEXT: <key>category</key><string>Logic error</string>
868// CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string>
Gabor Horvathc18a1132015-02-09 22:52:26 +0000869// CHECK-NEXT: <key>check_name</key><string>core.NullDereference</string>
Gabor Horvathefec1632015-10-22 11:53:04 +0000870// CHECK-NEXT: <!-- This hash is experimental and going to change! -->
871// CHECK-NEXT: <key>issue_hash_content_of_line_in_context</key><string>1ee3fb0b2fbd9c66e0cc34ca1181ece3</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000872// CHECK-NEXT: <key>issue_context_kind</key><string>function</string>
873// CHECK-NEXT: <key>issue_context</key><string>triggers_bug</string>
Gabor Horvathefec1632015-10-22 11:53:04 +0000874// CHECK-NEXT: <key>issue_hash_function_offset</key><string>1</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000875// CHECK-NEXT: <key>location</key>
876// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +0000877// CHECK-NEXT: <key>line</key><integer>33</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +0000878// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000879// CHECK-NEXT: <key>file</key><integer>0</integer>
880// CHECK-NEXT: </dict>
881// CHECK-NEXT: </dict>
882// CHECK-NEXT: <dict>
883// CHECK-NEXT: <key>path</key>
884// CHECK-NEXT: <array>
885// CHECK-NEXT: <dict>
886// CHECK-NEXT: <key>kind</key><string>event</string>
887// CHECK-NEXT: <key>location</key>
888// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000889// CHECK-NEXT: <key>line</key><integer>58</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000890// CHECK-NEXT: <key>col</key><integer>3</integer>
891// CHECK-NEXT: <key>file</key><integer>0</integer>
892// CHECK-NEXT: </dict>
893// CHECK-NEXT: <key>ranges</key>
894// CHECK-NEXT: <array>
895// CHECK-NEXT: <array>
896// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000897// CHECK-NEXT: <key>line</key><integer>58</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000898// CHECK-NEXT: <key>col</key><integer>3</integer>
899// CHECK-NEXT: <key>file</key><integer>0</integer>
900// CHECK-NEXT: </dict>
901// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000902// CHECK-NEXT: <key>line</key><integer>58</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000903// CHECK-NEXT: <key>col</key><integer>8</integer>
904// CHECK-NEXT: <key>file</key><integer>0</integer>
905// CHECK-NEXT: </dict>
906// CHECK-NEXT: </array>
907// CHECK-NEXT: </array>
908// CHECK-NEXT: <key>depth</key><integer>0</integer>
909// CHECK-NEXT: <key>extended_message</key>
Ted Kremenek37c777e2013-02-26 19:44:38 +0000910// CHECK-NEXT: <string>&apos;p&apos; initialized to a null pointer value</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000911// CHECK-NEXT: <key>message</key>
Ted Kremenek37c777e2013-02-26 19:44:38 +0000912// CHECK-NEXT: <string>&apos;p&apos; initialized to a null pointer value</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000913// CHECK-NEXT: </dict>
914// CHECK-NEXT: <dict>
915// CHECK-NEXT: <key>kind</key><string>control</string>
916// CHECK-NEXT: <key>edges</key>
917// CHECK-NEXT: <array>
918// CHECK-NEXT: <dict>
919// CHECK-NEXT: <key>start</key>
920// CHECK-NEXT: <array>
921// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000922// CHECK-NEXT: <key>line</key><integer>58</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000923// CHECK-NEXT: <key>col</key><integer>3</integer>
924// CHECK-NEXT: <key>file</key><integer>0</integer>
925// CHECK-NEXT: </dict>
926// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000927// CHECK-NEXT: <key>line</key><integer>58</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000928// CHECK-NEXT: <key>col</key><integer>5</integer>
929// CHECK-NEXT: <key>file</key><integer>0</integer>
930// CHECK-NEXT: </dict>
931// CHECK-NEXT: </array>
932// CHECK-NEXT: <key>end</key>
933// CHECK-NEXT: <array>
934// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000935// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000936// CHECK-NEXT: <key>col</key><integer>3</integer>
937// CHECK-NEXT: <key>file</key><integer>0</integer>
938// CHECK-NEXT: </dict>
939// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000940// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000941// CHECK-NEXT: <key>col</key><integer>3</integer>
942// CHECK-NEXT: <key>file</key><integer>0</integer>
943// CHECK-NEXT: </dict>
944// CHECK-NEXT: </array>
945// CHECK-NEXT: </dict>
946// CHECK-NEXT: </array>
947// CHECK-NEXT: </dict>
948// CHECK-NEXT: <dict>
949// CHECK-NEXT: <key>kind</key><string>event</string>
950// CHECK-NEXT: <key>location</key>
951// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000952// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000953// CHECK-NEXT: <key>col</key><integer>3</integer>
954// CHECK-NEXT: <key>file</key><integer>0</integer>
955// CHECK-NEXT: </dict>
956// CHECK-NEXT: <key>ranges</key>
957// CHECK-NEXT: <array>
958// CHECK-NEXT: <array>
959// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000960// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000961// CHECK-NEXT: <key>col</key><integer>3</integer>
962// CHECK-NEXT: <key>file</key><integer>0</integer>
963// CHECK-NEXT: </dict>
964// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000965// CHECK-NEXT: <key>line</key><integer>61</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000966// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000967// CHECK-NEXT: <key>file</key><integer>0</integer>
968// CHECK-NEXT: </dict>
969// CHECK-NEXT: </array>
970// CHECK-NEXT: </array>
971// CHECK-NEXT: <key>depth</key><integer>0</integer>
972// CHECK-NEXT: <key>extended_message</key>
973// CHECK-NEXT: <string>Calling anonymous block</string>
974// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +0000975// CHECK-NEXT: <string>Calling anonymous block</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000976// CHECK-NEXT: </dict>
977// CHECK-NEXT: <dict>
978// CHECK-NEXT: <key>kind</key><string>event</string>
979// CHECK-NEXT: <key>location</key>
980// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000981// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000982// CHECK-NEXT: <key>col</key><integer>3</integer>
983// CHECK-NEXT: <key>file</key><integer>0</integer>
984// CHECK-NEXT: </dict>
985// CHECK-NEXT: <key>depth</key><integer>1</integer>
986// CHECK-NEXT: <key>extended_message</key>
987// CHECK-NEXT: <string>Entered call from &apos;test_block__capture_null&apos;</string>
988// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +0000989// CHECK-NEXT: <string>Entered call from &apos;test_block__capture_null&apos;</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000990// CHECK-NEXT: </dict>
991// CHECK-NEXT: <dict>
992// CHECK-NEXT: <key>kind</key><string>control</string>
993// CHECK-NEXT: <key>edges</key>
994// CHECK-NEXT: <array>
995// CHECK-NEXT: <dict>
996// CHECK-NEXT: <key>start</key>
997// CHECK-NEXT: <array>
998// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000999// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001000// CHECK-NEXT: <key>col</key><integer>3</integer>
1001// CHECK-NEXT: <key>file</key><integer>0</integer>
1002// CHECK-NEXT: </dict>
1003// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001004// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001005// CHECK-NEXT: <key>col</key><integer>3</integer>
1006// CHECK-NEXT: <key>file</key><integer>0</integer>
1007// CHECK-NEXT: </dict>
1008// CHECK-NEXT: </array>
1009// CHECK-NEXT: <key>end</key>
1010// CHECK-NEXT: <array>
1011// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001012// CHECK-NEXT: <key>line</key><integer>60</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001013// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001014// CHECK-NEXT: <key>file</key><integer>0</integer>
1015// CHECK-NEXT: </dict>
1016// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001017// CHECK-NEXT: <key>line</key><integer>60</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001018// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001019// CHECK-NEXT: <key>file</key><integer>0</integer>
1020// CHECK-NEXT: </dict>
1021// CHECK-NEXT: </array>
1022// CHECK-NEXT: </dict>
1023// CHECK-NEXT: </array>
1024// CHECK-NEXT: </dict>
1025// CHECK-NEXT: <dict>
Anna Zaks4e16b292013-04-23 23:57:43 +00001026// CHECK-NEXT: <key>kind</key><string>control</string>
1027// CHECK-NEXT: <key>edges</key>
1028// CHECK-NEXT: <array>
1029// CHECK-NEXT: <dict>
1030// CHECK-NEXT: <key>start</key>
1031// CHECK-NEXT: <array>
1032// CHECK-NEXT: <dict>
1033// CHECK-NEXT: <key>line</key><integer>60</integer>
1034// CHECK-NEXT: <key>col</key><integer>5</integer>
1035// CHECK-NEXT: <key>file</key><integer>0</integer>
1036// CHECK-NEXT: </dict>
1037// CHECK-NEXT: <dict>
1038// CHECK-NEXT: <key>line</key><integer>60</integer>
1039// CHECK-NEXT: <key>col</key><integer>5</integer>
1040// CHECK-NEXT: <key>file</key><integer>0</integer>
1041// CHECK-NEXT: </dict>
1042// CHECK-NEXT: </array>
1043// CHECK-NEXT: <key>end</key>
1044// CHECK-NEXT: <array>
1045// CHECK-NEXT: <dict>
1046// CHECK-NEXT: <key>line</key><integer>60</integer>
1047// CHECK-NEXT: <key>col</key><integer>8</integer>
1048// CHECK-NEXT: <key>file</key><integer>0</integer>
1049// CHECK-NEXT: </dict>
1050// CHECK-NEXT: <dict>
1051// CHECK-NEXT: <key>line</key><integer>60</integer>
1052// CHECK-NEXT: <key>col</key><integer>8</integer>
1053// CHECK-NEXT: <key>file</key><integer>0</integer>
1054// CHECK-NEXT: </dict>
1055// CHECK-NEXT: </array>
1056// CHECK-NEXT: </dict>
1057// CHECK-NEXT: </array>
1058// CHECK-NEXT: </dict>
1059// CHECK-NEXT: <dict>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001060// CHECK-NEXT: <key>kind</key><string>event</string>
1061// CHECK-NEXT: <key>location</key>
1062// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001063// CHECK-NEXT: <key>line</key><integer>60</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001064// CHECK-NEXT: <key>col</key><integer>8</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001065// CHECK-NEXT: <key>file</key><integer>0</integer>
1066// CHECK-NEXT: </dict>
1067// CHECK-NEXT: <key>ranges</key>
1068// CHECK-NEXT: <array>
1069// CHECK-NEXT: <array>
1070// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001071// CHECK-NEXT: <key>line</key><integer>60</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001072// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001073// CHECK-NEXT: <key>file</key><integer>0</integer>
1074// CHECK-NEXT: </dict>
1075// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001076// CHECK-NEXT: <key>line</key><integer>60</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001077// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001078// CHECK-NEXT: <key>file</key><integer>0</integer>
1079// CHECK-NEXT: </dict>
1080// CHECK-NEXT: </array>
1081// CHECK-NEXT: </array>
1082// CHECK-NEXT: <key>depth</key><integer>1</integer>
1083// CHECK-NEXT: <key>extended_message</key>
1084// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1085// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001086// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001087// CHECK-NEXT: </dict>
1088// CHECK-NEXT: </array>
1089// CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1090// CHECK-NEXT: <key>category</key><string>Logic error</string>
1091// CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string>
Gabor Horvathc18a1132015-02-09 22:52:26 +00001092// CHECK-NEXT: <key>check_name</key><string>core.NullDereference</string>
Gabor Horvathefec1632015-10-22 11:53:04 +00001093// CHECK-NEXT: <!-- This hash is experimental and going to change! -->
1094// CHECK-NEXT: <key>issue_hash_content_of_line_in_context</key><string>a2e7504f29818834127c44ba841f4da8</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001095// CHECK-NEXT: <key>location</key>
1096// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001097// CHECK-NEXT: <key>line</key><integer>60</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001098// CHECK-NEXT: <key>col</key><integer>8</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001099// CHECK-NEXT: <key>file</key><integer>0</integer>
1100// CHECK-NEXT: </dict>
1101// CHECK-NEXT: </dict>
1102// CHECK-NEXT: <dict>
1103// CHECK-NEXT: <key>path</key>
1104// CHECK-NEXT: <array>
1105// CHECK-NEXT: <dict>
1106// CHECK-NEXT: <key>kind</key><string>control</string>
1107// CHECK-NEXT: <key>edges</key>
1108// CHECK-NEXT: <array>
1109// CHECK-NEXT: <dict>
1110// CHECK-NEXT: <key>start</key>
1111// CHECK-NEXT: <array>
1112// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001113// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001114// CHECK-NEXT: <key>col</key><integer>3</integer>
1115// CHECK-NEXT: <key>file</key><integer>0</integer>
1116// CHECK-NEXT: </dict>
1117// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001118// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001119// CHECK-NEXT: <key>col</key><integer>5</integer>
1120// CHECK-NEXT: <key>file</key><integer>0</integer>
1121// CHECK-NEXT: </dict>
1122// CHECK-NEXT: </array>
1123// CHECK-NEXT: <key>end</key>
1124// CHECK-NEXT: <array>
1125// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001126// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001127// CHECK-NEXT: <key>col</key><integer>12</integer>
1128// CHECK-NEXT: <key>file</key><integer>0</integer>
1129// CHECK-NEXT: </dict>
1130// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001131// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001132// CHECK-NEXT: <key>col</key><integer>12</integer>
1133// CHECK-NEXT: <key>file</key><integer>0</integer>
1134// CHECK-NEXT: </dict>
1135// CHECK-NEXT: </array>
1136// CHECK-NEXT: </dict>
1137// CHECK-NEXT: </array>
1138// CHECK-NEXT: </dict>
1139// CHECK-NEXT: <dict>
1140// CHECK-NEXT: <key>kind</key><string>event</string>
1141// CHECK-NEXT: <key>location</key>
1142// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001143// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-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: <key>ranges</key>
1148// CHECK-NEXT: <array>
1149// CHECK-NEXT: <array>
1150// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001151// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001152// CHECK-NEXT: <key>col</key><integer>12</integer>
1153// CHECK-NEXT: <key>file</key><integer>0</integer>
1154// CHECK-NEXT: </dict>
1155// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001156// CHECK-NEXT: <key>line</key><integer>69</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001157// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001158// CHECK-NEXT: <key>file</key><integer>0</integer>
1159// CHECK-NEXT: </dict>
1160// CHECK-NEXT: </array>
1161// CHECK-NEXT: </array>
1162// CHECK-NEXT: <key>depth</key><integer>0</integer>
1163// CHECK-NEXT: <key>extended_message</key>
1164// CHECK-NEXT: <string>Calling anonymous block</string>
1165// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001166// CHECK-NEXT: <string>Calling anonymous block</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001167// CHECK-NEXT: </dict>
1168// CHECK-NEXT: <dict>
1169// CHECK-NEXT: <key>kind</key><string>event</string>
1170// CHECK-NEXT: <key>location</key>
1171// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001172// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001173// CHECK-NEXT: <key>col</key><integer>12</integer>
1174// CHECK-NEXT: <key>file</key><integer>0</integer>
1175// CHECK-NEXT: </dict>
1176// CHECK-NEXT: <key>depth</key><integer>1</integer>
1177// CHECK-NEXT: <key>extended_message</key>
1178// CHECK-NEXT: <string>Entered call from &apos;test_block_ret&apos;</string>
1179// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001180// CHECK-NEXT: <string>Entered call from &apos;test_block_ret&apos;</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001181// CHECK-NEXT: </dict>
1182// CHECK-NEXT: <dict>
1183// CHECK-NEXT: <key>kind</key><string>control</string>
1184// CHECK-NEXT: <key>edges</key>
1185// CHECK-NEXT: <array>
1186// CHECK-NEXT: <dict>
1187// CHECK-NEXT: <key>start</key>
1188// CHECK-NEXT: <array>
1189// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001190// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001191// CHECK-NEXT: <key>col</key><integer>12</integer>
1192// CHECK-NEXT: <key>file</key><integer>0</integer>
1193// CHECK-NEXT: </dict>
1194// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001195// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001196// CHECK-NEXT: <key>col</key><integer>12</integer>
1197// CHECK-NEXT: <key>file</key><integer>0</integer>
1198// CHECK-NEXT: </dict>
1199// CHECK-NEXT: </array>
1200// CHECK-NEXT: <key>end</key>
1201// CHECK-NEXT: <array>
1202// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001203// CHECK-NEXT: <key>line</key><integer>67</integer>
1204// CHECK-NEXT: <key>col</key><integer>5</integer>
1205// CHECK-NEXT: <key>file</key><integer>0</integer>
1206// CHECK-NEXT: </dict>
1207// CHECK-NEXT: <dict>
1208// CHECK-NEXT: <key>line</key><integer>67</integer>
1209// CHECK-NEXT: <key>col</key><integer>7</integer>
1210// CHECK-NEXT: <key>file</key><integer>0</integer>
1211// CHECK-NEXT: </dict>
1212// CHECK-NEXT: </array>
1213// CHECK-NEXT: </dict>
1214// CHECK-NEXT: </array>
1215// CHECK-NEXT: </dict>
1216// CHECK-NEXT: <dict>
1217// CHECK-NEXT: <key>kind</key><string>event</string>
1218// CHECK-NEXT: <key>location</key>
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: <key>ranges</key>
1225// CHECK-NEXT: <array>
1226// CHECK-NEXT: <array>
1227// CHECK-NEXT: <dict>
1228// CHECK-NEXT: <key>line</key><integer>67</integer>
1229// CHECK-NEXT: <key>col</key><integer>5</integer>
1230// CHECK-NEXT: <key>file</key><integer>0</integer>
1231// CHECK-NEXT: </dict>
1232// CHECK-NEXT: <dict>
1233// CHECK-NEXT: <key>line</key><integer>67</integer>
1234// CHECK-NEXT: <key>col</key><integer>10</integer>
1235// CHECK-NEXT: <key>file</key><integer>0</integer>
1236// CHECK-NEXT: </dict>
1237// CHECK-NEXT: </array>
1238// CHECK-NEXT: </array>
1239// CHECK-NEXT: <key>depth</key><integer>1</integer>
1240// CHECK-NEXT: <key>extended_message</key>
Ted Kremenek37c777e2013-02-26 19:44:38 +00001241// CHECK-NEXT: <string>&apos;q&apos; initialized to a null pointer value</string>
Ted Kremeneka5958862012-10-25 22:07:10 +00001242// CHECK-NEXT: <key>message</key>
Ted Kremenek37c777e2013-02-26 19:44:38 +00001243// CHECK-NEXT: <string>&apos;q&apos; initialized to a null pointer value</string>
Ted Kremeneka5958862012-10-25 22:07:10 +00001244// CHECK-NEXT: </dict>
1245// CHECK-NEXT: <dict>
1246// CHECK-NEXT: <key>kind</key><string>control</string>
1247// CHECK-NEXT: <key>edges</key>
1248// CHECK-NEXT: <array>
1249// CHECK-NEXT: <dict>
1250// CHECK-NEXT: <key>start</key>
1251// CHECK-NEXT: <array>
1252// CHECK-NEXT: <dict>
1253// CHECK-NEXT: <key>line</key><integer>67</integer>
1254// CHECK-NEXT: <key>col</key><integer>5</integer>
1255// CHECK-NEXT: <key>file</key><integer>0</integer>
1256// CHECK-NEXT: </dict>
1257// CHECK-NEXT: <dict>
1258// CHECK-NEXT: <key>line</key><integer>67</integer>
1259// CHECK-NEXT: <key>col</key><integer>7</integer>
1260// CHECK-NEXT: <key>file</key><integer>0</integer>
1261// CHECK-NEXT: </dict>
1262// CHECK-NEXT: </array>
1263// CHECK-NEXT: <key>end</key>
1264// CHECK-NEXT: <array>
1265// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +00001266// CHECK-NEXT: <key>line</key><integer>68</integer>
1267// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001268// CHECK-NEXT: <key>file</key><integer>0</integer>
1269// CHECK-NEXT: </dict>
1270// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +00001271// CHECK-NEXT: <key>line</key><integer>68</integer>
Ted Kremeneka5958862012-10-25 22:07:10 +00001272// CHECK-NEXT: <key>col</key><integer>10</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001273// CHECK-NEXT: <key>file</key><integer>0</integer>
1274// CHECK-NEXT: </dict>
1275// CHECK-NEXT: </array>
1276// CHECK-NEXT: </dict>
1277// CHECK-NEXT: </array>
1278// CHECK-NEXT: </dict>
1279// CHECK-NEXT: <dict>
1280// CHECK-NEXT: <key>kind</key><string>event</string>
1281// CHECK-NEXT: <key>location</key>
1282// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +00001283// CHECK-NEXT: <key>line</key><integer>68</integer>
1284// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001285// CHECK-NEXT: <key>file</key><integer>0</integer>
1286// CHECK-NEXT: </dict>
1287// CHECK-NEXT: <key>ranges</key>
1288// CHECK-NEXT: <array>
1289// CHECK-NEXT: <array>
1290// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +00001291// CHECK-NEXT: <key>line</key><integer>68</integer>
1292// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001293// CHECK-NEXT: <key>file</key><integer>0</integer>
1294// CHECK-NEXT: </dict>
1295// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +00001296// CHECK-NEXT: <key>line</key><integer>68</integer>
1297// CHECK-NEXT: <key>col</key><integer>12</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001298// CHECK-NEXT: <key>file</key><integer>0</integer>
1299// CHECK-NEXT: </dict>
1300// CHECK-NEXT: </array>
1301// CHECK-NEXT: </array>
1302// CHECK-NEXT: <key>depth</key><integer>1</integer>
1303// CHECK-NEXT: <key>extended_message</key>
1304// CHECK-NEXT: <string>Returning null pointer (loaded from &apos;q&apos;)</string>
1305// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001306// CHECK-NEXT: <string>Returning null pointer (loaded from &apos;q&apos;)</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001307// CHECK-NEXT: </dict>
1308// CHECK-NEXT: <dict>
1309// CHECK-NEXT: <key>kind</key><string>event</string>
1310// CHECK-NEXT: <key>location</key>
1311// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001312// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-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: <key>ranges</key>
1317// CHECK-NEXT: <array>
1318// CHECK-NEXT: <array>
1319// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001320// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001321// CHECK-NEXT: <key>col</key><integer>12</integer>
1322// CHECK-NEXT: <key>file</key><integer>0</integer>
1323// CHECK-NEXT: </dict>
1324// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001325// CHECK-NEXT: <key>line</key><integer>69</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001326// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001327// CHECK-NEXT: <key>file</key><integer>0</integer>
1328// CHECK-NEXT: </dict>
1329// CHECK-NEXT: </array>
1330// CHECK-NEXT: </array>
Jordan Rose526d93c2013-04-12 00:44:17 +00001331// CHECK-NEXT: <key>depth</key><integer>0</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001332// CHECK-NEXT: <key>extended_message</key>
1333// CHECK-NEXT: <string>Returning to caller</string>
1334// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001335// CHECK-NEXT: <string>Returning to caller</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001336// CHECK-NEXT: </dict>
1337// CHECK-NEXT: <dict>
1338// CHECK-NEXT: <key>kind</key><string>control</string>
1339// CHECK-NEXT: <key>edges</key>
1340// CHECK-NEXT: <array>
1341// CHECK-NEXT: <dict>
1342// CHECK-NEXT: <key>start</key>
1343// CHECK-NEXT: <array>
1344// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001345// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001346// CHECK-NEXT: <key>col</key><integer>12</integer>
1347// CHECK-NEXT: <key>file</key><integer>0</integer>
1348// CHECK-NEXT: </dict>
1349// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001350// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001351// CHECK-NEXT: <key>col</key><integer>12</integer>
1352// CHECK-NEXT: <key>file</key><integer>0</integer>
1353// CHECK-NEXT: </dict>
1354// CHECK-NEXT: </array>
1355// CHECK-NEXT: <key>end</key>
1356// CHECK-NEXT: <array>
1357// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001358// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001359// CHECK-NEXT: <key>col</key><integer>3</integer>
1360// CHECK-NEXT: <key>file</key><integer>0</integer>
1361// CHECK-NEXT: </dict>
1362// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001363// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001364// CHECK-NEXT: <key>col</key><integer>5</integer>
1365// CHECK-NEXT: <key>file</key><integer>0</integer>
1366// CHECK-NEXT: </dict>
1367// CHECK-NEXT: </array>
1368// CHECK-NEXT: </dict>
1369// CHECK-NEXT: </array>
1370// CHECK-NEXT: </dict>
1371// CHECK-NEXT: <dict>
1372// CHECK-NEXT: <key>kind</key><string>event</string>
1373// CHECK-NEXT: <key>location</key>
1374// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001375// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-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: <key>ranges</key>
1380// CHECK-NEXT: <array>
1381// CHECK-NEXT: <array>
1382// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001383// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001384// CHECK-NEXT: <key>col</key><integer>3</integer>
1385// CHECK-NEXT: <key>file</key><integer>0</integer>
1386// CHECK-NEXT: </dict>
1387// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001388// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001389// CHECK-NEXT: <key>col</key><integer>8</integer>
1390// CHECK-NEXT: <key>file</key><integer>0</integer>
1391// CHECK-NEXT: </dict>
1392// CHECK-NEXT: </array>
1393// CHECK-NEXT: </array>
1394// CHECK-NEXT: <key>depth</key><integer>0</integer>
1395// CHECK-NEXT: <key>extended_message</key>
Ted Kremenek37c777e2013-02-26 19:44:38 +00001396// CHECK-NEXT: <string>&apos;p&apos; initialized to a null pointer value</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001397// CHECK-NEXT: <key>message</key>
Ted Kremenek37c777e2013-02-26 19:44:38 +00001398// CHECK-NEXT: <string>&apos;p&apos; initialized to a null pointer value</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001399// CHECK-NEXT: </dict>
1400// CHECK-NEXT: <dict>
1401// CHECK-NEXT: <key>kind</key><string>control</string>
1402// CHECK-NEXT: <key>edges</key>
1403// CHECK-NEXT: <array>
1404// CHECK-NEXT: <dict>
1405// CHECK-NEXT: <key>start</key>
1406// CHECK-NEXT: <array>
1407// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001408// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001409// CHECK-NEXT: <key>col</key><integer>3</integer>
1410// CHECK-NEXT: <key>file</key><integer>0</integer>
1411// CHECK-NEXT: </dict>
1412// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001413// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001414// CHECK-NEXT: <key>col</key><integer>5</integer>
1415// CHECK-NEXT: <key>file</key><integer>0</integer>
1416// CHECK-NEXT: </dict>
1417// CHECK-NEXT: </array>
1418// CHECK-NEXT: <key>end</key>
1419// CHECK-NEXT: <array>
1420// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001421// CHECK-NEXT: <key>line</key><integer>70</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001422// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001423// CHECK-NEXT: <key>file</key><integer>0</integer>
1424// CHECK-NEXT: </dict>
1425// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001426// CHECK-NEXT: <key>line</key><integer>70</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001427// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001428// CHECK-NEXT: <key>file</key><integer>0</integer>
1429// CHECK-NEXT: </dict>
1430// CHECK-NEXT: </array>
1431// CHECK-NEXT: </dict>
1432// CHECK-NEXT: </array>
1433// CHECK-NEXT: </dict>
1434// CHECK-NEXT: <dict>
1435// CHECK-NEXT: <key>kind</key><string>event</string>
1436// CHECK-NEXT: <key>location</key>
1437// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001438// CHECK-NEXT: <key>line</key><integer>70</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001439// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001440// CHECK-NEXT: <key>file</key><integer>0</integer>
1441// CHECK-NEXT: </dict>
1442// CHECK-NEXT: <key>ranges</key>
1443// CHECK-NEXT: <array>
1444// CHECK-NEXT: <array>
1445// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001446// CHECK-NEXT: <key>line</key><integer>70</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001447// CHECK-NEXT: <key>col</key><integer>4</integer>
1448// CHECK-NEXT: <key>file</key><integer>0</integer>
1449// CHECK-NEXT: </dict>
1450// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001451// CHECK-NEXT: <key>line</key><integer>70</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001452// CHECK-NEXT: <key>col</key><integer>4</integer>
1453// CHECK-NEXT: <key>file</key><integer>0</integer>
1454// CHECK-NEXT: </dict>
1455// CHECK-NEXT: </array>
1456// CHECK-NEXT: </array>
1457// CHECK-NEXT: <key>depth</key><integer>0</integer>
1458// CHECK-NEXT: <key>extended_message</key>
1459// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1460// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001461// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001462// CHECK-NEXT: </dict>
1463// CHECK-NEXT: </array>
1464// CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1465// CHECK-NEXT: <key>category</key><string>Logic error</string>
1466// CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string>
Gabor Horvathc18a1132015-02-09 22:52:26 +00001467// CHECK-NEXT: <key>check_name</key><string>core.NullDereference</string>
Gabor Horvathefec1632015-10-22 11:53:04 +00001468// CHECK-NEXT: <!-- This hash is experimental and going to change! -->
1469// CHECK-NEXT: <key>issue_hash_content_of_line_in_context</key><string>931be9c3a45b61c0a9c99b4772bd6fca</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001470// CHECK-NEXT: <key>issue_context_kind</key><string>function</string>
1471// CHECK-NEXT: <key>issue_context</key><string>test_block_ret</string>
Gabor Horvathefec1632015-10-22 11:53:04 +00001472// CHECK-NEXT: <key>issue_hash_function_offset</key><string>5</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001473// CHECK-NEXT: <key>location</key>
1474// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001475// CHECK-NEXT: <key>line</key><integer>70</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001476// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001477// CHECK-NEXT: <key>file</key><integer>0</integer>
1478// CHECK-NEXT: </dict>
1479// CHECK-NEXT: </dict>
1480// CHECK-NEXT: <dict>
1481// CHECK-NEXT: <key>path</key>
1482// CHECK-NEXT: <array>
1483// CHECK-NEXT: <dict>
1484// CHECK-NEXT: <key>kind</key><string>control</string>
1485// CHECK-NEXT: <key>edges</key>
1486// CHECK-NEXT: <array>
1487// CHECK-NEXT: <dict>
1488// CHECK-NEXT: <key>start</key>
1489// CHECK-NEXT: <array>
1490// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001491// CHECK-NEXT: <key>line</key><integer>74</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001492// CHECK-NEXT: <key>col</key><integer>3</integer>
1493// CHECK-NEXT: <key>file</key><integer>0</integer>
1494// CHECK-NEXT: </dict>
1495// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001496// CHECK-NEXT: <key>line</key><integer>74</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001497// CHECK-NEXT: <key>col</key><integer>9</integer>
1498// CHECK-NEXT: <key>file</key><integer>0</integer>
1499// CHECK-NEXT: </dict>
1500// CHECK-NEXT: </array>
1501// CHECK-NEXT: <key>end</key>
1502// CHECK-NEXT: <array>
1503// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001504// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001505// CHECK-NEXT: <key>col</key><integer>3</integer>
1506// CHECK-NEXT: <key>file</key><integer>0</integer>
1507// CHECK-NEXT: </dict>
1508// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001509// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001510// CHECK-NEXT: <key>col</key><integer>3</integer>
1511// CHECK-NEXT: <key>file</key><integer>0</integer>
1512// CHECK-NEXT: </dict>
1513// CHECK-NEXT: </array>
1514// CHECK-NEXT: </dict>
1515// CHECK-NEXT: </array>
1516// CHECK-NEXT: </dict>
1517// CHECK-NEXT: <dict>
1518// CHECK-NEXT: <key>kind</key><string>event</string>
1519// CHECK-NEXT: <key>location</key>
1520// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001521// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001522// CHECK-NEXT: <key>col</key><integer>3</integer>
1523// CHECK-NEXT: <key>file</key><integer>0</integer>
1524// CHECK-NEXT: </dict>
1525// CHECK-NEXT: <key>ranges</key>
1526// CHECK-NEXT: <array>
1527// CHECK-NEXT: <array>
1528// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001529// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001530// CHECK-NEXT: <key>col</key><integer>3</integer>
1531// CHECK-NEXT: <key>file</key><integer>0</integer>
1532// CHECK-NEXT: </dict>
1533// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001534// CHECK-NEXT: <key>line</key><integer>77</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001535// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001536// CHECK-NEXT: <key>file</key><integer>0</integer>
1537// CHECK-NEXT: </dict>
1538// CHECK-NEXT: </array>
1539// CHECK-NEXT: </array>
1540// CHECK-NEXT: <key>depth</key><integer>0</integer>
1541// CHECK-NEXT: <key>extended_message</key>
1542// CHECK-NEXT: <string>Calling anonymous block</string>
1543// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001544// CHECK-NEXT: <string>Calling anonymous block</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001545// CHECK-NEXT: </dict>
1546// CHECK-NEXT: <dict>
1547// CHECK-NEXT: <key>kind</key><string>event</string>
1548// CHECK-NEXT: <key>location</key>
1549// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001550// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001551// CHECK-NEXT: <key>col</key><integer>3</integer>
1552// CHECK-NEXT: <key>file</key><integer>0</integer>
1553// CHECK-NEXT: </dict>
1554// CHECK-NEXT: <key>depth</key><integer>1</integer>
1555// CHECK-NEXT: <key>extended_message</key>
1556// CHECK-NEXT: <string>Entered call from &apos;test_block_blockvar&apos;</string>
1557// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001558// CHECK-NEXT: <string>Entered call from &apos;test_block_blockvar&apos;</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001559// CHECK-NEXT: </dict>
1560// CHECK-NEXT: <dict>
1561// CHECK-NEXT: <key>kind</key><string>control</string>
1562// CHECK-NEXT: <key>edges</key>
1563// CHECK-NEXT: <array>
1564// CHECK-NEXT: <dict>
1565// CHECK-NEXT: <key>start</key>
1566// CHECK-NEXT: <array>
1567// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001568// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001569// CHECK-NEXT: <key>col</key><integer>3</integer>
1570// CHECK-NEXT: <key>file</key><integer>0</integer>
1571// CHECK-NEXT: </dict>
1572// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001573// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001574// CHECK-NEXT: <key>col</key><integer>3</integer>
1575// CHECK-NEXT: <key>file</key><integer>0</integer>
1576// CHECK-NEXT: </dict>
1577// CHECK-NEXT: </array>
1578// CHECK-NEXT: <key>end</key>
1579// CHECK-NEXT: <array>
1580// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001581// CHECK-NEXT: <key>line</key><integer>76</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001582// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001583// CHECK-NEXT: <key>file</key><integer>0</integer>
1584// CHECK-NEXT: </dict>
1585// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001586// CHECK-NEXT: <key>line</key><integer>76</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001587// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001588// CHECK-NEXT: <key>file</key><integer>0</integer>
1589// CHECK-NEXT: </dict>
1590// CHECK-NEXT: </array>
1591// CHECK-NEXT: </dict>
1592// CHECK-NEXT: </array>
1593// CHECK-NEXT: </dict>
1594// CHECK-NEXT: <dict>
1595// CHECK-NEXT: <key>kind</key><string>event</string>
1596// CHECK-NEXT: <key>location</key>
1597// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001598// CHECK-NEXT: <key>line</key><integer>76</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001599// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001600// CHECK-NEXT: <key>file</key><integer>0</integer>
1601// CHECK-NEXT: </dict>
1602// CHECK-NEXT: <key>ranges</key>
1603// CHECK-NEXT: <array>
1604// CHECK-NEXT: <array>
1605// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001606// CHECK-NEXT: <key>line</key><integer>76</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001607// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001608// CHECK-NEXT: <key>file</key><integer>0</integer>
1609// CHECK-NEXT: </dict>
1610// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001611// CHECK-NEXT: <key>line</key><integer>76</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001612// CHECK-NEXT: <key>col</key><integer>9</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001613// CHECK-NEXT: <key>file</key><integer>0</integer>
1614// CHECK-NEXT: </dict>
1615// CHECK-NEXT: </array>
1616// CHECK-NEXT: </array>
1617// CHECK-NEXT: <key>depth</key><integer>1</integer>
1618// CHECK-NEXT: <key>extended_message</key>
1619// CHECK-NEXT: <string>Null pointer value stored to &apos;p&apos;</string>
1620// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001621// CHECK-NEXT: <string>Null pointer value stored to &apos;p&apos;</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001622// CHECK-NEXT: </dict>
1623// CHECK-NEXT: <dict>
1624// CHECK-NEXT: <key>kind</key><string>event</string>
1625// CHECK-NEXT: <key>location</key>
1626// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001627// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001628// CHECK-NEXT: <key>col</key><integer>3</integer>
1629// CHECK-NEXT: <key>file</key><integer>0</integer>
1630// CHECK-NEXT: </dict>
1631// CHECK-NEXT: <key>ranges</key>
1632// CHECK-NEXT: <array>
1633// CHECK-NEXT: <array>
1634// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001635// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001636// CHECK-NEXT: <key>col</key><integer>3</integer>
1637// CHECK-NEXT: <key>file</key><integer>0</integer>
1638// CHECK-NEXT: </dict>
1639// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001640// CHECK-NEXT: <key>line</key><integer>77</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001641// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001642// CHECK-NEXT: <key>file</key><integer>0</integer>
1643// CHECK-NEXT: </dict>
1644// CHECK-NEXT: </array>
1645// CHECK-NEXT: </array>
Jordan Rose526d93c2013-04-12 00:44:17 +00001646// CHECK-NEXT: <key>depth</key><integer>0</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001647// CHECK-NEXT: <key>extended_message</key>
1648// CHECK-NEXT: <string>Returning to caller</string>
1649// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001650// CHECK-NEXT: <string>Returning to caller</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001651// CHECK-NEXT: </dict>
1652// CHECK-NEXT: <dict>
1653// CHECK-NEXT: <key>kind</key><string>control</string>
1654// CHECK-NEXT: <key>edges</key>
1655// CHECK-NEXT: <array>
1656// CHECK-NEXT: <dict>
1657// CHECK-NEXT: <key>start</key>
1658// CHECK-NEXT: <array>
1659// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001660// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001661// CHECK-NEXT: <key>col</key><integer>3</integer>
1662// CHECK-NEXT: <key>file</key><integer>0</integer>
1663// CHECK-NEXT: </dict>
1664// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001665// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001666// CHECK-NEXT: <key>col</key><integer>3</integer>
1667// CHECK-NEXT: <key>file</key><integer>0</integer>
1668// CHECK-NEXT: </dict>
1669// CHECK-NEXT: </array>
1670// CHECK-NEXT: <key>end</key>
1671// CHECK-NEXT: <array>
1672// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001673// CHECK-NEXT: <key>line</key><integer>78</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001674// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001675// CHECK-NEXT: <key>file</key><integer>0</integer>
1676// CHECK-NEXT: </dict>
1677// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001678// CHECK-NEXT: <key>line</key><integer>78</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001679// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001680// CHECK-NEXT: <key>file</key><integer>0</integer>
1681// CHECK-NEXT: </dict>
1682// CHECK-NEXT: </array>
1683// CHECK-NEXT: </dict>
1684// CHECK-NEXT: </array>
1685// CHECK-NEXT: </dict>
1686// CHECK-NEXT: <dict>
1687// CHECK-NEXT: <key>kind</key><string>event</string>
1688// CHECK-NEXT: <key>location</key>
1689// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001690// CHECK-NEXT: <key>line</key><integer>78</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001691// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001692// CHECK-NEXT: <key>file</key><integer>0</integer>
1693// CHECK-NEXT: </dict>
1694// CHECK-NEXT: <key>ranges</key>
1695// CHECK-NEXT: <array>
1696// CHECK-NEXT: <array>
1697// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001698// CHECK-NEXT: <key>line</key><integer>78</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001699// CHECK-NEXT: <key>col</key><integer>4</integer>
1700// CHECK-NEXT: <key>file</key><integer>0</integer>
1701// CHECK-NEXT: </dict>
1702// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001703// CHECK-NEXT: <key>line</key><integer>78</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001704// CHECK-NEXT: <key>col</key><integer>4</integer>
1705// CHECK-NEXT: <key>file</key><integer>0</integer>
1706// CHECK-NEXT: </dict>
1707// CHECK-NEXT: </array>
1708// CHECK-NEXT: </array>
1709// CHECK-NEXT: <key>depth</key><integer>0</integer>
1710// CHECK-NEXT: <key>extended_message</key>
1711// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1712// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001713// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001714// CHECK-NEXT: </dict>
1715// CHECK-NEXT: </array>
1716// CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1717// CHECK-NEXT: <key>category</key><string>Logic error</string>
1718// CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string>
Gabor Horvathc18a1132015-02-09 22:52:26 +00001719// CHECK-NEXT: <key>check_name</key><string>core.NullDereference</string>
Gabor Horvathefec1632015-10-22 11:53:04 +00001720// CHECK-NEXT: <!-- This hash is experimental and going to change! -->
1721// CHECK-NEXT: <key>issue_hash_content_of_line_in_context</key><string>524a8647c40f017409d858ff70900c1a</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001722// CHECK-NEXT: <key>issue_context_kind</key><string>function</string>
1723// CHECK-NEXT: <key>issue_context</key><string>test_block_blockvar</string>
Gabor Horvathefec1632015-10-22 11:53:04 +00001724// CHECK-NEXT: <key>issue_hash_function_offset</key><string>5</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001725// CHECK-NEXT: <key>location</key>
1726// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001727// CHECK-NEXT: <key>line</key><integer>78</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001728// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001729// CHECK-NEXT: <key>file</key><integer>0</integer>
1730// CHECK-NEXT: </dict>
1731// CHECK-NEXT: </dict>
1732// CHECK-NEXT: <dict>
1733// CHECK-NEXT: <key>path</key>
1734// CHECK-NEXT: <array>
1735// CHECK-NEXT: <dict>
1736// CHECK-NEXT: <key>kind</key><string>control</string>
1737// CHECK-NEXT: <key>edges</key>
1738// CHECK-NEXT: <array>
1739// CHECK-NEXT: <dict>
1740// CHECK-NEXT: <key>start</key>
1741// CHECK-NEXT: <array>
1742// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001743// CHECK-NEXT: <key>line</key><integer>82</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001744// CHECK-NEXT: <key>col</key><integer>3</integer>
1745// CHECK-NEXT: <key>file</key><integer>0</integer>
1746// CHECK-NEXT: </dict>
1747// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001748// CHECK-NEXT: <key>line</key><integer>82</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001749// CHECK-NEXT: <key>col</key><integer>5</integer>
1750// CHECK-NEXT: <key>file</key><integer>0</integer>
1751// CHECK-NEXT: </dict>
1752// CHECK-NEXT: </array>
1753// CHECK-NEXT: <key>end</key>
1754// CHECK-NEXT: <array>
1755// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001756// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001757// CHECK-NEXT: <key>col</key><integer>3</integer>
1758// CHECK-NEXT: <key>file</key><integer>0</integer>
1759// CHECK-NEXT: </dict>
1760// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001761// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-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: </array>
1766// CHECK-NEXT: </dict>
1767// CHECK-NEXT: </array>
1768// CHECK-NEXT: </dict>
1769// CHECK-NEXT: <dict>
1770// CHECK-NEXT: <key>kind</key><string>event</string>
1771// CHECK-NEXT: <key>location</key>
1772// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001773// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001774// CHECK-NEXT: <key>col</key><integer>3</integer>
1775// CHECK-NEXT: <key>file</key><integer>0</integer>
1776// CHECK-NEXT: </dict>
1777// CHECK-NEXT: <key>ranges</key>
1778// CHECK-NEXT: <array>
1779// CHECK-NEXT: <array>
1780// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001781// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001782// CHECK-NEXT: <key>col</key><integer>3</integer>
1783// CHECK-NEXT: <key>file</key><integer>0</integer>
1784// CHECK-NEXT: </dict>
1785// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001786// CHECK-NEXT: <key>line</key><integer>85</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001787// CHECK-NEXT: <key>col</key><integer>7</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001788// CHECK-NEXT: <key>file</key><integer>0</integer>
1789// CHECK-NEXT: </dict>
1790// CHECK-NEXT: </array>
1791// CHECK-NEXT: </array>
1792// CHECK-NEXT: <key>depth</key><integer>0</integer>
1793// CHECK-NEXT: <key>extended_message</key>
1794// CHECK-NEXT: <string>Calling anonymous block</string>
1795// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001796// CHECK-NEXT: <string>Calling anonymous block</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001797// CHECK-NEXT: </dict>
1798// CHECK-NEXT: <dict>
1799// CHECK-NEXT: <key>kind</key><string>event</string>
1800// CHECK-NEXT: <key>location</key>
1801// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001802// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001803// CHECK-NEXT: <key>col</key><integer>3</integer>
1804// CHECK-NEXT: <key>file</key><integer>0</integer>
1805// CHECK-NEXT: </dict>
1806// CHECK-NEXT: <key>depth</key><integer>1</integer>
1807// CHECK-NEXT: <key>extended_message</key>
1808// CHECK-NEXT: <string>Entered call from &apos;test_block_arg&apos;</string>
1809// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001810// CHECK-NEXT: <string>Entered call from &apos;test_block_arg&apos;</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001811// CHECK-NEXT: </dict>
1812// CHECK-NEXT: <dict>
1813// CHECK-NEXT: <key>kind</key><string>control</string>
1814// CHECK-NEXT: <key>edges</key>
1815// CHECK-NEXT: <array>
1816// CHECK-NEXT: <dict>
1817// CHECK-NEXT: <key>start</key>
1818// CHECK-NEXT: <array>
1819// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001820// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001821// CHECK-NEXT: <key>col</key><integer>3</integer>
1822// CHECK-NEXT: <key>file</key><integer>0</integer>
1823// CHECK-NEXT: </dict>
1824// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001825// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001826// CHECK-NEXT: <key>col</key><integer>3</integer>
1827// CHECK-NEXT: <key>file</key><integer>0</integer>
1828// CHECK-NEXT: </dict>
1829// CHECK-NEXT: </array>
1830// CHECK-NEXT: <key>end</key>
1831// CHECK-NEXT: <array>
1832// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001833// CHECK-NEXT: <key>line</key><integer>84</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001834// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001835// CHECK-NEXT: <key>file</key><integer>0</integer>
1836// CHECK-NEXT: </dict>
1837// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001838// CHECK-NEXT: <key>line</key><integer>84</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001839// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001840// CHECK-NEXT: <key>file</key><integer>0</integer>
1841// CHECK-NEXT: </dict>
1842// CHECK-NEXT: </array>
1843// CHECK-NEXT: </dict>
1844// CHECK-NEXT: </array>
1845// CHECK-NEXT: </dict>
1846// CHECK-NEXT: <dict>
1847// CHECK-NEXT: <key>kind</key><string>event</string>
1848// CHECK-NEXT: <key>location</key>
1849// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001850// CHECK-NEXT: <key>line</key><integer>84</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001851// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001852// CHECK-NEXT: <key>file</key><integer>0</integer>
1853// CHECK-NEXT: </dict>
1854// CHECK-NEXT: <key>ranges</key>
1855// CHECK-NEXT: <array>
1856// CHECK-NEXT: <array>
1857// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001858// CHECK-NEXT: <key>line</key><integer>84</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001859// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001860// CHECK-NEXT: <key>file</key><integer>0</integer>
1861// CHECK-NEXT: </dict>
1862// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001863// CHECK-NEXT: <key>line</key><integer>84</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001864// CHECK-NEXT: <key>col</key><integer>10</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001865// CHECK-NEXT: <key>file</key><integer>0</integer>
1866// CHECK-NEXT: </dict>
1867// CHECK-NEXT: </array>
1868// CHECK-NEXT: </array>
1869// CHECK-NEXT: <key>depth</key><integer>1</integer>
1870// CHECK-NEXT: <key>extended_message</key>
1871// CHECK-NEXT: <string>Null pointer value stored to &apos;p&apos;</string>
1872// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001873// CHECK-NEXT: <string>Null pointer value stored to &apos;p&apos;</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001874// CHECK-NEXT: </dict>
1875// CHECK-NEXT: <dict>
1876// CHECK-NEXT: <key>kind</key><string>event</string>
1877// CHECK-NEXT: <key>location</key>
1878// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001879// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001880// CHECK-NEXT: <key>col</key><integer>3</integer>
1881// CHECK-NEXT: <key>file</key><integer>0</integer>
1882// CHECK-NEXT: </dict>
1883// CHECK-NEXT: <key>ranges</key>
1884// CHECK-NEXT: <array>
1885// CHECK-NEXT: <array>
1886// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001887// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001888// CHECK-NEXT: <key>col</key><integer>3</integer>
1889// CHECK-NEXT: <key>file</key><integer>0</integer>
1890// CHECK-NEXT: </dict>
1891// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001892// CHECK-NEXT: <key>line</key><integer>85</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001893// CHECK-NEXT: <key>col</key><integer>7</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001894// CHECK-NEXT: <key>file</key><integer>0</integer>
1895// CHECK-NEXT: </dict>
1896// CHECK-NEXT: </array>
1897// CHECK-NEXT: </array>
Jordan Rose526d93c2013-04-12 00:44:17 +00001898// CHECK-NEXT: <key>depth</key><integer>0</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001899// CHECK-NEXT: <key>extended_message</key>
1900// CHECK-NEXT: <string>Returning to caller</string>
1901// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001902// CHECK-NEXT: <string>Returning to caller</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001903// CHECK-NEXT: </dict>
1904// CHECK-NEXT: <dict>
1905// CHECK-NEXT: <key>kind</key><string>control</string>
1906// CHECK-NEXT: <key>edges</key>
1907// CHECK-NEXT: <array>
1908// CHECK-NEXT: <dict>
1909// CHECK-NEXT: <key>start</key>
1910// CHECK-NEXT: <array>
1911// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001912// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001913// CHECK-NEXT: <key>col</key><integer>3</integer>
1914// CHECK-NEXT: <key>file</key><integer>0</integer>
1915// CHECK-NEXT: </dict>
1916// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001917// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001918// CHECK-NEXT: <key>col</key><integer>3</integer>
1919// CHECK-NEXT: <key>file</key><integer>0</integer>
1920// CHECK-NEXT: </dict>
1921// CHECK-NEXT: </array>
1922// CHECK-NEXT: <key>end</key>
1923// CHECK-NEXT: <array>
1924// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001925// CHECK-NEXT: <key>line</key><integer>86</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001926// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001927// CHECK-NEXT: <key>file</key><integer>0</integer>
1928// CHECK-NEXT: </dict>
1929// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001930// CHECK-NEXT: <key>line</key><integer>86</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001931// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001932// CHECK-NEXT: <key>file</key><integer>0</integer>
1933// CHECK-NEXT: </dict>
1934// CHECK-NEXT: </array>
1935// CHECK-NEXT: </dict>
1936// CHECK-NEXT: </array>
1937// CHECK-NEXT: </dict>
1938// CHECK-NEXT: <dict>
1939// CHECK-NEXT: <key>kind</key><string>event</string>
1940// CHECK-NEXT: <key>location</key>
1941// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001942// CHECK-NEXT: <key>line</key><integer>86</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001943// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001944// CHECK-NEXT: <key>file</key><integer>0</integer>
1945// CHECK-NEXT: </dict>
1946// CHECK-NEXT: <key>ranges</key>
1947// CHECK-NEXT: <array>
1948// CHECK-NEXT: <array>
1949// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001950// CHECK-NEXT: <key>line</key><integer>86</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001951// CHECK-NEXT: <key>col</key><integer>4</integer>
1952// CHECK-NEXT: <key>file</key><integer>0</integer>
1953// CHECK-NEXT: </dict>
1954// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001955// CHECK-NEXT: <key>line</key><integer>86</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001956// CHECK-NEXT: <key>col</key><integer>4</integer>
1957// CHECK-NEXT: <key>file</key><integer>0</integer>
1958// CHECK-NEXT: </dict>
1959// CHECK-NEXT: </array>
1960// CHECK-NEXT: </array>
1961// CHECK-NEXT: <key>depth</key><integer>0</integer>
1962// CHECK-NEXT: <key>extended_message</key>
1963// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1964// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001965// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001966// CHECK-NEXT: </dict>
1967// CHECK-NEXT: </array>
1968// CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1969// CHECK-NEXT: <key>category</key><string>Logic error</string>
1970// CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string>
Gabor Horvathc18a1132015-02-09 22:52:26 +00001971// CHECK-NEXT: <key>check_name</key><string>core.NullDereference</string>
Gabor Horvathefec1632015-10-22 11:53:04 +00001972// CHECK-NEXT: <!-- This hash is experimental and going to change! -->
1973// CHECK-NEXT: <key>issue_hash_content_of_line_in_context</key><string>0efdf891fbddf2932f9d434968b94164</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001974// CHECK-NEXT: <key>issue_context_kind</key><string>function</string>
1975// CHECK-NEXT: <key>issue_context</key><string>test_block_arg</string>
Gabor Horvathefec1632015-10-22 11:53:04 +00001976// CHECK-NEXT: <key>issue_hash_function_offset</key><string>5</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001977// CHECK-NEXT: <key>location</key>
1978// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001979// CHECK-NEXT: <key>line</key><integer>86</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001980// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001981// CHECK-NEXT: <key>file</key><integer>0</integer>
1982// CHECK-NEXT: </dict>
1983// CHECK-NEXT: </dict>
1984// CHECK-NEXT: </array>