blob: bcf15b343ae11d5331e41e079562d6aeda836ae3 [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>
292// CHECK-NEXT: <key>issue_context_kind</key><string>function</string>
293// CHECK-NEXT: <key>issue_context</key><string>foo</string>
Anna Zaks58b961d2013-01-08 00:25:22 +0000294// CHECK-NEXT: <key>issue_hash</key><string>7</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000295// CHECK-NEXT: <key>location</key>
296// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +0000297// CHECK-NEXT: <key>line</key><integer>18</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +0000298// CHECK-NEXT: <key>col</key><integer>11</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000299// CHECK-NEXT: <key>file</key><integer>0</integer>
300// CHECK-NEXT: </dict>
301// CHECK-NEXT: </dict>
302// CHECK-NEXT: <dict>
303// CHECK-NEXT: <key>path</key>
304// CHECK-NEXT: <array>
305// CHECK-NEXT: <dict>
306// CHECK-NEXT: <key>kind</key><string>control</string>
307// CHECK-NEXT: <key>edges</key>
308// CHECK-NEXT: <array>
309// CHECK-NEXT: <dict>
310// CHECK-NEXT: <key>start</key>
311// CHECK-NEXT: <array>
312// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +0000313// CHECK-NEXT: <key>line</key><integer>27</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000314// CHECK-NEXT: <key>col</key><integer>3</integer>
315// CHECK-NEXT: <key>file</key><integer>0</integer>
316// CHECK-NEXT: </dict>
317// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +0000318// CHECK-NEXT: <key>line</key><integer>27</integer>
319// CHECK-NEXT: <key>col</key><integer>9</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000320// CHECK-NEXT: <key>file</key><integer>0</integer>
321// CHECK-NEXT: </dict>
322// CHECK-NEXT: </array>
323// CHECK-NEXT: <key>end</key>
324// CHECK-NEXT: <array>
325// CHECK-NEXT: <dict>
326// CHECK-NEXT: <key>line</key><integer>27</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000327// CHECK-NEXT: <key>col</key><integer>11</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000328// CHECK-NEXT: <key>file</key><integer>0</integer>
329// CHECK-NEXT: </dict>
330// CHECK-NEXT: <dict>
331// CHECK-NEXT: <key>line</key><integer>27</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000332// CHECK-NEXT: <key>col</key><integer>11</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000333// CHECK-NEXT: <key>file</key><integer>0</integer>
334// CHECK-NEXT: </dict>
335// CHECK-NEXT: </array>
336// CHECK-NEXT: </dict>
337// CHECK-NEXT: </array>
338// CHECK-NEXT: </dict>
339// CHECK-NEXT: <dict>
340// CHECK-NEXT: <key>kind</key><string>event</string>
341// CHECK-NEXT: <key>location</key>
342// CHECK-NEXT: <dict>
343// CHECK-NEXT: <key>line</key><integer>27</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000344// CHECK-NEXT: <key>col</key><integer>11</integer>
345// CHECK-NEXT: <key>file</key><integer>0</integer>
346// CHECK-NEXT: </dict>
347// CHECK-NEXT: <key>ranges</key>
348// CHECK-NEXT: <array>
349// CHECK-NEXT: <array>
350// CHECK-NEXT: <dict>
351// CHECK-NEXT: <key>line</key><integer>27</integer>
352// CHECK-NEXT: <key>col</key><integer>11</integer>
353// CHECK-NEXT: <key>file</key><integer>0</integer>
354// CHECK-NEXT: </dict>
355// CHECK-NEXT: <dict>
356// CHECK-NEXT: <key>line</key><integer>27</integer>
357// CHECK-NEXT: <key>col</key><integer>11</integer>
358// CHECK-NEXT: <key>file</key><integer>0</integer>
359// CHECK-NEXT: </dict>
360// CHECK-NEXT: </array>
361// CHECK-NEXT: </array>
362// CHECK-NEXT: <key>depth</key><integer>0</integer>
363// CHECK-NEXT: <key>extended_message</key>
364// CHECK-NEXT: <string>Passing null pointer value via 1st parameter &apos;p&apos;</string>
365// CHECK-NEXT: <key>message</key>
366// CHECK-NEXT: <string>Passing null pointer value via 1st parameter &apos;p&apos;</string>
367// CHECK-NEXT: </dict>
368// CHECK-NEXT: <dict>
369// CHECK-NEXT: <key>kind</key><string>event</string>
370// CHECK-NEXT: <key>location</key>
371// CHECK-NEXT: <dict>
372// CHECK-NEXT: <key>line</key><integer>27</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000373// CHECK-NEXT: <key>col</key><integer>3</integer>
374// CHECK-NEXT: <key>file</key><integer>0</integer>
375// CHECK-NEXT: </dict>
376// CHECK-NEXT: <key>ranges</key>
377// CHECK-NEXT: <array>
378// CHECK-NEXT: <array>
379// CHECK-NEXT: <dict>
380// CHECK-NEXT: <key>line</key><integer>27</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000381// CHECK-NEXT: <key>col</key><integer>3</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000382// CHECK-NEXT: <key>file</key><integer>0</integer>
383// CHECK-NEXT: </dict>
384// CHECK-NEXT: <dict>
385// CHECK-NEXT: <key>line</key><integer>27</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000386// CHECK-NEXT: <key>col</key><integer>12</integer>
387// CHECK-NEXT: <key>file</key><integer>0</integer>
388// CHECK-NEXT: </dict>
389// CHECK-NEXT: </array>
390// CHECK-NEXT: </array>
391// CHECK-NEXT: <key>depth</key><integer>0</integer>
392// CHECK-NEXT: <key>extended_message</key>
393// CHECK-NEXT: <string>Calling &apos;has_bug&apos;</string>
394// CHECK-NEXT: <key>message</key>
395// CHECK-NEXT: <string>Calling &apos;has_bug&apos;</string>
396// CHECK-NEXT: </dict>
397// CHECK-NEXT: <dict>
398// CHECK-NEXT: <key>kind</key><string>event</string>
399// CHECK-NEXT: <key>location</key>
400// CHECK-NEXT: <dict>
401// CHECK-NEXT: <key>line</key><integer>22</integer>
402// CHECK-NEXT: <key>col</key><integer>1</integer>
403// CHECK-NEXT: <key>file</key><integer>0</integer>
404// CHECK-NEXT: </dict>
405// CHECK-NEXT: <key>depth</key><integer>1</integer>
406// CHECK-NEXT: <key>extended_message</key>
407// CHECK-NEXT: <string>Entered call from &apos;test_has_bug&apos;</string>
408// CHECK-NEXT: <key>message</key>
409// CHECK-NEXT: <string>Entered call from &apos;test_has_bug&apos;</string>
410// CHECK-NEXT: </dict>
411// CHECK-NEXT: <dict>
412// CHECK-NEXT: <key>kind</key><string>control</string>
413// CHECK-NEXT: <key>edges</key>
414// CHECK-NEXT: <array>
415// CHECK-NEXT: <dict>
416// CHECK-NEXT: <key>start</key>
417// CHECK-NEXT: <array>
418// CHECK-NEXT: <dict>
419// CHECK-NEXT: <key>line</key><integer>22</integer>
420// CHECK-NEXT: <key>col</key><integer>1</integer>
421// CHECK-NEXT: <key>file</key><integer>0</integer>
422// CHECK-NEXT: </dict>
423// CHECK-NEXT: <dict>
424// CHECK-NEXT: <key>line</key><integer>22</integer>
425// CHECK-NEXT: <key>col</key><integer>4</integer>
426// CHECK-NEXT: <key>file</key><integer>0</integer>
427// CHECK-NEXT: </dict>
428// CHECK-NEXT: </array>
429// CHECK-NEXT: <key>end</key>
430// CHECK-NEXT: <array>
431// CHECK-NEXT: <dict>
432// CHECK-NEXT: <key>line</key><integer>23</integer>
433// CHECK-NEXT: <key>col</key><integer>3</integer>
434// CHECK-NEXT: <key>file</key><integer>0</integer>
435// CHECK-NEXT: </dict>
436// CHECK-NEXT: <dict>
437// CHECK-NEXT: <key>line</key><integer>23</integer>
438// CHECK-NEXT: <key>col</key><integer>3</integer>
439// CHECK-NEXT: <key>file</key><integer>0</integer>
440// CHECK-NEXT: </dict>
441// CHECK-NEXT: </array>
442// CHECK-NEXT: </dict>
443// CHECK-NEXT: </array>
444// CHECK-NEXT: </dict>
445// CHECK-NEXT: <dict>
Anna Zaks4e16b292013-04-23 23:57:43 +0000446// CHECK-NEXT: <key>kind</key><string>control</string>
447// CHECK-NEXT: <key>edges</key>
448// CHECK-NEXT: <array>
449// CHECK-NEXT: <dict>
450// CHECK-NEXT: <key>start</key>
451// CHECK-NEXT: <array>
452// CHECK-NEXT: <dict>
453// CHECK-NEXT: <key>line</key><integer>23</integer>
454// CHECK-NEXT: <key>col</key><integer>3</integer>
455// CHECK-NEXT: <key>file</key><integer>0</integer>
456// CHECK-NEXT: </dict>
457// CHECK-NEXT: <dict>
458// CHECK-NEXT: <key>line</key><integer>23</integer>
459// CHECK-NEXT: <key>col</key><integer>3</integer>
460// CHECK-NEXT: <key>file</key><integer>0</integer>
461// CHECK-NEXT: </dict>
462// CHECK-NEXT: </array>
463// CHECK-NEXT: <key>end</key>
464// CHECK-NEXT: <array>
465// CHECK-NEXT: <dict>
466// CHECK-NEXT: <key>line</key><integer>23</integer>
467// CHECK-NEXT: <key>col</key><integer>6</integer>
468// CHECK-NEXT: <key>file</key><integer>0</integer>
469// CHECK-NEXT: </dict>
470// CHECK-NEXT: <dict>
471// CHECK-NEXT: <key>line</key><integer>23</integer>
472// CHECK-NEXT: <key>col</key><integer>6</integer>
473// CHECK-NEXT: <key>file</key><integer>0</integer>
474// CHECK-NEXT: </dict>
475// CHECK-NEXT: </array>
476// CHECK-NEXT: </dict>
477// CHECK-NEXT: </array>
478// CHECK-NEXT: </dict>
479// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +0000480// CHECK-NEXT: <key>kind</key><string>event</string>
481// CHECK-NEXT: <key>location</key>
482// CHECK-NEXT: <dict>
483// CHECK-NEXT: <key>line</key><integer>23</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +0000484// CHECK-NEXT: <key>col</key><integer>6</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000485// CHECK-NEXT: <key>file</key><integer>0</integer>
486// CHECK-NEXT: </dict>
487// CHECK-NEXT: <key>ranges</key>
488// CHECK-NEXT: <array>
489// CHECK-NEXT: <array>
490// CHECK-NEXT: <dict>
491// CHECK-NEXT: <key>line</key><integer>23</integer>
492// CHECK-NEXT: <key>col</key><integer>4</integer>
493// CHECK-NEXT: <key>file</key><integer>0</integer>
494// CHECK-NEXT: </dict>
495// CHECK-NEXT: <dict>
496// CHECK-NEXT: <key>line</key><integer>23</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000497// CHECK-NEXT: <key>col</key><integer>4</integer>
498// CHECK-NEXT: <key>file</key><integer>0</integer>
499// CHECK-NEXT: </dict>
500// CHECK-NEXT: </array>
501// CHECK-NEXT: </array>
502// CHECK-NEXT: <key>depth</key><integer>1</integer>
503// CHECK-NEXT: <key>extended_message</key>
504// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
505// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +0000506// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
507// CHECK-NEXT: </dict>
508// CHECK-NEXT: </array>
509// CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
510// CHECK-NEXT: <key>category</key><string>Logic error</string>
511// CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string>
512// CHECK-NEXT: <key>issue_context_kind</key><string>function</string>
513// CHECK-NEXT: <key>issue_context</key><string>has_bug</string>
Anna Zaks58b961d2013-01-08 00:25:22 +0000514// CHECK-NEXT: <key>issue_hash</key><string>1</string>
Jordan Rose106b037a2012-09-22 01:24:46 +0000515// CHECK-NEXT: <key>location</key>
516// CHECK-NEXT: <dict>
517// CHECK-NEXT: <key>line</key><integer>23</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +0000518// CHECK-NEXT: <key>col</key><integer>6</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000519// CHECK-NEXT: <key>file</key><integer>0</integer>
520// CHECK-NEXT: </dict>
521// CHECK-NEXT: </dict>
522// CHECK-NEXT: <dict>
523// CHECK-NEXT: <key>path</key>
524// CHECK-NEXT: <array>
525// CHECK-NEXT: <dict>
526// CHECK-NEXT: <key>kind</key><string>control</string>
527// CHECK-NEXT: <key>edges</key>
528// CHECK-NEXT: <array>
529// CHECK-NEXT: <dict>
530// CHECK-NEXT: <key>start</key>
531// CHECK-NEXT: <array>
532// CHECK-NEXT: <dict>
533// CHECK-NEXT: <key>line</key><integer>39</integer>
534// CHECK-NEXT: <key>col</key><integer>3</integer>
535// CHECK-NEXT: <key>file</key><integer>0</integer>
536// CHECK-NEXT: </dict>
537// CHECK-NEXT: <dict>
538// CHECK-NEXT: <key>line</key><integer>39</integer>
539// CHECK-NEXT: <key>col</key><integer>4</integer>
540// CHECK-NEXT: <key>file</key><integer>0</integer>
541// CHECK-NEXT: </dict>
542// CHECK-NEXT: </array>
543// CHECK-NEXT: <key>end</key>
544// CHECK-NEXT: <array>
545// CHECK-NEXT: <dict>
546// CHECK-NEXT: <key>line</key><integer>39</integer>
547// CHECK-NEXT: <key>col</key><integer>8</integer>
548// CHECK-NEXT: <key>file</key><integer>0</integer>
549// CHECK-NEXT: </dict>
550// CHECK-NEXT: <dict>
551// CHECK-NEXT: <key>line</key><integer>39</integer>
552// CHECK-NEXT: <key>col</key><integer>8</integer>
553// CHECK-NEXT: <key>file</key><integer>0</integer>
554// CHECK-NEXT: </dict>
555// CHECK-NEXT: </array>
556// CHECK-NEXT: </dict>
557// CHECK-NEXT: </array>
558// CHECK-NEXT: </dict>
559// CHECK-NEXT: <dict>
560// CHECK-NEXT: <key>kind</key><string>event</string>
561// CHECK-NEXT: <key>location</key>
562// CHECK-NEXT: <dict>
563// CHECK-NEXT: <key>line</key><integer>39</integer>
564// CHECK-NEXT: <key>col</key><integer>8</integer>
565// CHECK-NEXT: <key>file</key><integer>0</integer>
566// CHECK-NEXT: </dict>
567// CHECK-NEXT: <key>ranges</key>
568// CHECK-NEXT: <array>
569// CHECK-NEXT: <array>
570// CHECK-NEXT: <dict>
571// CHECK-NEXT: <key>line</key><integer>39</integer>
572// CHECK-NEXT: <key>col</key><integer>8</integer>
573// CHECK-NEXT: <key>file</key><integer>0</integer>
574// CHECK-NEXT: </dict>
575// CHECK-NEXT: <dict>
576// CHECK-NEXT: <key>line</key><integer>39</integer>
577// CHECK-NEXT: <key>col</key><integer>9</integer>
578// CHECK-NEXT: <key>file</key><integer>0</integer>
579// CHECK-NEXT: </dict>
580// CHECK-NEXT: </array>
581// CHECK-NEXT: </array>
582// CHECK-NEXT: <key>depth</key><integer>0</integer>
583// CHECK-NEXT: <key>extended_message</key>
584// CHECK-NEXT: <string>Assuming &apos;p&apos; is null</string>
585// CHECK-NEXT: <key>message</key>
586// CHECK-NEXT: <string>Assuming &apos;p&apos; is null</string>
587// CHECK-NEXT: </dict>
588// CHECK-NEXT: <dict>
589// CHECK-NEXT: <key>kind</key><string>control</string>
590// CHECK-NEXT: <key>edges</key>
591// CHECK-NEXT: <array>
592// CHECK-NEXT: <dict>
593// CHECK-NEXT: <key>start</key>
594// CHECK-NEXT: <array>
595// CHECK-NEXT: <dict>
596// CHECK-NEXT: <key>line</key><integer>39</integer>
597// CHECK-NEXT: <key>col</key><integer>8</integer>
598// CHECK-NEXT: <key>file</key><integer>0</integer>
599// CHECK-NEXT: </dict>
600// CHECK-NEXT: <dict>
601// CHECK-NEXT: <key>line</key><integer>39</integer>
602// CHECK-NEXT: <key>col</key><integer>8</integer>
603// CHECK-NEXT: <key>file</key><integer>0</integer>
604// CHECK-NEXT: </dict>
605// CHECK-NEXT: </array>
606// CHECK-NEXT: <key>end</key>
607// CHECK-NEXT: <array>
608// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000609// CHECK-NEXT: <key>line</key><integer>45</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000610// CHECK-NEXT: <key>col</key><integer>3</integer>
611// CHECK-NEXT: <key>file</key><integer>0</integer>
612// CHECK-NEXT: </dict>
613// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000614// CHECK-NEXT: <key>line</key><integer>45</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000615// CHECK-NEXT: <key>col</key><integer>4</integer>
616// CHECK-NEXT: <key>file</key><integer>0</integer>
617// CHECK-NEXT: </dict>
618// CHECK-NEXT: </array>
619// CHECK-NEXT: </dict>
620// CHECK-NEXT: </array>
621// CHECK-NEXT: </dict>
622// CHECK-NEXT: <dict>
623// CHECK-NEXT: <key>kind</key><string>control</string>
624// CHECK-NEXT: <key>edges</key>
625// CHECK-NEXT: <array>
626// CHECK-NEXT: <dict>
627// CHECK-NEXT: <key>start</key>
628// CHECK-NEXT: <array>
629// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000630// CHECK-NEXT: <key>line</key><integer>45</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000631// CHECK-NEXT: <key>col</key><integer>3</integer>
632// CHECK-NEXT: <key>file</key><integer>0</integer>
633// CHECK-NEXT: </dict>
634// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000635// CHECK-NEXT: <key>line</key><integer>45</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000636// CHECK-NEXT: <key>col</key><integer>4</integer>
637// CHECK-NEXT: <key>file</key><integer>0</integer>
638// CHECK-NEXT: </dict>
639// CHECK-NEXT: </array>
640// CHECK-NEXT: <key>end</key>
641// CHECK-NEXT: <array>
642// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000643// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000644// CHECK-NEXT: <key>col</key><integer>5</integer>
645// CHECK-NEXT: <key>file</key><integer>0</integer>
646// CHECK-NEXT: </dict>
647// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000648// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000649// CHECK-NEXT: <key>col</key><integer>16</integer>
650// CHECK-NEXT: <key>file</key><integer>0</integer>
651// CHECK-NEXT: </dict>
652// CHECK-NEXT: </array>
653// CHECK-NEXT: </dict>
654// CHECK-NEXT: </array>
655// CHECK-NEXT: </dict>
656// CHECK-NEXT: <dict>
657// CHECK-NEXT: <key>kind</key><string>control</string>
658// CHECK-NEXT: <key>edges</key>
659// CHECK-NEXT: <array>
660// CHECK-NEXT: <dict>
661// CHECK-NEXT: <key>start</key>
662// CHECK-NEXT: <array>
663// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000664// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000665// CHECK-NEXT: <key>col</key><integer>5</integer>
666// CHECK-NEXT: <key>file</key><integer>0</integer>
667// CHECK-NEXT: </dict>
668// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000669// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000670// CHECK-NEXT: <key>col</key><integer>16</integer>
671// CHECK-NEXT: <key>file</key><integer>0</integer>
672// CHECK-NEXT: </dict>
673// CHECK-NEXT: </array>
674// CHECK-NEXT: <key>end</key>
675// CHECK-NEXT: <array>
676// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000677// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000678// CHECK-NEXT: <key>col</key><integer>18</integer>
679// CHECK-NEXT: <key>file</key><integer>0</integer>
680// CHECK-NEXT: </dict>
681// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000682// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000683// CHECK-NEXT: <key>col</key><integer>18</integer>
684// CHECK-NEXT: <key>file</key><integer>0</integer>
685// CHECK-NEXT: </dict>
686// CHECK-NEXT: </array>
687// CHECK-NEXT: </dict>
688// CHECK-NEXT: </array>
689// CHECK-NEXT: </dict>
690// CHECK-NEXT: <dict>
691// CHECK-NEXT: <key>kind</key><string>event</string>
692// CHECK-NEXT: <key>location</key>
693// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000694// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000695// CHECK-NEXT: <key>col</key><integer>18</integer>
696// CHECK-NEXT: <key>file</key><integer>0</integer>
697// CHECK-NEXT: </dict>
698// CHECK-NEXT: <key>ranges</key>
699// CHECK-NEXT: <array>
700// CHECK-NEXT: <array>
701// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000702// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000703// CHECK-NEXT: <key>col</key><integer>18</integer>
704// CHECK-NEXT: <key>file</key><integer>0</integer>
705// CHECK-NEXT: </dict>
706// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000707// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000708// CHECK-NEXT: <key>col</key><integer>18</integer>
709// CHECK-NEXT: <key>file</key><integer>0</integer>
710// CHECK-NEXT: </dict>
711// CHECK-NEXT: </array>
712// CHECK-NEXT: </array>
713// CHECK-NEXT: <key>depth</key><integer>0</integer>
714// CHECK-NEXT: <key>extended_message</key>
715// CHECK-NEXT: <string>Passing null pointer value via 1st parameter &apos;p&apos;</string>
716// CHECK-NEXT: <key>message</key>
717// CHECK-NEXT: <string>Passing null pointer value via 1st parameter &apos;p&apos;</string>
718// CHECK-NEXT: </dict>
719// CHECK-NEXT: <dict>
720// CHECK-NEXT: <key>kind</key><string>event</string>
721// CHECK-NEXT: <key>location</key>
722// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000723// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000724// CHECK-NEXT: <key>col</key><integer>5</integer>
725// CHECK-NEXT: <key>file</key><integer>0</integer>
726// CHECK-NEXT: </dict>
727// CHECK-NEXT: <key>ranges</key>
728// CHECK-NEXT: <array>
729// CHECK-NEXT: <array>
730// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000731// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000732// CHECK-NEXT: <key>col</key><integer>5</integer>
733// CHECK-NEXT: <key>file</key><integer>0</integer>
734// CHECK-NEXT: </dict>
735// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000736// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000737// CHECK-NEXT: <key>col</key><integer>19</integer>
738// CHECK-NEXT: <key>file</key><integer>0</integer>
739// CHECK-NEXT: </dict>
740// CHECK-NEXT: </array>
741// CHECK-NEXT: </array>
742// CHECK-NEXT: <key>depth</key><integer>0</integer>
743// CHECK-NEXT: <key>extended_message</key>
744// CHECK-NEXT: <string>Calling &apos;triggers_bug&apos;</string>
745// CHECK-NEXT: <key>message</key>
746// CHECK-NEXT: <string>Calling &apos;triggers_bug&apos;</string>
747// CHECK-NEXT: </dict>
748// CHECK-NEXT: <dict>
749// CHECK-NEXT: <key>kind</key><string>event</string>
750// CHECK-NEXT: <key>location</key>
751// CHECK-NEXT: <dict>
752// CHECK-NEXT: <key>line</key><integer>32</integer>
753// CHECK-NEXT: <key>col</key><integer>1</integer>
754// CHECK-NEXT: <key>file</key><integer>0</integer>
755// CHECK-NEXT: </dict>
756// CHECK-NEXT: <key>depth</key><integer>1</integer>
757// CHECK-NEXT: <key>extended_message</key>
758// CHECK-NEXT: <string>Entered call from &apos;bar&apos;</string>
759// CHECK-NEXT: <key>message</key>
760// CHECK-NEXT: <string>Entered call from &apos;bar&apos;</string>
761// CHECK-NEXT: </dict>
762// CHECK-NEXT: <dict>
763// CHECK-NEXT: <key>kind</key><string>control</string>
764// CHECK-NEXT: <key>edges</key>
765// CHECK-NEXT: <array>
766// CHECK-NEXT: <dict>
767// CHECK-NEXT: <key>start</key>
768// CHECK-NEXT: <array>
769// CHECK-NEXT: <dict>
770// CHECK-NEXT: <key>line</key><integer>32</integer>
771// CHECK-NEXT: <key>col</key><integer>1</integer>
772// CHECK-NEXT: <key>file</key><integer>0</integer>
773// CHECK-NEXT: </dict>
774// CHECK-NEXT: <dict>
775// CHECK-NEXT: <key>line</key><integer>32</integer>
776// CHECK-NEXT: <key>col</key><integer>4</integer>
777// CHECK-NEXT: <key>file</key><integer>0</integer>
778// CHECK-NEXT: </dict>
779// CHECK-NEXT: </array>
780// CHECK-NEXT: <key>end</key>
781// CHECK-NEXT: <array>
782// CHECK-NEXT: <dict>
783// CHECK-NEXT: <key>line</key><integer>33</integer>
784// CHECK-NEXT: <key>col</key><integer>3</integer>
785// CHECK-NEXT: <key>file</key><integer>0</integer>
786// CHECK-NEXT: </dict>
787// CHECK-NEXT: <dict>
788// CHECK-NEXT: <key>line</key><integer>33</integer>
789// CHECK-NEXT: <key>col</key><integer>3</integer>
790// CHECK-NEXT: <key>file</key><integer>0</integer>
791// CHECK-NEXT: </dict>
792// CHECK-NEXT: </array>
793// CHECK-NEXT: </dict>
794// CHECK-NEXT: </array>
795// CHECK-NEXT: </dict>
796// CHECK-NEXT: <dict>
Anna Zaks4e16b292013-04-23 23:57:43 +0000797// CHECK-NEXT: <key>kind</key><string>control</string>
798// CHECK-NEXT: <key>edges</key>
799// CHECK-NEXT: <array>
800// CHECK-NEXT: <dict>
801// CHECK-NEXT: <key>start</key>
802// CHECK-NEXT: <array>
803// CHECK-NEXT: <dict>
804// CHECK-NEXT: <key>line</key><integer>33</integer>
805// CHECK-NEXT: <key>col</key><integer>3</integer>
806// CHECK-NEXT: <key>file</key><integer>0</integer>
807// CHECK-NEXT: </dict>
808// CHECK-NEXT: <dict>
809// CHECK-NEXT: <key>line</key><integer>33</integer>
810// CHECK-NEXT: <key>col</key><integer>3</integer>
811// CHECK-NEXT: <key>file</key><integer>0</integer>
812// CHECK-NEXT: </dict>
813// CHECK-NEXT: </array>
814// CHECK-NEXT: <key>end</key>
815// CHECK-NEXT: <array>
816// CHECK-NEXT: <dict>
817// CHECK-NEXT: <key>line</key><integer>33</integer>
818// CHECK-NEXT: <key>col</key><integer>6</integer>
819// CHECK-NEXT: <key>file</key><integer>0</integer>
820// CHECK-NEXT: </dict>
821// CHECK-NEXT: <dict>
822// CHECK-NEXT: <key>line</key><integer>33</integer>
823// CHECK-NEXT: <key>col</key><integer>6</integer>
824// CHECK-NEXT: <key>file</key><integer>0</integer>
825// CHECK-NEXT: </dict>
826// CHECK-NEXT: </array>
827// CHECK-NEXT: </dict>
828// CHECK-NEXT: </array>
829// CHECK-NEXT: </dict>
830// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +0000831// CHECK-NEXT: <key>kind</key><string>event</string>
832// CHECK-NEXT: <key>location</key>
833// CHECK-NEXT: <dict>
834// CHECK-NEXT: <key>line</key><integer>33</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +0000835// CHECK-NEXT: <key>col</key><integer>6</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000836// CHECK-NEXT: <key>file</key><integer>0</integer>
837// CHECK-NEXT: </dict>
838// CHECK-NEXT: <key>ranges</key>
839// CHECK-NEXT: <array>
840// CHECK-NEXT: <array>
841// CHECK-NEXT: <dict>
842// CHECK-NEXT: <key>line</key><integer>33</integer>
843// CHECK-NEXT: <key>col</key><integer>4</integer>
844// CHECK-NEXT: <key>file</key><integer>0</integer>
845// CHECK-NEXT: </dict>
846// CHECK-NEXT: <dict>
847// CHECK-NEXT: <key>line</key><integer>33</integer>
848// CHECK-NEXT: <key>col</key><integer>4</integer>
849// CHECK-NEXT: <key>file</key><integer>0</integer>
850// CHECK-NEXT: </dict>
851// CHECK-NEXT: </array>
852// CHECK-NEXT: </array>
853// CHECK-NEXT: <key>depth</key><integer>1</integer>
854// CHECK-NEXT: <key>extended_message</key>
855// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
856// CHECK-NEXT: <key>message</key>
857// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000858// CHECK-NEXT: </dict>
859// CHECK-NEXT: </array>
860// CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
861// CHECK-NEXT: <key>category</key><string>Logic error</string>
862// CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string>
863// CHECK-NEXT: <key>issue_context_kind</key><string>function</string>
864// CHECK-NEXT: <key>issue_context</key><string>triggers_bug</string>
Anna Zaks58b961d2013-01-08 00:25:22 +0000865// CHECK-NEXT: <key>issue_hash</key><string>1</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000866// CHECK-NEXT: <key>location</key>
867// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +0000868// CHECK-NEXT: <key>line</key><integer>33</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +0000869// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000870// CHECK-NEXT: <key>file</key><integer>0</integer>
871// CHECK-NEXT: </dict>
872// CHECK-NEXT: </dict>
873// CHECK-NEXT: <dict>
874// CHECK-NEXT: <key>path</key>
875// CHECK-NEXT: <array>
876// CHECK-NEXT: <dict>
877// CHECK-NEXT: <key>kind</key><string>event</string>
878// CHECK-NEXT: <key>location</key>
879// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000880// CHECK-NEXT: <key>line</key><integer>58</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000881// CHECK-NEXT: <key>col</key><integer>3</integer>
882// CHECK-NEXT: <key>file</key><integer>0</integer>
883// CHECK-NEXT: </dict>
884// CHECK-NEXT: <key>ranges</key>
885// CHECK-NEXT: <array>
886// CHECK-NEXT: <array>
887// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000888// CHECK-NEXT: <key>line</key><integer>58</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000889// CHECK-NEXT: <key>col</key><integer>3</integer>
890// CHECK-NEXT: <key>file</key><integer>0</integer>
891// CHECK-NEXT: </dict>
892// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000893// CHECK-NEXT: <key>line</key><integer>58</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000894// CHECK-NEXT: <key>col</key><integer>8</integer>
895// CHECK-NEXT: <key>file</key><integer>0</integer>
896// CHECK-NEXT: </dict>
897// CHECK-NEXT: </array>
898// CHECK-NEXT: </array>
899// CHECK-NEXT: <key>depth</key><integer>0</integer>
900// CHECK-NEXT: <key>extended_message</key>
Ted Kremenek37c777e2013-02-26 19:44:38 +0000901// CHECK-NEXT: <string>&apos;p&apos; initialized to a null pointer value</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000902// CHECK-NEXT: <key>message</key>
Ted Kremenek37c777e2013-02-26 19:44:38 +0000903// CHECK-NEXT: <string>&apos;p&apos; initialized to a null pointer value</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000904// CHECK-NEXT: </dict>
905// CHECK-NEXT: <dict>
906// CHECK-NEXT: <key>kind</key><string>control</string>
907// CHECK-NEXT: <key>edges</key>
908// CHECK-NEXT: <array>
909// CHECK-NEXT: <dict>
910// CHECK-NEXT: <key>start</key>
911// CHECK-NEXT: <array>
912// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000913// CHECK-NEXT: <key>line</key><integer>58</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000914// CHECK-NEXT: <key>col</key><integer>3</integer>
915// CHECK-NEXT: <key>file</key><integer>0</integer>
916// CHECK-NEXT: </dict>
917// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000918// CHECK-NEXT: <key>line</key><integer>58</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000919// CHECK-NEXT: <key>col</key><integer>5</integer>
920// CHECK-NEXT: <key>file</key><integer>0</integer>
921// CHECK-NEXT: </dict>
922// CHECK-NEXT: </array>
923// CHECK-NEXT: <key>end</key>
924// CHECK-NEXT: <array>
925// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000926// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000927// CHECK-NEXT: <key>col</key><integer>3</integer>
928// CHECK-NEXT: <key>file</key><integer>0</integer>
929// CHECK-NEXT: </dict>
930// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000931// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000932// CHECK-NEXT: <key>col</key><integer>3</integer>
933// CHECK-NEXT: <key>file</key><integer>0</integer>
934// CHECK-NEXT: </dict>
935// CHECK-NEXT: </array>
936// CHECK-NEXT: </dict>
937// CHECK-NEXT: </array>
938// CHECK-NEXT: </dict>
939// CHECK-NEXT: <dict>
940// CHECK-NEXT: <key>kind</key><string>event</string>
941// CHECK-NEXT: <key>location</key>
942// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000943// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000944// CHECK-NEXT: <key>col</key><integer>3</integer>
945// CHECK-NEXT: <key>file</key><integer>0</integer>
946// CHECK-NEXT: </dict>
947// CHECK-NEXT: <key>ranges</key>
948// CHECK-NEXT: <array>
949// CHECK-NEXT: <array>
950// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000951// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000952// CHECK-NEXT: <key>col</key><integer>3</integer>
953// CHECK-NEXT: <key>file</key><integer>0</integer>
954// CHECK-NEXT: </dict>
955// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000956// CHECK-NEXT: <key>line</key><integer>61</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000957// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000958// CHECK-NEXT: <key>file</key><integer>0</integer>
959// CHECK-NEXT: </dict>
960// CHECK-NEXT: </array>
961// CHECK-NEXT: </array>
962// CHECK-NEXT: <key>depth</key><integer>0</integer>
963// CHECK-NEXT: <key>extended_message</key>
964// CHECK-NEXT: <string>Calling anonymous block</string>
965// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +0000966// CHECK-NEXT: <string>Calling anonymous block</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000967// CHECK-NEXT: </dict>
968// CHECK-NEXT: <dict>
969// CHECK-NEXT: <key>kind</key><string>event</string>
970// CHECK-NEXT: <key>location</key>
971// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000972// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000973// CHECK-NEXT: <key>col</key><integer>3</integer>
974// CHECK-NEXT: <key>file</key><integer>0</integer>
975// CHECK-NEXT: </dict>
976// CHECK-NEXT: <key>depth</key><integer>1</integer>
977// CHECK-NEXT: <key>extended_message</key>
978// CHECK-NEXT: <string>Entered call from &apos;test_block__capture_null&apos;</string>
979// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +0000980// CHECK-NEXT: <string>Entered call from &apos;test_block__capture_null&apos;</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000981// CHECK-NEXT: </dict>
982// CHECK-NEXT: <dict>
983// CHECK-NEXT: <key>kind</key><string>control</string>
984// CHECK-NEXT: <key>edges</key>
985// CHECK-NEXT: <array>
986// CHECK-NEXT: <dict>
987// CHECK-NEXT: <key>start</key>
988// CHECK-NEXT: <array>
989// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000990// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000991// CHECK-NEXT: <key>col</key><integer>3</integer>
992// CHECK-NEXT: <key>file</key><integer>0</integer>
993// CHECK-NEXT: </dict>
994// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000995// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000996// CHECK-NEXT: <key>col</key><integer>3</integer>
997// CHECK-NEXT: <key>file</key><integer>0</integer>
998// CHECK-NEXT: </dict>
999// CHECK-NEXT: </array>
1000// CHECK-NEXT: <key>end</key>
1001// CHECK-NEXT: <array>
1002// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001003// CHECK-NEXT: <key>line</key><integer>60</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001004// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001005// CHECK-NEXT: <key>file</key><integer>0</integer>
1006// CHECK-NEXT: </dict>
1007// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001008// CHECK-NEXT: <key>line</key><integer>60</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001009// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001010// CHECK-NEXT: <key>file</key><integer>0</integer>
1011// CHECK-NEXT: </dict>
1012// CHECK-NEXT: </array>
1013// CHECK-NEXT: </dict>
1014// CHECK-NEXT: </array>
1015// CHECK-NEXT: </dict>
1016// CHECK-NEXT: <dict>
Anna Zaks4e16b292013-04-23 23:57:43 +00001017// CHECK-NEXT: <key>kind</key><string>control</string>
1018// CHECK-NEXT: <key>edges</key>
1019// CHECK-NEXT: <array>
1020// CHECK-NEXT: <dict>
1021// CHECK-NEXT: <key>start</key>
1022// CHECK-NEXT: <array>
1023// CHECK-NEXT: <dict>
1024// CHECK-NEXT: <key>line</key><integer>60</integer>
1025// CHECK-NEXT: <key>col</key><integer>5</integer>
1026// CHECK-NEXT: <key>file</key><integer>0</integer>
1027// CHECK-NEXT: </dict>
1028// CHECK-NEXT: <dict>
1029// CHECK-NEXT: <key>line</key><integer>60</integer>
1030// CHECK-NEXT: <key>col</key><integer>5</integer>
1031// CHECK-NEXT: <key>file</key><integer>0</integer>
1032// CHECK-NEXT: </dict>
1033// CHECK-NEXT: </array>
1034// CHECK-NEXT: <key>end</key>
1035// CHECK-NEXT: <array>
1036// CHECK-NEXT: <dict>
1037// CHECK-NEXT: <key>line</key><integer>60</integer>
1038// CHECK-NEXT: <key>col</key><integer>8</integer>
1039// CHECK-NEXT: <key>file</key><integer>0</integer>
1040// CHECK-NEXT: </dict>
1041// CHECK-NEXT: <dict>
1042// CHECK-NEXT: <key>line</key><integer>60</integer>
1043// CHECK-NEXT: <key>col</key><integer>8</integer>
1044// CHECK-NEXT: <key>file</key><integer>0</integer>
1045// CHECK-NEXT: </dict>
1046// CHECK-NEXT: </array>
1047// CHECK-NEXT: </dict>
1048// CHECK-NEXT: </array>
1049// CHECK-NEXT: </dict>
1050// CHECK-NEXT: <dict>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001051// CHECK-NEXT: <key>kind</key><string>event</string>
1052// CHECK-NEXT: <key>location</key>
1053// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001054// CHECK-NEXT: <key>line</key><integer>60</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001055// CHECK-NEXT: <key>col</key><integer>8</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001056// CHECK-NEXT: <key>file</key><integer>0</integer>
1057// CHECK-NEXT: </dict>
1058// CHECK-NEXT: <key>ranges</key>
1059// CHECK-NEXT: <array>
1060// CHECK-NEXT: <array>
1061// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001062// CHECK-NEXT: <key>line</key><integer>60</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001063// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001064// CHECK-NEXT: <key>file</key><integer>0</integer>
1065// CHECK-NEXT: </dict>
1066// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001067// CHECK-NEXT: <key>line</key><integer>60</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001068// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001069// CHECK-NEXT: <key>file</key><integer>0</integer>
1070// CHECK-NEXT: </dict>
1071// CHECK-NEXT: </array>
1072// CHECK-NEXT: </array>
1073// CHECK-NEXT: <key>depth</key><integer>1</integer>
1074// CHECK-NEXT: <key>extended_message</key>
1075// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1076// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001077// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001078// CHECK-NEXT: </dict>
1079// CHECK-NEXT: </array>
1080// CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1081// CHECK-NEXT: <key>category</key><string>Logic error</string>
1082// CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string>
1083// CHECK-NEXT: <key>location</key>
1084// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001085// CHECK-NEXT: <key>line</key><integer>60</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001086// CHECK-NEXT: <key>col</key><integer>8</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001087// CHECK-NEXT: <key>file</key><integer>0</integer>
1088// CHECK-NEXT: </dict>
1089// CHECK-NEXT: </dict>
1090// CHECK-NEXT: <dict>
1091// CHECK-NEXT: <key>path</key>
1092// CHECK-NEXT: <array>
1093// CHECK-NEXT: <dict>
1094// CHECK-NEXT: <key>kind</key><string>control</string>
1095// CHECK-NEXT: <key>edges</key>
1096// CHECK-NEXT: <array>
1097// CHECK-NEXT: <dict>
1098// CHECK-NEXT: <key>start</key>
1099// CHECK-NEXT: <array>
1100// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001101// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001102// CHECK-NEXT: <key>col</key><integer>3</integer>
1103// CHECK-NEXT: <key>file</key><integer>0</integer>
1104// CHECK-NEXT: </dict>
1105// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001106// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001107// CHECK-NEXT: <key>col</key><integer>5</integer>
1108// CHECK-NEXT: <key>file</key><integer>0</integer>
1109// CHECK-NEXT: </dict>
1110// CHECK-NEXT: </array>
1111// CHECK-NEXT: <key>end</key>
1112// CHECK-NEXT: <array>
1113// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001114// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001115// CHECK-NEXT: <key>col</key><integer>12</integer>
1116// CHECK-NEXT: <key>file</key><integer>0</integer>
1117// CHECK-NEXT: </dict>
1118// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001119// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001120// CHECK-NEXT: <key>col</key><integer>12</integer>
1121// CHECK-NEXT: <key>file</key><integer>0</integer>
1122// CHECK-NEXT: </dict>
1123// CHECK-NEXT: </array>
1124// CHECK-NEXT: </dict>
1125// CHECK-NEXT: </array>
1126// CHECK-NEXT: </dict>
1127// CHECK-NEXT: <dict>
1128// CHECK-NEXT: <key>kind</key><string>event</string>
1129// CHECK-NEXT: <key>location</key>
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: <key>ranges</key>
1136// CHECK-NEXT: <array>
1137// CHECK-NEXT: <array>
1138// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001139// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001140// CHECK-NEXT: <key>col</key><integer>12</integer>
1141// CHECK-NEXT: <key>file</key><integer>0</integer>
1142// CHECK-NEXT: </dict>
1143// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001144// CHECK-NEXT: <key>line</key><integer>69</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001145// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001146// CHECK-NEXT: <key>file</key><integer>0</integer>
1147// CHECK-NEXT: </dict>
1148// CHECK-NEXT: </array>
1149// CHECK-NEXT: </array>
1150// CHECK-NEXT: <key>depth</key><integer>0</integer>
1151// CHECK-NEXT: <key>extended_message</key>
1152// CHECK-NEXT: <string>Calling anonymous block</string>
1153// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001154// CHECK-NEXT: <string>Calling anonymous block</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001155// CHECK-NEXT: </dict>
1156// CHECK-NEXT: <dict>
1157// CHECK-NEXT: <key>kind</key><string>event</string>
1158// CHECK-NEXT: <key>location</key>
1159// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001160// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001161// CHECK-NEXT: <key>col</key><integer>12</integer>
1162// CHECK-NEXT: <key>file</key><integer>0</integer>
1163// CHECK-NEXT: </dict>
1164// CHECK-NEXT: <key>depth</key><integer>1</integer>
1165// CHECK-NEXT: <key>extended_message</key>
1166// CHECK-NEXT: <string>Entered call from &apos;test_block_ret&apos;</string>
1167// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001168// CHECK-NEXT: <string>Entered call from &apos;test_block_ret&apos;</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001169// CHECK-NEXT: </dict>
1170// CHECK-NEXT: <dict>
1171// CHECK-NEXT: <key>kind</key><string>control</string>
1172// CHECK-NEXT: <key>edges</key>
1173// CHECK-NEXT: <array>
1174// CHECK-NEXT: <dict>
1175// CHECK-NEXT: <key>start</key>
1176// CHECK-NEXT: <array>
1177// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001178// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001179// CHECK-NEXT: <key>col</key><integer>12</integer>
1180// CHECK-NEXT: <key>file</key><integer>0</integer>
1181// CHECK-NEXT: </dict>
1182// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001183// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001184// CHECK-NEXT: <key>col</key><integer>12</integer>
1185// CHECK-NEXT: <key>file</key><integer>0</integer>
1186// CHECK-NEXT: </dict>
1187// CHECK-NEXT: </array>
1188// CHECK-NEXT: <key>end</key>
1189// CHECK-NEXT: <array>
1190// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001191// CHECK-NEXT: <key>line</key><integer>67</integer>
1192// CHECK-NEXT: <key>col</key><integer>5</integer>
1193// CHECK-NEXT: <key>file</key><integer>0</integer>
1194// CHECK-NEXT: </dict>
1195// CHECK-NEXT: <dict>
1196// CHECK-NEXT: <key>line</key><integer>67</integer>
1197// CHECK-NEXT: <key>col</key><integer>7</integer>
1198// CHECK-NEXT: <key>file</key><integer>0</integer>
1199// CHECK-NEXT: </dict>
1200// CHECK-NEXT: </array>
1201// CHECK-NEXT: </dict>
1202// CHECK-NEXT: </array>
1203// CHECK-NEXT: </dict>
1204// CHECK-NEXT: <dict>
1205// CHECK-NEXT: <key>kind</key><string>event</string>
1206// CHECK-NEXT: <key>location</key>
1207// CHECK-NEXT: <dict>
1208// CHECK-NEXT: <key>line</key><integer>67</integer>
1209// CHECK-NEXT: <key>col</key><integer>5</integer>
1210// CHECK-NEXT: <key>file</key><integer>0</integer>
1211// CHECK-NEXT: </dict>
1212// CHECK-NEXT: <key>ranges</key>
1213// CHECK-NEXT: <array>
1214// CHECK-NEXT: <array>
1215// CHECK-NEXT: <dict>
1216// CHECK-NEXT: <key>line</key><integer>67</integer>
1217// CHECK-NEXT: <key>col</key><integer>5</integer>
1218// CHECK-NEXT: <key>file</key><integer>0</integer>
1219// CHECK-NEXT: </dict>
1220// CHECK-NEXT: <dict>
1221// CHECK-NEXT: <key>line</key><integer>67</integer>
1222// CHECK-NEXT: <key>col</key><integer>10</integer>
1223// CHECK-NEXT: <key>file</key><integer>0</integer>
1224// CHECK-NEXT: </dict>
1225// CHECK-NEXT: </array>
1226// CHECK-NEXT: </array>
1227// CHECK-NEXT: <key>depth</key><integer>1</integer>
1228// CHECK-NEXT: <key>extended_message</key>
Ted Kremenek37c777e2013-02-26 19:44:38 +00001229// CHECK-NEXT: <string>&apos;q&apos; initialized to a null pointer value</string>
Ted Kremeneka5958862012-10-25 22:07:10 +00001230// CHECK-NEXT: <key>message</key>
Ted Kremenek37c777e2013-02-26 19:44:38 +00001231// CHECK-NEXT: <string>&apos;q&apos; initialized to a null pointer value</string>
Ted Kremeneka5958862012-10-25 22:07:10 +00001232// CHECK-NEXT: </dict>
1233// CHECK-NEXT: <dict>
1234// CHECK-NEXT: <key>kind</key><string>control</string>
1235// CHECK-NEXT: <key>edges</key>
1236// CHECK-NEXT: <array>
1237// CHECK-NEXT: <dict>
1238// CHECK-NEXT: <key>start</key>
1239// CHECK-NEXT: <array>
1240// CHECK-NEXT: <dict>
1241// CHECK-NEXT: <key>line</key><integer>67</integer>
1242// CHECK-NEXT: <key>col</key><integer>5</integer>
1243// CHECK-NEXT: <key>file</key><integer>0</integer>
1244// CHECK-NEXT: </dict>
1245// CHECK-NEXT: <dict>
1246// CHECK-NEXT: <key>line</key><integer>67</integer>
1247// CHECK-NEXT: <key>col</key><integer>7</integer>
1248// CHECK-NEXT: <key>file</key><integer>0</integer>
1249// CHECK-NEXT: </dict>
1250// CHECK-NEXT: </array>
1251// CHECK-NEXT: <key>end</key>
1252// CHECK-NEXT: <array>
1253// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +00001254// CHECK-NEXT: <key>line</key><integer>68</integer>
1255// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001256// CHECK-NEXT: <key>file</key><integer>0</integer>
1257// CHECK-NEXT: </dict>
1258// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +00001259// CHECK-NEXT: <key>line</key><integer>68</integer>
Ted Kremeneka5958862012-10-25 22:07:10 +00001260// CHECK-NEXT: <key>col</key><integer>10</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001261// CHECK-NEXT: <key>file</key><integer>0</integer>
1262// CHECK-NEXT: </dict>
1263// CHECK-NEXT: </array>
1264// CHECK-NEXT: </dict>
1265// CHECK-NEXT: </array>
1266// CHECK-NEXT: </dict>
1267// CHECK-NEXT: <dict>
1268// CHECK-NEXT: <key>kind</key><string>event</string>
1269// CHECK-NEXT: <key>location</key>
1270// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +00001271// CHECK-NEXT: <key>line</key><integer>68</integer>
1272// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001273// CHECK-NEXT: <key>file</key><integer>0</integer>
1274// CHECK-NEXT: </dict>
1275// CHECK-NEXT: <key>ranges</key>
1276// CHECK-NEXT: <array>
1277// CHECK-NEXT: <array>
1278// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +00001279// CHECK-NEXT: <key>line</key><integer>68</integer>
1280// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001281// CHECK-NEXT: <key>file</key><integer>0</integer>
1282// CHECK-NEXT: </dict>
1283// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +00001284// CHECK-NEXT: <key>line</key><integer>68</integer>
1285// CHECK-NEXT: <key>col</key><integer>12</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001286// CHECK-NEXT: <key>file</key><integer>0</integer>
1287// CHECK-NEXT: </dict>
1288// CHECK-NEXT: </array>
1289// CHECK-NEXT: </array>
1290// CHECK-NEXT: <key>depth</key><integer>1</integer>
1291// CHECK-NEXT: <key>extended_message</key>
1292// CHECK-NEXT: <string>Returning null pointer (loaded from &apos;q&apos;)</string>
1293// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001294// CHECK-NEXT: <string>Returning null pointer (loaded from &apos;q&apos;)</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001295// CHECK-NEXT: </dict>
1296// CHECK-NEXT: <dict>
1297// CHECK-NEXT: <key>kind</key><string>event</string>
1298// CHECK-NEXT: <key>location</key>
1299// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001300// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001301// CHECK-NEXT: <key>col</key><integer>12</integer>
1302// CHECK-NEXT: <key>file</key><integer>0</integer>
1303// CHECK-NEXT: </dict>
1304// CHECK-NEXT: <key>ranges</key>
1305// CHECK-NEXT: <array>
1306// CHECK-NEXT: <array>
1307// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001308// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001309// CHECK-NEXT: <key>col</key><integer>12</integer>
1310// CHECK-NEXT: <key>file</key><integer>0</integer>
1311// CHECK-NEXT: </dict>
1312// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001313// CHECK-NEXT: <key>line</key><integer>69</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001314// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001315// CHECK-NEXT: <key>file</key><integer>0</integer>
1316// CHECK-NEXT: </dict>
1317// CHECK-NEXT: </array>
1318// CHECK-NEXT: </array>
Jordan Rose526d93c2013-04-12 00:44:17 +00001319// CHECK-NEXT: <key>depth</key><integer>0</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001320// CHECK-NEXT: <key>extended_message</key>
1321// CHECK-NEXT: <string>Returning to caller</string>
1322// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001323// CHECK-NEXT: <string>Returning to caller</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001324// CHECK-NEXT: </dict>
1325// CHECK-NEXT: <dict>
1326// CHECK-NEXT: <key>kind</key><string>control</string>
1327// CHECK-NEXT: <key>edges</key>
1328// CHECK-NEXT: <array>
1329// CHECK-NEXT: <dict>
1330// CHECK-NEXT: <key>start</key>
1331// CHECK-NEXT: <array>
1332// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001333// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001334// CHECK-NEXT: <key>col</key><integer>12</integer>
1335// CHECK-NEXT: <key>file</key><integer>0</integer>
1336// CHECK-NEXT: </dict>
1337// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001338// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001339// CHECK-NEXT: <key>col</key><integer>12</integer>
1340// CHECK-NEXT: <key>file</key><integer>0</integer>
1341// CHECK-NEXT: </dict>
1342// CHECK-NEXT: </array>
1343// CHECK-NEXT: <key>end</key>
1344// CHECK-NEXT: <array>
1345// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001346// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001347// CHECK-NEXT: <key>col</key><integer>3</integer>
1348// CHECK-NEXT: <key>file</key><integer>0</integer>
1349// CHECK-NEXT: </dict>
1350// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001351// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001352// CHECK-NEXT: <key>col</key><integer>5</integer>
1353// CHECK-NEXT: <key>file</key><integer>0</integer>
1354// CHECK-NEXT: </dict>
1355// CHECK-NEXT: </array>
1356// CHECK-NEXT: </dict>
1357// CHECK-NEXT: </array>
1358// CHECK-NEXT: </dict>
1359// CHECK-NEXT: <dict>
1360// CHECK-NEXT: <key>kind</key><string>event</string>
1361// CHECK-NEXT: <key>location</key>
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>3</integer>
1365// CHECK-NEXT: <key>file</key><integer>0</integer>
1366// CHECK-NEXT: </dict>
1367// CHECK-NEXT: <key>ranges</key>
1368// CHECK-NEXT: <array>
1369// CHECK-NEXT: <array>
1370// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001371// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001372// CHECK-NEXT: <key>col</key><integer>3</integer>
1373// CHECK-NEXT: <key>file</key><integer>0</integer>
1374// CHECK-NEXT: </dict>
1375// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001376// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001377// CHECK-NEXT: <key>col</key><integer>8</integer>
1378// CHECK-NEXT: <key>file</key><integer>0</integer>
1379// CHECK-NEXT: </dict>
1380// CHECK-NEXT: </array>
1381// CHECK-NEXT: </array>
1382// CHECK-NEXT: <key>depth</key><integer>0</integer>
1383// CHECK-NEXT: <key>extended_message</key>
Ted Kremenek37c777e2013-02-26 19:44:38 +00001384// CHECK-NEXT: <string>&apos;p&apos; initialized to a null pointer value</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001385// CHECK-NEXT: <key>message</key>
Ted Kremenek37c777e2013-02-26 19:44:38 +00001386// CHECK-NEXT: <string>&apos;p&apos; initialized to a null pointer value</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001387// CHECK-NEXT: </dict>
1388// CHECK-NEXT: <dict>
1389// CHECK-NEXT: <key>kind</key><string>control</string>
1390// CHECK-NEXT: <key>edges</key>
1391// CHECK-NEXT: <array>
1392// CHECK-NEXT: <dict>
1393// CHECK-NEXT: <key>start</key>
1394// CHECK-NEXT: <array>
1395// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001396// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001397// CHECK-NEXT: <key>col</key><integer>3</integer>
1398// CHECK-NEXT: <key>file</key><integer>0</integer>
1399// CHECK-NEXT: </dict>
1400// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001401// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001402// CHECK-NEXT: <key>col</key><integer>5</integer>
1403// CHECK-NEXT: <key>file</key><integer>0</integer>
1404// CHECK-NEXT: </dict>
1405// CHECK-NEXT: </array>
1406// CHECK-NEXT: <key>end</key>
1407// CHECK-NEXT: <array>
1408// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001409// CHECK-NEXT: <key>line</key><integer>70</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001410// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001411// CHECK-NEXT: <key>file</key><integer>0</integer>
1412// CHECK-NEXT: </dict>
1413// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001414// CHECK-NEXT: <key>line</key><integer>70</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001415// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001416// CHECK-NEXT: <key>file</key><integer>0</integer>
1417// CHECK-NEXT: </dict>
1418// CHECK-NEXT: </array>
1419// CHECK-NEXT: </dict>
1420// CHECK-NEXT: </array>
1421// CHECK-NEXT: </dict>
1422// CHECK-NEXT: <dict>
1423// CHECK-NEXT: <key>kind</key><string>event</string>
1424// CHECK-NEXT: <key>location</key>
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: <key>ranges</key>
1431// CHECK-NEXT: <array>
1432// CHECK-NEXT: <array>
1433// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001434// CHECK-NEXT: <key>line</key><integer>70</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001435// CHECK-NEXT: <key>col</key><integer>4</integer>
1436// CHECK-NEXT: <key>file</key><integer>0</integer>
1437// CHECK-NEXT: </dict>
1438// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001439// CHECK-NEXT: <key>line</key><integer>70</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001440// CHECK-NEXT: <key>col</key><integer>4</integer>
1441// CHECK-NEXT: <key>file</key><integer>0</integer>
1442// CHECK-NEXT: </dict>
1443// CHECK-NEXT: </array>
1444// CHECK-NEXT: </array>
1445// CHECK-NEXT: <key>depth</key><integer>0</integer>
1446// CHECK-NEXT: <key>extended_message</key>
1447// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1448// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001449// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001450// CHECK-NEXT: </dict>
1451// CHECK-NEXT: </array>
1452// CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1453// CHECK-NEXT: <key>category</key><string>Logic error</string>
1454// CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string>
1455// CHECK-NEXT: <key>issue_context_kind</key><string>function</string>
1456// CHECK-NEXT: <key>issue_context</key><string>test_block_ret</string>
Anna Zaks58b961d2013-01-08 00:25:22 +00001457// CHECK-NEXT: <key>issue_hash</key><string>5</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001458// CHECK-NEXT: <key>location</key>
1459// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001460// CHECK-NEXT: <key>line</key><integer>70</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001461// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001462// CHECK-NEXT: <key>file</key><integer>0</integer>
1463// CHECK-NEXT: </dict>
1464// CHECK-NEXT: </dict>
1465// CHECK-NEXT: <dict>
1466// CHECK-NEXT: <key>path</key>
1467// CHECK-NEXT: <array>
1468// CHECK-NEXT: <dict>
1469// CHECK-NEXT: <key>kind</key><string>control</string>
1470// CHECK-NEXT: <key>edges</key>
1471// CHECK-NEXT: <array>
1472// CHECK-NEXT: <dict>
1473// CHECK-NEXT: <key>start</key>
1474// CHECK-NEXT: <array>
1475// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001476// CHECK-NEXT: <key>line</key><integer>74</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001477// CHECK-NEXT: <key>col</key><integer>3</integer>
1478// CHECK-NEXT: <key>file</key><integer>0</integer>
1479// CHECK-NEXT: </dict>
1480// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001481// CHECK-NEXT: <key>line</key><integer>74</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001482// CHECK-NEXT: <key>col</key><integer>9</integer>
1483// CHECK-NEXT: <key>file</key><integer>0</integer>
1484// CHECK-NEXT: </dict>
1485// CHECK-NEXT: </array>
1486// CHECK-NEXT: <key>end</key>
1487// CHECK-NEXT: <array>
1488// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001489// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001490// CHECK-NEXT: <key>col</key><integer>3</integer>
1491// CHECK-NEXT: <key>file</key><integer>0</integer>
1492// CHECK-NEXT: </dict>
1493// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001494// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001495// CHECK-NEXT: <key>col</key><integer>3</integer>
1496// CHECK-NEXT: <key>file</key><integer>0</integer>
1497// CHECK-NEXT: </dict>
1498// CHECK-NEXT: </array>
1499// CHECK-NEXT: </dict>
1500// CHECK-NEXT: </array>
1501// CHECK-NEXT: </dict>
1502// CHECK-NEXT: <dict>
1503// CHECK-NEXT: <key>kind</key><string>event</string>
1504// CHECK-NEXT: <key>location</key>
1505// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001506// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001507// CHECK-NEXT: <key>col</key><integer>3</integer>
1508// CHECK-NEXT: <key>file</key><integer>0</integer>
1509// CHECK-NEXT: </dict>
1510// CHECK-NEXT: <key>ranges</key>
1511// CHECK-NEXT: <array>
1512// CHECK-NEXT: <array>
1513// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001514// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001515// CHECK-NEXT: <key>col</key><integer>3</integer>
1516// CHECK-NEXT: <key>file</key><integer>0</integer>
1517// CHECK-NEXT: </dict>
1518// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001519// CHECK-NEXT: <key>line</key><integer>77</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001520// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001521// CHECK-NEXT: <key>file</key><integer>0</integer>
1522// CHECK-NEXT: </dict>
1523// CHECK-NEXT: </array>
1524// CHECK-NEXT: </array>
1525// CHECK-NEXT: <key>depth</key><integer>0</integer>
1526// CHECK-NEXT: <key>extended_message</key>
1527// CHECK-NEXT: <string>Calling anonymous block</string>
1528// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001529// CHECK-NEXT: <string>Calling anonymous block</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001530// CHECK-NEXT: </dict>
1531// CHECK-NEXT: <dict>
1532// CHECK-NEXT: <key>kind</key><string>event</string>
1533// CHECK-NEXT: <key>location</key>
1534// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001535// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001536// CHECK-NEXT: <key>col</key><integer>3</integer>
1537// CHECK-NEXT: <key>file</key><integer>0</integer>
1538// CHECK-NEXT: </dict>
1539// CHECK-NEXT: <key>depth</key><integer>1</integer>
1540// CHECK-NEXT: <key>extended_message</key>
1541// CHECK-NEXT: <string>Entered call from &apos;test_block_blockvar&apos;</string>
1542// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001543// CHECK-NEXT: <string>Entered call from &apos;test_block_blockvar&apos;</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001544// CHECK-NEXT: </dict>
1545// CHECK-NEXT: <dict>
1546// CHECK-NEXT: <key>kind</key><string>control</string>
1547// CHECK-NEXT: <key>edges</key>
1548// CHECK-NEXT: <array>
1549// CHECK-NEXT: <dict>
1550// CHECK-NEXT: <key>start</key>
1551// CHECK-NEXT: <array>
1552// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001553// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001554// CHECK-NEXT: <key>col</key><integer>3</integer>
1555// CHECK-NEXT: <key>file</key><integer>0</integer>
1556// CHECK-NEXT: </dict>
1557// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001558// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001559// CHECK-NEXT: <key>col</key><integer>3</integer>
1560// CHECK-NEXT: <key>file</key><integer>0</integer>
1561// CHECK-NEXT: </dict>
1562// CHECK-NEXT: </array>
1563// CHECK-NEXT: <key>end</key>
1564// CHECK-NEXT: <array>
1565// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001566// CHECK-NEXT: <key>line</key><integer>76</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001567// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001568// CHECK-NEXT: <key>file</key><integer>0</integer>
1569// CHECK-NEXT: </dict>
1570// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001571// CHECK-NEXT: <key>line</key><integer>76</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001572// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001573// CHECK-NEXT: <key>file</key><integer>0</integer>
1574// CHECK-NEXT: </dict>
1575// CHECK-NEXT: </array>
1576// CHECK-NEXT: </dict>
1577// CHECK-NEXT: </array>
1578// CHECK-NEXT: </dict>
1579// CHECK-NEXT: <dict>
1580// CHECK-NEXT: <key>kind</key><string>event</string>
1581// CHECK-NEXT: <key>location</key>
1582// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001583// CHECK-NEXT: <key>line</key><integer>76</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001584// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001585// CHECK-NEXT: <key>file</key><integer>0</integer>
1586// CHECK-NEXT: </dict>
1587// CHECK-NEXT: <key>ranges</key>
1588// CHECK-NEXT: <array>
1589// CHECK-NEXT: <array>
1590// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001591// CHECK-NEXT: <key>line</key><integer>76</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001592// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001593// CHECK-NEXT: <key>file</key><integer>0</integer>
1594// CHECK-NEXT: </dict>
1595// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001596// CHECK-NEXT: <key>line</key><integer>76</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001597// CHECK-NEXT: <key>col</key><integer>9</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001598// CHECK-NEXT: <key>file</key><integer>0</integer>
1599// CHECK-NEXT: </dict>
1600// CHECK-NEXT: </array>
1601// CHECK-NEXT: </array>
1602// CHECK-NEXT: <key>depth</key><integer>1</integer>
1603// CHECK-NEXT: <key>extended_message</key>
1604// CHECK-NEXT: <string>Null pointer value stored to &apos;p&apos;</string>
1605// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001606// CHECK-NEXT: <string>Null pointer value stored to &apos;p&apos;</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001607// CHECK-NEXT: </dict>
1608// CHECK-NEXT: <dict>
1609// CHECK-NEXT: <key>kind</key><string>event</string>
1610// CHECK-NEXT: <key>location</key>
1611// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001612// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001613// CHECK-NEXT: <key>col</key><integer>3</integer>
1614// CHECK-NEXT: <key>file</key><integer>0</integer>
1615// CHECK-NEXT: </dict>
1616// CHECK-NEXT: <key>ranges</key>
1617// CHECK-NEXT: <array>
1618// CHECK-NEXT: <array>
1619// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001620// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001621// CHECK-NEXT: <key>col</key><integer>3</integer>
1622// CHECK-NEXT: <key>file</key><integer>0</integer>
1623// CHECK-NEXT: </dict>
1624// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001625// CHECK-NEXT: <key>line</key><integer>77</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001626// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001627// CHECK-NEXT: <key>file</key><integer>0</integer>
1628// CHECK-NEXT: </dict>
1629// CHECK-NEXT: </array>
1630// CHECK-NEXT: </array>
Jordan Rose526d93c2013-04-12 00:44:17 +00001631// CHECK-NEXT: <key>depth</key><integer>0</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001632// CHECK-NEXT: <key>extended_message</key>
1633// CHECK-NEXT: <string>Returning to caller</string>
1634// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001635// CHECK-NEXT: <string>Returning to caller</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001636// CHECK-NEXT: </dict>
1637// CHECK-NEXT: <dict>
1638// CHECK-NEXT: <key>kind</key><string>control</string>
1639// CHECK-NEXT: <key>edges</key>
1640// CHECK-NEXT: <array>
1641// CHECK-NEXT: <dict>
1642// CHECK-NEXT: <key>start</key>
1643// CHECK-NEXT: <array>
1644// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001645// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001646// CHECK-NEXT: <key>col</key><integer>3</integer>
1647// CHECK-NEXT: <key>file</key><integer>0</integer>
1648// CHECK-NEXT: </dict>
1649// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001650// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001651// CHECK-NEXT: <key>col</key><integer>3</integer>
1652// CHECK-NEXT: <key>file</key><integer>0</integer>
1653// CHECK-NEXT: </dict>
1654// CHECK-NEXT: </array>
1655// CHECK-NEXT: <key>end</key>
1656// CHECK-NEXT: <array>
1657// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001658// CHECK-NEXT: <key>line</key><integer>78</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001659// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001660// CHECK-NEXT: <key>file</key><integer>0</integer>
1661// CHECK-NEXT: </dict>
1662// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001663// CHECK-NEXT: <key>line</key><integer>78</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001664// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001665// CHECK-NEXT: <key>file</key><integer>0</integer>
1666// CHECK-NEXT: </dict>
1667// CHECK-NEXT: </array>
1668// CHECK-NEXT: </dict>
1669// CHECK-NEXT: </array>
1670// CHECK-NEXT: </dict>
1671// CHECK-NEXT: <dict>
1672// CHECK-NEXT: <key>kind</key><string>event</string>
1673// CHECK-NEXT: <key>location</key>
1674// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001675// CHECK-NEXT: <key>line</key><integer>78</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001676// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001677// CHECK-NEXT: <key>file</key><integer>0</integer>
1678// CHECK-NEXT: </dict>
1679// CHECK-NEXT: <key>ranges</key>
1680// CHECK-NEXT: <array>
1681// CHECK-NEXT: <array>
1682// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001683// CHECK-NEXT: <key>line</key><integer>78</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001684// CHECK-NEXT: <key>col</key><integer>4</integer>
1685// CHECK-NEXT: <key>file</key><integer>0</integer>
1686// CHECK-NEXT: </dict>
1687// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001688// CHECK-NEXT: <key>line</key><integer>78</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001689// CHECK-NEXT: <key>col</key><integer>4</integer>
1690// CHECK-NEXT: <key>file</key><integer>0</integer>
1691// CHECK-NEXT: </dict>
1692// CHECK-NEXT: </array>
1693// CHECK-NEXT: </array>
1694// CHECK-NEXT: <key>depth</key><integer>0</integer>
1695// CHECK-NEXT: <key>extended_message</key>
1696// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1697// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001698// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001699// CHECK-NEXT: </dict>
1700// CHECK-NEXT: </array>
1701// CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1702// CHECK-NEXT: <key>category</key><string>Logic error</string>
1703// CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string>
1704// CHECK-NEXT: <key>issue_context_kind</key><string>function</string>
1705// CHECK-NEXT: <key>issue_context</key><string>test_block_blockvar</string>
Anna Zaks58b961d2013-01-08 00:25:22 +00001706// CHECK-NEXT: <key>issue_hash</key><string>5</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001707// CHECK-NEXT: <key>location</key>
1708// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001709// CHECK-NEXT: <key>line</key><integer>78</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001710// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001711// CHECK-NEXT: <key>file</key><integer>0</integer>
1712// CHECK-NEXT: </dict>
1713// CHECK-NEXT: </dict>
1714// CHECK-NEXT: <dict>
1715// CHECK-NEXT: <key>path</key>
1716// CHECK-NEXT: <array>
1717// CHECK-NEXT: <dict>
1718// CHECK-NEXT: <key>kind</key><string>control</string>
1719// CHECK-NEXT: <key>edges</key>
1720// CHECK-NEXT: <array>
1721// CHECK-NEXT: <dict>
1722// CHECK-NEXT: <key>start</key>
1723// CHECK-NEXT: <array>
1724// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001725// CHECK-NEXT: <key>line</key><integer>82</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001726// CHECK-NEXT: <key>col</key><integer>3</integer>
1727// CHECK-NEXT: <key>file</key><integer>0</integer>
1728// CHECK-NEXT: </dict>
1729// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001730// CHECK-NEXT: <key>line</key><integer>82</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001731// CHECK-NEXT: <key>col</key><integer>5</integer>
1732// CHECK-NEXT: <key>file</key><integer>0</integer>
1733// CHECK-NEXT: </dict>
1734// CHECK-NEXT: </array>
1735// CHECK-NEXT: <key>end</key>
1736// CHECK-NEXT: <array>
1737// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001738// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001739// CHECK-NEXT: <key>col</key><integer>3</integer>
1740// CHECK-NEXT: <key>file</key><integer>0</integer>
1741// CHECK-NEXT: </dict>
1742// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001743// CHECK-NEXT: <key>line</key><integer>83</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: </array>
1748// CHECK-NEXT: </dict>
1749// CHECK-NEXT: </array>
1750// CHECK-NEXT: </dict>
1751// CHECK-NEXT: <dict>
1752// CHECK-NEXT: <key>kind</key><string>event</string>
1753// CHECK-NEXT: <key>location</key>
1754// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001755// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001756// CHECK-NEXT: <key>col</key><integer>3</integer>
1757// CHECK-NEXT: <key>file</key><integer>0</integer>
1758// CHECK-NEXT: </dict>
1759// CHECK-NEXT: <key>ranges</key>
1760// CHECK-NEXT: <array>
1761// CHECK-NEXT: <array>
1762// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001763// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001764// CHECK-NEXT: <key>col</key><integer>3</integer>
1765// CHECK-NEXT: <key>file</key><integer>0</integer>
1766// CHECK-NEXT: </dict>
1767// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001768// CHECK-NEXT: <key>line</key><integer>85</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001769// CHECK-NEXT: <key>col</key><integer>7</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001770// CHECK-NEXT: <key>file</key><integer>0</integer>
1771// CHECK-NEXT: </dict>
1772// CHECK-NEXT: </array>
1773// CHECK-NEXT: </array>
1774// CHECK-NEXT: <key>depth</key><integer>0</integer>
1775// CHECK-NEXT: <key>extended_message</key>
1776// CHECK-NEXT: <string>Calling anonymous block</string>
1777// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001778// CHECK-NEXT: <string>Calling anonymous block</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001779// CHECK-NEXT: </dict>
1780// CHECK-NEXT: <dict>
1781// CHECK-NEXT: <key>kind</key><string>event</string>
1782// CHECK-NEXT: <key>location</key>
1783// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001784// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001785// CHECK-NEXT: <key>col</key><integer>3</integer>
1786// CHECK-NEXT: <key>file</key><integer>0</integer>
1787// CHECK-NEXT: </dict>
1788// CHECK-NEXT: <key>depth</key><integer>1</integer>
1789// CHECK-NEXT: <key>extended_message</key>
1790// CHECK-NEXT: <string>Entered call from &apos;test_block_arg&apos;</string>
1791// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001792// CHECK-NEXT: <string>Entered call from &apos;test_block_arg&apos;</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001793// CHECK-NEXT: </dict>
1794// CHECK-NEXT: <dict>
1795// CHECK-NEXT: <key>kind</key><string>control</string>
1796// CHECK-NEXT: <key>edges</key>
1797// CHECK-NEXT: <array>
1798// CHECK-NEXT: <dict>
1799// CHECK-NEXT: <key>start</key>
1800// CHECK-NEXT: <array>
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: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001807// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001808// CHECK-NEXT: <key>col</key><integer>3</integer>
1809// CHECK-NEXT: <key>file</key><integer>0</integer>
1810// CHECK-NEXT: </dict>
1811// CHECK-NEXT: </array>
1812// CHECK-NEXT: <key>end</key>
1813// CHECK-NEXT: <array>
1814// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001815// CHECK-NEXT: <key>line</key><integer>84</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001816// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001817// CHECK-NEXT: <key>file</key><integer>0</integer>
1818// CHECK-NEXT: </dict>
1819// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001820// CHECK-NEXT: <key>line</key><integer>84</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001821// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001822// CHECK-NEXT: <key>file</key><integer>0</integer>
1823// CHECK-NEXT: </dict>
1824// CHECK-NEXT: </array>
1825// CHECK-NEXT: </dict>
1826// CHECK-NEXT: </array>
1827// CHECK-NEXT: </dict>
1828// CHECK-NEXT: <dict>
1829// CHECK-NEXT: <key>kind</key><string>event</string>
1830// CHECK-NEXT: <key>location</key>
1831// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001832// CHECK-NEXT: <key>line</key><integer>84</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001833// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001834// CHECK-NEXT: <key>file</key><integer>0</integer>
1835// CHECK-NEXT: </dict>
1836// CHECK-NEXT: <key>ranges</key>
1837// CHECK-NEXT: <array>
1838// CHECK-NEXT: <array>
1839// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001840// CHECK-NEXT: <key>line</key><integer>84</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001841// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001842// CHECK-NEXT: <key>file</key><integer>0</integer>
1843// CHECK-NEXT: </dict>
1844// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001845// CHECK-NEXT: <key>line</key><integer>84</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001846// CHECK-NEXT: <key>col</key><integer>10</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001847// CHECK-NEXT: <key>file</key><integer>0</integer>
1848// CHECK-NEXT: </dict>
1849// CHECK-NEXT: </array>
1850// CHECK-NEXT: </array>
1851// CHECK-NEXT: <key>depth</key><integer>1</integer>
1852// CHECK-NEXT: <key>extended_message</key>
1853// CHECK-NEXT: <string>Null pointer value stored to &apos;p&apos;</string>
1854// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001855// CHECK-NEXT: <string>Null pointer value stored to &apos;p&apos;</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001856// CHECK-NEXT: </dict>
1857// CHECK-NEXT: <dict>
1858// CHECK-NEXT: <key>kind</key><string>event</string>
1859// CHECK-NEXT: <key>location</key>
1860// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001861// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001862// CHECK-NEXT: <key>col</key><integer>3</integer>
1863// CHECK-NEXT: <key>file</key><integer>0</integer>
1864// CHECK-NEXT: </dict>
1865// CHECK-NEXT: <key>ranges</key>
1866// CHECK-NEXT: <array>
1867// CHECK-NEXT: <array>
1868// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001869// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001870// CHECK-NEXT: <key>col</key><integer>3</integer>
1871// CHECK-NEXT: <key>file</key><integer>0</integer>
1872// CHECK-NEXT: </dict>
1873// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001874// CHECK-NEXT: <key>line</key><integer>85</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001875// CHECK-NEXT: <key>col</key><integer>7</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001876// CHECK-NEXT: <key>file</key><integer>0</integer>
1877// CHECK-NEXT: </dict>
1878// CHECK-NEXT: </array>
1879// CHECK-NEXT: </array>
Jordan Rose526d93c2013-04-12 00:44:17 +00001880// CHECK-NEXT: <key>depth</key><integer>0</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001881// CHECK-NEXT: <key>extended_message</key>
1882// CHECK-NEXT: <string>Returning to caller</string>
1883// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001884// CHECK-NEXT: <string>Returning to caller</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001885// CHECK-NEXT: </dict>
1886// CHECK-NEXT: <dict>
1887// CHECK-NEXT: <key>kind</key><string>control</string>
1888// CHECK-NEXT: <key>edges</key>
1889// CHECK-NEXT: <array>
1890// CHECK-NEXT: <dict>
1891// CHECK-NEXT: <key>start</key>
1892// CHECK-NEXT: <array>
1893// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001894// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001895// CHECK-NEXT: <key>col</key><integer>3</integer>
1896// CHECK-NEXT: <key>file</key><integer>0</integer>
1897// CHECK-NEXT: </dict>
1898// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001899// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001900// CHECK-NEXT: <key>col</key><integer>3</integer>
1901// CHECK-NEXT: <key>file</key><integer>0</integer>
1902// CHECK-NEXT: </dict>
1903// CHECK-NEXT: </array>
1904// CHECK-NEXT: <key>end</key>
1905// CHECK-NEXT: <array>
1906// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001907// CHECK-NEXT: <key>line</key><integer>86</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001908// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001909// CHECK-NEXT: <key>file</key><integer>0</integer>
1910// CHECK-NEXT: </dict>
1911// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001912// CHECK-NEXT: <key>line</key><integer>86</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001913// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001914// CHECK-NEXT: <key>file</key><integer>0</integer>
1915// CHECK-NEXT: </dict>
1916// CHECK-NEXT: </array>
1917// CHECK-NEXT: </dict>
1918// CHECK-NEXT: </array>
1919// CHECK-NEXT: </dict>
1920// CHECK-NEXT: <dict>
1921// CHECK-NEXT: <key>kind</key><string>event</string>
1922// CHECK-NEXT: <key>location</key>
1923// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001924// CHECK-NEXT: <key>line</key><integer>86</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001925// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001926// CHECK-NEXT: <key>file</key><integer>0</integer>
1927// CHECK-NEXT: </dict>
1928// CHECK-NEXT: <key>ranges</key>
1929// CHECK-NEXT: <array>
1930// CHECK-NEXT: <array>
1931// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001932// CHECK-NEXT: <key>line</key><integer>86</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001933// CHECK-NEXT: <key>col</key><integer>4</integer>
1934// CHECK-NEXT: <key>file</key><integer>0</integer>
1935// CHECK-NEXT: </dict>
1936// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001937// CHECK-NEXT: <key>line</key><integer>86</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001938// CHECK-NEXT: <key>col</key><integer>4</integer>
1939// CHECK-NEXT: <key>file</key><integer>0</integer>
1940// CHECK-NEXT: </dict>
1941// CHECK-NEXT: </array>
1942// CHECK-NEXT: </array>
1943// CHECK-NEXT: <key>depth</key><integer>0</integer>
1944// CHECK-NEXT: <key>extended_message</key>
1945// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1946// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001947// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001948// CHECK-NEXT: </dict>
1949// CHECK-NEXT: </array>
1950// CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1951// CHECK-NEXT: <key>category</key><string>Logic error</string>
1952// CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string>
1953// CHECK-NEXT: <key>issue_context_kind</key><string>function</string>
1954// CHECK-NEXT: <key>issue_context</key><string>test_block_arg</string>
Anna Zaks58b961d2013-01-08 00:25:22 +00001955// CHECK-NEXT: <key>issue_hash</key><string>5</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001956// CHECK-NEXT: <key>location</key>
1957// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001958// CHECK-NEXT: <key>line</key><integer>86</integer>
Anna Zaks4e16b292013-04-23 23:57:43 +00001959// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001960// CHECK-NEXT: <key>file</key><integer>0</integer>
1961// CHECK-NEXT: </dict>
1962// CHECK-NEXT: </dict>
1963// CHECK-NEXT: </array>