blob: 999ebdbd3ab9b3df058941d0db06ab96fb087917 [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
2// RUN: %clang --analyze %s -fblocks -Xanalyzer -analyzer-config -Xanalyzer suppress-null-return-paths=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() {
Jordan Rose106b037a2012-09-22 01:24:46 +000058 int *p = 0; // expected-note{{Variable 'p' initialized to a null pointer value}}
59 ^(){ // 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 Rose106b037a2012-09-22 01:24:46 +000066 int *p = ^(){ // expected-note {{Calling anonymous block}} expected-note{{Returning to caller}} expected-note {{Variable 'p' initialized to a null pointer value}}
67 int *q = 0; // expected-note {{Variable 'q' initialized to a null pointer value}}
68 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>
247// CHECK-NEXT: <key>col</key><integer>10</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>
252// CHECK-NEXT: <key>col</key><integer>10</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>
264// CHECK-NEXT: <key>col</key><integer>10</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>
Jordan Rose106b037a2012-09-22 01:24:46 +0000294// CHECK-NEXT: <key>issue_hash</key><integer>7</integer>
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>
298// CHECK-NEXT: <key>col</key><integer>10</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>
446// CHECK-NEXT: <key>kind</key><string>event</string>
447// CHECK-NEXT: <key>location</key>
448// CHECK-NEXT: <dict>
449// CHECK-NEXT: <key>line</key><integer>23</integer>
450// CHECK-NEXT: <key>col</key><integer>3</integer>
451// CHECK-NEXT: <key>file</key><integer>0</integer>
452// CHECK-NEXT: </dict>
453// CHECK-NEXT: <key>ranges</key>
454// CHECK-NEXT: <array>
455// CHECK-NEXT: <array>
456// CHECK-NEXT: <dict>
457// CHECK-NEXT: <key>line</key><integer>23</integer>
458// CHECK-NEXT: <key>col</key><integer>4</integer>
459// CHECK-NEXT: <key>file</key><integer>0</integer>
460// CHECK-NEXT: </dict>
461// CHECK-NEXT: <dict>
462// CHECK-NEXT: <key>line</key><integer>23</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000463// CHECK-NEXT: <key>col</key><integer>4</integer>
464// CHECK-NEXT: <key>file</key><integer>0</integer>
465// CHECK-NEXT: </dict>
466// CHECK-NEXT: </array>
467// CHECK-NEXT: </array>
468// CHECK-NEXT: <key>depth</key><integer>1</integer>
469// CHECK-NEXT: <key>extended_message</key>
470// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
471// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +0000472// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
473// CHECK-NEXT: </dict>
474// CHECK-NEXT: </array>
475// CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
476// CHECK-NEXT: <key>category</key><string>Logic error</string>
477// CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string>
478// CHECK-NEXT: <key>issue_context_kind</key><string>function</string>
479// CHECK-NEXT: <key>issue_context</key><string>has_bug</string>
480// CHECK-NEXT: <key>issue_hash</key><integer>1</integer>
481// CHECK-NEXT: <key>location</key>
482// CHECK-NEXT: <dict>
483// CHECK-NEXT: <key>line</key><integer>23</integer>
484// CHECK-NEXT: <key>col</key><integer>3</integer>
485// CHECK-NEXT: <key>file</key><integer>0</integer>
486// CHECK-NEXT: </dict>
487// CHECK-NEXT: </dict>
488// CHECK-NEXT: <dict>
489// CHECK-NEXT: <key>path</key>
490// CHECK-NEXT: <array>
491// CHECK-NEXT: <dict>
492// CHECK-NEXT: <key>kind</key><string>control</string>
493// CHECK-NEXT: <key>edges</key>
494// CHECK-NEXT: <array>
495// CHECK-NEXT: <dict>
496// CHECK-NEXT: <key>start</key>
497// CHECK-NEXT: <array>
498// CHECK-NEXT: <dict>
499// CHECK-NEXT: <key>line</key><integer>39</integer>
500// CHECK-NEXT: <key>col</key><integer>3</integer>
501// CHECK-NEXT: <key>file</key><integer>0</integer>
502// CHECK-NEXT: </dict>
503// CHECK-NEXT: <dict>
504// CHECK-NEXT: <key>line</key><integer>39</integer>
505// CHECK-NEXT: <key>col</key><integer>4</integer>
506// CHECK-NEXT: <key>file</key><integer>0</integer>
507// CHECK-NEXT: </dict>
508// CHECK-NEXT: </array>
509// CHECK-NEXT: <key>end</key>
510// CHECK-NEXT: <array>
511// CHECK-NEXT: <dict>
512// CHECK-NEXT: <key>line</key><integer>39</integer>
513// CHECK-NEXT: <key>col</key><integer>8</integer>
514// CHECK-NEXT: <key>file</key><integer>0</integer>
515// CHECK-NEXT: </dict>
516// CHECK-NEXT: <dict>
517// CHECK-NEXT: <key>line</key><integer>39</integer>
518// CHECK-NEXT: <key>col</key><integer>8</integer>
519// CHECK-NEXT: <key>file</key><integer>0</integer>
520// CHECK-NEXT: </dict>
521// CHECK-NEXT: </array>
522// CHECK-NEXT: </dict>
523// CHECK-NEXT: </array>
524// CHECK-NEXT: </dict>
525// CHECK-NEXT: <dict>
526// CHECK-NEXT: <key>kind</key><string>event</string>
527// CHECK-NEXT: <key>location</key>
528// CHECK-NEXT: <dict>
529// CHECK-NEXT: <key>line</key><integer>39</integer>
530// CHECK-NEXT: <key>col</key><integer>8</integer>
531// CHECK-NEXT: <key>file</key><integer>0</integer>
532// CHECK-NEXT: </dict>
533// CHECK-NEXT: <key>ranges</key>
534// CHECK-NEXT: <array>
535// CHECK-NEXT: <array>
536// CHECK-NEXT: <dict>
537// CHECK-NEXT: <key>line</key><integer>39</integer>
538// CHECK-NEXT: <key>col</key><integer>8</integer>
539// CHECK-NEXT: <key>file</key><integer>0</integer>
540// CHECK-NEXT: </dict>
541// CHECK-NEXT: <dict>
542// CHECK-NEXT: <key>line</key><integer>39</integer>
543// CHECK-NEXT: <key>col</key><integer>9</integer>
544// CHECK-NEXT: <key>file</key><integer>0</integer>
545// CHECK-NEXT: </dict>
546// CHECK-NEXT: </array>
547// CHECK-NEXT: </array>
548// CHECK-NEXT: <key>depth</key><integer>0</integer>
549// CHECK-NEXT: <key>extended_message</key>
550// CHECK-NEXT: <string>Assuming &apos;p&apos; is null</string>
551// CHECK-NEXT: <key>message</key>
552// CHECK-NEXT: <string>Assuming &apos;p&apos; is null</string>
553// CHECK-NEXT: </dict>
554// CHECK-NEXT: <dict>
555// CHECK-NEXT: <key>kind</key><string>control</string>
556// CHECK-NEXT: <key>edges</key>
557// CHECK-NEXT: <array>
558// CHECK-NEXT: <dict>
559// CHECK-NEXT: <key>start</key>
560// CHECK-NEXT: <array>
561// CHECK-NEXT: <dict>
562// CHECK-NEXT: <key>line</key><integer>39</integer>
563// CHECK-NEXT: <key>col</key><integer>8</integer>
564// CHECK-NEXT: <key>file</key><integer>0</integer>
565// CHECK-NEXT: </dict>
566// CHECK-NEXT: <dict>
567// CHECK-NEXT: <key>line</key><integer>39</integer>
568// CHECK-NEXT: <key>col</key><integer>8</integer>
569// CHECK-NEXT: <key>file</key><integer>0</integer>
570// CHECK-NEXT: </dict>
571// CHECK-NEXT: </array>
572// CHECK-NEXT: <key>end</key>
573// CHECK-NEXT: <array>
574// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000575// CHECK-NEXT: <key>line</key><integer>45</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000576// CHECK-NEXT: <key>col</key><integer>3</integer>
577// CHECK-NEXT: <key>file</key><integer>0</integer>
578// CHECK-NEXT: </dict>
579// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000580// CHECK-NEXT: <key>line</key><integer>45</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000581// CHECK-NEXT: <key>col</key><integer>4</integer>
582// CHECK-NEXT: <key>file</key><integer>0</integer>
583// CHECK-NEXT: </dict>
584// CHECK-NEXT: </array>
585// CHECK-NEXT: </dict>
586// CHECK-NEXT: </array>
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>
Ted Kremeneka5958862012-10-25 22:07:10 +0000596// CHECK-NEXT: <key>line</key><integer>45</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000597// CHECK-NEXT: <key>col</key><integer>3</integer>
598// CHECK-NEXT: <key>file</key><integer>0</integer>
599// CHECK-NEXT: </dict>
600// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000601// CHECK-NEXT: <key>line</key><integer>45</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000602// CHECK-NEXT: <key>col</key><integer>4</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>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000610// CHECK-NEXT: <key>col</key><integer>5</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>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000615// CHECK-NEXT: <key>col</key><integer>16</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>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000631// CHECK-NEXT: <key>col</key><integer>5</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>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000636// CHECK-NEXT: <key>col</key><integer>16</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>18</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>18</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>event</string>
658// CHECK-NEXT: <key>location</key>
659// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000660// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000661// CHECK-NEXT: <key>col</key><integer>18</integer>
662// CHECK-NEXT: <key>file</key><integer>0</integer>
663// CHECK-NEXT: </dict>
664// CHECK-NEXT: <key>ranges</key>
665// CHECK-NEXT: <array>
666// CHECK-NEXT: <array>
667// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000668// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000669// CHECK-NEXT: <key>col</key><integer>18</integer>
670// CHECK-NEXT: <key>file</key><integer>0</integer>
671// CHECK-NEXT: </dict>
672// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000673// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000674// CHECK-NEXT: <key>col</key><integer>18</integer>
675// CHECK-NEXT: <key>file</key><integer>0</integer>
676// CHECK-NEXT: </dict>
677// CHECK-NEXT: </array>
678// CHECK-NEXT: </array>
679// CHECK-NEXT: <key>depth</key><integer>0</integer>
680// CHECK-NEXT: <key>extended_message</key>
681// CHECK-NEXT: <string>Passing null pointer value via 1st parameter &apos;p&apos;</string>
682// CHECK-NEXT: <key>message</key>
683// CHECK-NEXT: <string>Passing null pointer value via 1st parameter &apos;p&apos;</string>
684// CHECK-NEXT: </dict>
685// CHECK-NEXT: <dict>
686// CHECK-NEXT: <key>kind</key><string>event</string>
687// CHECK-NEXT: <key>location</key>
688// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000689// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000690// CHECK-NEXT: <key>col</key><integer>5</integer>
691// CHECK-NEXT: <key>file</key><integer>0</integer>
692// CHECK-NEXT: </dict>
693// CHECK-NEXT: <key>ranges</key>
694// CHECK-NEXT: <array>
695// CHECK-NEXT: <array>
696// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000697// CHECK-NEXT: <key>line</key><integer>47</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000698// CHECK-NEXT: <key>col</key><integer>5</integer>
699// CHECK-NEXT: <key>file</key><integer>0</integer>
700// CHECK-NEXT: </dict>
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>19</integer>
704// CHECK-NEXT: <key>file</key><integer>0</integer>
705// CHECK-NEXT: </dict>
706// CHECK-NEXT: </array>
707// CHECK-NEXT: </array>
708// CHECK-NEXT: <key>depth</key><integer>0</integer>
709// CHECK-NEXT: <key>extended_message</key>
710// CHECK-NEXT: <string>Calling &apos;triggers_bug&apos;</string>
711// CHECK-NEXT: <key>message</key>
712// CHECK-NEXT: <string>Calling &apos;triggers_bug&apos;</string>
713// CHECK-NEXT: </dict>
714// CHECK-NEXT: <dict>
715// CHECK-NEXT: <key>kind</key><string>event</string>
716// CHECK-NEXT: <key>location</key>
717// CHECK-NEXT: <dict>
718// CHECK-NEXT: <key>line</key><integer>32</integer>
719// CHECK-NEXT: <key>col</key><integer>1</integer>
720// CHECK-NEXT: <key>file</key><integer>0</integer>
721// CHECK-NEXT: </dict>
722// CHECK-NEXT: <key>depth</key><integer>1</integer>
723// CHECK-NEXT: <key>extended_message</key>
724// CHECK-NEXT: <string>Entered call from &apos;bar&apos;</string>
725// CHECK-NEXT: <key>message</key>
726// CHECK-NEXT: <string>Entered call from &apos;bar&apos;</string>
727// CHECK-NEXT: </dict>
728// CHECK-NEXT: <dict>
729// CHECK-NEXT: <key>kind</key><string>control</string>
730// CHECK-NEXT: <key>edges</key>
731// CHECK-NEXT: <array>
732// CHECK-NEXT: <dict>
733// CHECK-NEXT: <key>start</key>
734// CHECK-NEXT: <array>
735// CHECK-NEXT: <dict>
736// CHECK-NEXT: <key>line</key><integer>32</integer>
737// CHECK-NEXT: <key>col</key><integer>1</integer>
738// CHECK-NEXT: <key>file</key><integer>0</integer>
739// CHECK-NEXT: </dict>
740// CHECK-NEXT: <dict>
741// CHECK-NEXT: <key>line</key><integer>32</integer>
742// CHECK-NEXT: <key>col</key><integer>4</integer>
743// CHECK-NEXT: <key>file</key><integer>0</integer>
744// CHECK-NEXT: </dict>
745// CHECK-NEXT: </array>
746// CHECK-NEXT: <key>end</key>
747// CHECK-NEXT: <array>
748// CHECK-NEXT: <dict>
749// CHECK-NEXT: <key>line</key><integer>33</integer>
750// CHECK-NEXT: <key>col</key><integer>3</integer>
751// CHECK-NEXT: <key>file</key><integer>0</integer>
752// CHECK-NEXT: </dict>
753// CHECK-NEXT: <dict>
754// CHECK-NEXT: <key>line</key><integer>33</integer>
755// CHECK-NEXT: <key>col</key><integer>3</integer>
756// CHECK-NEXT: <key>file</key><integer>0</integer>
757// CHECK-NEXT: </dict>
758// CHECK-NEXT: </array>
759// CHECK-NEXT: </dict>
760// CHECK-NEXT: </array>
761// CHECK-NEXT: </dict>
762// CHECK-NEXT: <dict>
763// CHECK-NEXT: <key>kind</key><string>event</string>
764// CHECK-NEXT: <key>location</key>
765// CHECK-NEXT: <dict>
766// CHECK-NEXT: <key>line</key><integer>33</integer>
767// CHECK-NEXT: <key>col</key><integer>3</integer>
768// CHECK-NEXT: <key>file</key><integer>0</integer>
769// CHECK-NEXT: </dict>
770// CHECK-NEXT: <key>ranges</key>
771// CHECK-NEXT: <array>
772// CHECK-NEXT: <array>
773// CHECK-NEXT: <dict>
774// CHECK-NEXT: <key>line</key><integer>33</integer>
775// CHECK-NEXT: <key>col</key><integer>4</integer>
776// CHECK-NEXT: <key>file</key><integer>0</integer>
777// CHECK-NEXT: </dict>
778// CHECK-NEXT: <dict>
779// CHECK-NEXT: <key>line</key><integer>33</integer>
780// CHECK-NEXT: <key>col</key><integer>4</integer>
781// CHECK-NEXT: <key>file</key><integer>0</integer>
782// CHECK-NEXT: </dict>
783// CHECK-NEXT: </array>
784// CHECK-NEXT: </array>
785// CHECK-NEXT: <key>depth</key><integer>1</integer>
786// CHECK-NEXT: <key>extended_message</key>
787// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
788// CHECK-NEXT: <key>message</key>
789// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000790// CHECK-NEXT: </dict>
791// CHECK-NEXT: </array>
792// CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
793// CHECK-NEXT: <key>category</key><string>Logic error</string>
794// CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string>
795// CHECK-NEXT: <key>issue_context_kind</key><string>function</string>
796// CHECK-NEXT: <key>issue_context</key><string>triggers_bug</string>
797// CHECK-NEXT: <key>issue_hash</key><integer>1</integer>
798// CHECK-NEXT: <key>location</key>
799// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +0000800// CHECK-NEXT: <key>line</key><integer>33</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000801// CHECK-NEXT: <key>col</key><integer>3</integer>
802// CHECK-NEXT: <key>file</key><integer>0</integer>
803// CHECK-NEXT: </dict>
804// CHECK-NEXT: </dict>
805// CHECK-NEXT: <dict>
806// CHECK-NEXT: <key>path</key>
807// CHECK-NEXT: <array>
808// CHECK-NEXT: <dict>
809// CHECK-NEXT: <key>kind</key><string>event</string>
810// CHECK-NEXT: <key>location</key>
811// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000812// CHECK-NEXT: <key>line</key><integer>58</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000813// CHECK-NEXT: <key>col</key><integer>3</integer>
814// CHECK-NEXT: <key>file</key><integer>0</integer>
815// CHECK-NEXT: </dict>
816// CHECK-NEXT: <key>ranges</key>
817// CHECK-NEXT: <array>
818// CHECK-NEXT: <array>
819// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000820// CHECK-NEXT: <key>line</key><integer>58</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000821// CHECK-NEXT: <key>col</key><integer>3</integer>
822// CHECK-NEXT: <key>file</key><integer>0</integer>
823// CHECK-NEXT: </dict>
824// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000825// CHECK-NEXT: <key>line</key><integer>58</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000826// CHECK-NEXT: <key>col</key><integer>8</integer>
827// CHECK-NEXT: <key>file</key><integer>0</integer>
828// CHECK-NEXT: </dict>
829// CHECK-NEXT: </array>
830// CHECK-NEXT: </array>
831// CHECK-NEXT: <key>depth</key><integer>0</integer>
832// CHECK-NEXT: <key>extended_message</key>
833// CHECK-NEXT: <string>Variable &apos;p&apos; initialized to a null pointer value</string>
834// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +0000835// CHECK-NEXT: <string>Variable &apos;p&apos; initialized to a null pointer value</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000836// CHECK-NEXT: </dict>
837// CHECK-NEXT: <dict>
838// CHECK-NEXT: <key>kind</key><string>control</string>
839// CHECK-NEXT: <key>edges</key>
840// CHECK-NEXT: <array>
841// CHECK-NEXT: <dict>
842// CHECK-NEXT: <key>start</key>
843// CHECK-NEXT: <array>
844// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000845// CHECK-NEXT: <key>line</key><integer>58</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000846// CHECK-NEXT: <key>col</key><integer>3</integer>
847// CHECK-NEXT: <key>file</key><integer>0</integer>
848// CHECK-NEXT: </dict>
849// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000850// CHECK-NEXT: <key>line</key><integer>58</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000851// CHECK-NEXT: <key>col</key><integer>5</integer>
852// CHECK-NEXT: <key>file</key><integer>0</integer>
853// CHECK-NEXT: </dict>
854// CHECK-NEXT: </array>
855// CHECK-NEXT: <key>end</key>
856// CHECK-NEXT: <array>
857// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000858// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000859// CHECK-NEXT: <key>col</key><integer>3</integer>
860// CHECK-NEXT: <key>file</key><integer>0</integer>
861// CHECK-NEXT: </dict>
862// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000863// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000864// CHECK-NEXT: <key>col</key><integer>3</integer>
865// CHECK-NEXT: <key>file</key><integer>0</integer>
866// CHECK-NEXT: </dict>
867// CHECK-NEXT: </array>
868// CHECK-NEXT: </dict>
869// CHECK-NEXT: </array>
870// CHECK-NEXT: </dict>
871// CHECK-NEXT: <dict>
872// CHECK-NEXT: <key>kind</key><string>event</string>
873// CHECK-NEXT: <key>location</key>
874// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000875// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000876// CHECK-NEXT: <key>col</key><integer>3</integer>
877// CHECK-NEXT: <key>file</key><integer>0</integer>
878// CHECK-NEXT: </dict>
879// CHECK-NEXT: <key>ranges</key>
880// CHECK-NEXT: <array>
881// CHECK-NEXT: <array>
882// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000883// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000884// CHECK-NEXT: <key>col</key><integer>3</integer>
885// CHECK-NEXT: <key>file</key><integer>0</integer>
886// CHECK-NEXT: </dict>
887// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000888// CHECK-NEXT: <key>line</key><integer>61</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000889// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000890// CHECK-NEXT: <key>file</key><integer>0</integer>
891// CHECK-NEXT: </dict>
892// CHECK-NEXT: </array>
893// CHECK-NEXT: </array>
894// CHECK-NEXT: <key>depth</key><integer>0</integer>
895// CHECK-NEXT: <key>extended_message</key>
896// CHECK-NEXT: <string>Calling anonymous block</string>
897// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +0000898// CHECK-NEXT: <string>Calling anonymous block</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000899// CHECK-NEXT: </dict>
900// CHECK-NEXT: <dict>
901// CHECK-NEXT: <key>kind</key><string>event</string>
902// CHECK-NEXT: <key>location</key>
903// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000904// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000905// CHECK-NEXT: <key>col</key><integer>3</integer>
906// CHECK-NEXT: <key>file</key><integer>0</integer>
907// CHECK-NEXT: </dict>
908// CHECK-NEXT: <key>depth</key><integer>1</integer>
909// CHECK-NEXT: <key>extended_message</key>
910// CHECK-NEXT: <string>Entered call from &apos;test_block__capture_null&apos;</string>
911// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +0000912// CHECK-NEXT: <string>Entered call from &apos;test_block__capture_null&apos;</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000913// CHECK-NEXT: </dict>
914// CHECK-NEXT: <dict>
915// CHECK-NEXT: <key>kind</key><string>control</string>
916// CHECK-NEXT: <key>edges</key>
917// CHECK-NEXT: <array>
918// CHECK-NEXT: <dict>
919// CHECK-NEXT: <key>start</key>
920// CHECK-NEXT: <array>
921// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000922// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000923// CHECK-NEXT: <key>col</key><integer>3</integer>
924// CHECK-NEXT: <key>file</key><integer>0</integer>
925// CHECK-NEXT: </dict>
926// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000927// CHECK-NEXT: <key>line</key><integer>59</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000928// CHECK-NEXT: <key>col</key><integer>3</integer>
929// CHECK-NEXT: <key>file</key><integer>0</integer>
930// CHECK-NEXT: </dict>
931// CHECK-NEXT: </array>
932// CHECK-NEXT: <key>end</key>
933// CHECK-NEXT: <array>
934// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000935// CHECK-NEXT: <key>line</key><integer>60</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000936// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000937// CHECK-NEXT: <key>file</key><integer>0</integer>
938// CHECK-NEXT: </dict>
939// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000940// CHECK-NEXT: <key>line</key><integer>60</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000941// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000942// CHECK-NEXT: <key>file</key><integer>0</integer>
943// CHECK-NEXT: </dict>
944// CHECK-NEXT: </array>
945// CHECK-NEXT: </dict>
946// CHECK-NEXT: </array>
947// CHECK-NEXT: </dict>
948// CHECK-NEXT: <dict>
949// CHECK-NEXT: <key>kind</key><string>event</string>
950// CHECK-NEXT: <key>location</key>
951// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000952// CHECK-NEXT: <key>line</key><integer>60</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000953// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000954// CHECK-NEXT: <key>file</key><integer>0</integer>
955// CHECK-NEXT: </dict>
956// CHECK-NEXT: <key>ranges</key>
957// CHECK-NEXT: <array>
958// CHECK-NEXT: <array>
959// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000960// CHECK-NEXT: <key>line</key><integer>60</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000961// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000962// CHECK-NEXT: <key>file</key><integer>0</integer>
963// CHECK-NEXT: </dict>
964// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000965// CHECK-NEXT: <key>line</key><integer>60</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000966// CHECK-NEXT: <key>col</key><integer>6</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000967// CHECK-NEXT: <key>file</key><integer>0</integer>
968// CHECK-NEXT: </dict>
969// CHECK-NEXT: </array>
970// CHECK-NEXT: </array>
971// CHECK-NEXT: <key>depth</key><integer>1</integer>
972// CHECK-NEXT: <key>extended_message</key>
973// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
974// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +0000975// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000976// CHECK-NEXT: </dict>
977// CHECK-NEXT: </array>
978// CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
979// CHECK-NEXT: <key>category</key><string>Logic error</string>
980// CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string>
981// CHECK-NEXT: <key>location</key>
982// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000983// CHECK-NEXT: <key>line</key><integer>60</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +0000984// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +0000985// CHECK-NEXT: <key>file</key><integer>0</integer>
986// CHECK-NEXT: </dict>
987// CHECK-NEXT: </dict>
988// CHECK-NEXT: <dict>
989// CHECK-NEXT: <key>path</key>
990// CHECK-NEXT: <array>
991// CHECK-NEXT: <dict>
992// CHECK-NEXT: <key>kind</key><string>control</string>
993// CHECK-NEXT: <key>edges</key>
994// CHECK-NEXT: <array>
995// CHECK-NEXT: <dict>
996// CHECK-NEXT: <key>start</key>
997// CHECK-NEXT: <array>
998// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +0000999// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001000// CHECK-NEXT: <key>col</key><integer>3</integer>
1001// CHECK-NEXT: <key>file</key><integer>0</integer>
1002// CHECK-NEXT: </dict>
1003// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001004// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001005// CHECK-NEXT: <key>col</key><integer>5</integer>
1006// CHECK-NEXT: <key>file</key><integer>0</integer>
1007// CHECK-NEXT: </dict>
1008// CHECK-NEXT: </array>
1009// CHECK-NEXT: <key>end</key>
1010// CHECK-NEXT: <array>
1011// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001012// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001013// CHECK-NEXT: <key>col</key><integer>12</integer>
1014// CHECK-NEXT: <key>file</key><integer>0</integer>
1015// CHECK-NEXT: </dict>
1016// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001017// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001018// CHECK-NEXT: <key>col</key><integer>12</integer>
1019// CHECK-NEXT: <key>file</key><integer>0</integer>
1020// CHECK-NEXT: </dict>
1021// CHECK-NEXT: </array>
1022// CHECK-NEXT: </dict>
1023// CHECK-NEXT: </array>
1024// CHECK-NEXT: </dict>
1025// CHECK-NEXT: <dict>
1026// CHECK-NEXT: <key>kind</key><string>event</string>
1027// CHECK-NEXT: <key>location</key>
1028// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001029// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001030// CHECK-NEXT: <key>col</key><integer>12</integer>
1031// CHECK-NEXT: <key>file</key><integer>0</integer>
1032// CHECK-NEXT: </dict>
1033// CHECK-NEXT: <key>ranges</key>
1034// CHECK-NEXT: <array>
1035// CHECK-NEXT: <array>
1036// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001037// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001038// CHECK-NEXT: <key>col</key><integer>12</integer>
1039// CHECK-NEXT: <key>file</key><integer>0</integer>
1040// CHECK-NEXT: </dict>
1041// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001042// CHECK-NEXT: <key>line</key><integer>69</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001043// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001044// CHECK-NEXT: <key>file</key><integer>0</integer>
1045// CHECK-NEXT: </dict>
1046// CHECK-NEXT: </array>
1047// CHECK-NEXT: </array>
1048// CHECK-NEXT: <key>depth</key><integer>0</integer>
1049// CHECK-NEXT: <key>extended_message</key>
1050// CHECK-NEXT: <string>Calling anonymous block</string>
1051// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001052// CHECK-NEXT: <string>Calling anonymous block</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001053// CHECK-NEXT: </dict>
1054// CHECK-NEXT: <dict>
1055// CHECK-NEXT: <key>kind</key><string>event</string>
1056// CHECK-NEXT: <key>location</key>
1057// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001058// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001059// CHECK-NEXT: <key>col</key><integer>12</integer>
1060// CHECK-NEXT: <key>file</key><integer>0</integer>
1061// CHECK-NEXT: </dict>
1062// CHECK-NEXT: <key>depth</key><integer>1</integer>
1063// CHECK-NEXT: <key>extended_message</key>
1064// CHECK-NEXT: <string>Entered call from &apos;test_block_ret&apos;</string>
1065// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001066// CHECK-NEXT: <string>Entered call from &apos;test_block_ret&apos;</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001067// CHECK-NEXT: </dict>
1068// CHECK-NEXT: <dict>
1069// CHECK-NEXT: <key>kind</key><string>control</string>
1070// CHECK-NEXT: <key>edges</key>
1071// CHECK-NEXT: <array>
1072// CHECK-NEXT: <dict>
1073// CHECK-NEXT: <key>start</key>
1074// CHECK-NEXT: <array>
1075// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001076// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001077// CHECK-NEXT: <key>col</key><integer>12</integer>
1078// CHECK-NEXT: <key>file</key><integer>0</integer>
1079// CHECK-NEXT: </dict>
1080// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001081// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001082// CHECK-NEXT: <key>col</key><integer>12</integer>
1083// CHECK-NEXT: <key>file</key><integer>0</integer>
1084// CHECK-NEXT: </dict>
1085// CHECK-NEXT: </array>
1086// CHECK-NEXT: <key>end</key>
1087// CHECK-NEXT: <array>
1088// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001089// CHECK-NEXT: <key>line</key><integer>67</integer>
1090// CHECK-NEXT: <key>col</key><integer>5</integer>
1091// CHECK-NEXT: <key>file</key><integer>0</integer>
1092// CHECK-NEXT: </dict>
1093// CHECK-NEXT: <dict>
1094// CHECK-NEXT: <key>line</key><integer>67</integer>
1095// CHECK-NEXT: <key>col</key><integer>7</integer>
1096// CHECK-NEXT: <key>file</key><integer>0</integer>
1097// CHECK-NEXT: </dict>
1098// CHECK-NEXT: </array>
1099// CHECK-NEXT: </dict>
1100// CHECK-NEXT: </array>
1101// CHECK-NEXT: </dict>
1102// CHECK-NEXT: <dict>
1103// CHECK-NEXT: <key>kind</key><string>event</string>
1104// CHECK-NEXT: <key>location</key>
1105// CHECK-NEXT: <dict>
1106// CHECK-NEXT: <key>line</key><integer>67</integer>
1107// CHECK-NEXT: <key>col</key><integer>5</integer>
1108// CHECK-NEXT: <key>file</key><integer>0</integer>
1109// CHECK-NEXT: </dict>
1110// CHECK-NEXT: <key>ranges</key>
1111// CHECK-NEXT: <array>
1112// CHECK-NEXT: <array>
1113// CHECK-NEXT: <dict>
1114// CHECK-NEXT: <key>line</key><integer>67</integer>
1115// CHECK-NEXT: <key>col</key><integer>5</integer>
1116// CHECK-NEXT: <key>file</key><integer>0</integer>
1117// CHECK-NEXT: </dict>
1118// CHECK-NEXT: <dict>
1119// CHECK-NEXT: <key>line</key><integer>67</integer>
1120// CHECK-NEXT: <key>col</key><integer>10</integer>
1121// CHECK-NEXT: <key>file</key><integer>0</integer>
1122// CHECK-NEXT: </dict>
1123// CHECK-NEXT: </array>
1124// CHECK-NEXT: </array>
1125// CHECK-NEXT: <key>depth</key><integer>1</integer>
1126// CHECK-NEXT: <key>extended_message</key>
1127// CHECK-NEXT: <string>Variable &apos;q&apos; initialized to a null pointer value</string>
1128// CHECK-NEXT: <key>message</key>
1129// CHECK-NEXT: <string>Variable &apos;q&apos; initialized to a null pointer value</string>
1130// CHECK-NEXT: </dict>
1131// CHECK-NEXT: <dict>
1132// CHECK-NEXT: <key>kind</key><string>control</string>
1133// CHECK-NEXT: <key>edges</key>
1134// CHECK-NEXT: <array>
1135// CHECK-NEXT: <dict>
1136// CHECK-NEXT: <key>start</key>
1137// CHECK-NEXT: <array>
1138// CHECK-NEXT: <dict>
1139// CHECK-NEXT: <key>line</key><integer>67</integer>
1140// CHECK-NEXT: <key>col</key><integer>5</integer>
1141// CHECK-NEXT: <key>file</key><integer>0</integer>
1142// CHECK-NEXT: </dict>
1143// CHECK-NEXT: <dict>
1144// CHECK-NEXT: <key>line</key><integer>67</integer>
1145// CHECK-NEXT: <key>col</key><integer>7</integer>
1146// CHECK-NEXT: <key>file</key><integer>0</integer>
1147// CHECK-NEXT: </dict>
1148// CHECK-NEXT: </array>
1149// CHECK-NEXT: <key>end</key>
1150// CHECK-NEXT: <array>
1151// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +00001152// CHECK-NEXT: <key>line</key><integer>68</integer>
1153// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001154// CHECK-NEXT: <key>file</key><integer>0</integer>
1155// CHECK-NEXT: </dict>
1156// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +00001157// CHECK-NEXT: <key>line</key><integer>68</integer>
Ted Kremeneka5958862012-10-25 22:07:10 +00001158// CHECK-NEXT: <key>col</key><integer>10</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001159// CHECK-NEXT: <key>file</key><integer>0</integer>
1160// CHECK-NEXT: </dict>
1161// CHECK-NEXT: </array>
1162// CHECK-NEXT: </dict>
1163// CHECK-NEXT: </array>
1164// CHECK-NEXT: </dict>
1165// CHECK-NEXT: <dict>
1166// CHECK-NEXT: <key>kind</key><string>event</string>
1167// CHECK-NEXT: <key>location</key>
1168// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +00001169// CHECK-NEXT: <key>line</key><integer>68</integer>
1170// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001171// CHECK-NEXT: <key>file</key><integer>0</integer>
1172// CHECK-NEXT: </dict>
1173// CHECK-NEXT: <key>ranges</key>
1174// CHECK-NEXT: <array>
1175// CHECK-NEXT: <array>
1176// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +00001177// CHECK-NEXT: <key>line</key><integer>68</integer>
1178// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001179// CHECK-NEXT: <key>file</key><integer>0</integer>
1180// CHECK-NEXT: </dict>
1181// CHECK-NEXT: <dict>
Jordan Rose106b037a2012-09-22 01:24:46 +00001182// CHECK-NEXT: <key>line</key><integer>68</integer>
1183// CHECK-NEXT: <key>col</key><integer>12</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001184// CHECK-NEXT: <key>file</key><integer>0</integer>
1185// CHECK-NEXT: </dict>
1186// CHECK-NEXT: </array>
1187// CHECK-NEXT: </array>
1188// CHECK-NEXT: <key>depth</key><integer>1</integer>
1189// CHECK-NEXT: <key>extended_message</key>
1190// CHECK-NEXT: <string>Returning null pointer (loaded from &apos;q&apos;)</string>
1191// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001192// CHECK-NEXT: <string>Returning null pointer (loaded from &apos;q&apos;)</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001193// CHECK-NEXT: </dict>
1194// CHECK-NEXT: <dict>
1195// CHECK-NEXT: <key>kind</key><string>event</string>
1196// CHECK-NEXT: <key>location</key>
1197// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001198// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001199// CHECK-NEXT: <key>col</key><integer>12</integer>
1200// CHECK-NEXT: <key>file</key><integer>0</integer>
1201// CHECK-NEXT: </dict>
1202// CHECK-NEXT: <key>ranges</key>
1203// CHECK-NEXT: <array>
1204// CHECK-NEXT: <array>
1205// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001206// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001207// CHECK-NEXT: <key>col</key><integer>12</integer>
1208// CHECK-NEXT: <key>file</key><integer>0</integer>
1209// CHECK-NEXT: </dict>
1210// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001211// CHECK-NEXT: <key>line</key><integer>69</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001212// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001213// CHECK-NEXT: <key>file</key><integer>0</integer>
1214// CHECK-NEXT: </dict>
1215// CHECK-NEXT: </array>
1216// CHECK-NEXT: </array>
1217// CHECK-NEXT: <key>depth</key><integer>1</integer>
1218// CHECK-NEXT: <key>extended_message</key>
1219// CHECK-NEXT: <string>Returning to caller</string>
1220// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001221// CHECK-NEXT: <string>Returning to caller</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001222// CHECK-NEXT: </dict>
1223// CHECK-NEXT: <dict>
1224// CHECK-NEXT: <key>kind</key><string>control</string>
1225// CHECK-NEXT: <key>edges</key>
1226// CHECK-NEXT: <array>
1227// CHECK-NEXT: <dict>
1228// CHECK-NEXT: <key>start</key>
1229// CHECK-NEXT: <array>
1230// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001231// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001232// CHECK-NEXT: <key>col</key><integer>3</integer>
1233// CHECK-NEXT: <key>file</key><integer>0</integer>
1234// CHECK-NEXT: </dict>
1235// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001236// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001237// CHECK-NEXT: <key>col</key><integer>5</integer>
1238// CHECK-NEXT: <key>file</key><integer>0</integer>
1239// CHECK-NEXT: </dict>
1240// CHECK-NEXT: </array>
1241// CHECK-NEXT: <key>end</key>
1242// CHECK-NEXT: <array>
1243// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001244// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001245// CHECK-NEXT: <key>col</key><integer>12</integer>
1246// CHECK-NEXT: <key>file</key><integer>0</integer>
1247// CHECK-NEXT: </dict>
1248// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001249// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001250// CHECK-NEXT: <key>col</key><integer>12</integer>
1251// CHECK-NEXT: <key>file</key><integer>0</integer>
1252// CHECK-NEXT: </dict>
1253// CHECK-NEXT: </array>
1254// CHECK-NEXT: </dict>
1255// CHECK-NEXT: </array>
1256// CHECK-NEXT: </dict>
1257// CHECK-NEXT: <dict>
1258// CHECK-NEXT: <key>kind</key><string>control</string>
1259// CHECK-NEXT: <key>edges</key>
1260// CHECK-NEXT: <array>
1261// CHECK-NEXT: <dict>
1262// CHECK-NEXT: <key>start</key>
1263// CHECK-NEXT: <array>
1264// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001265// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001266// CHECK-NEXT: <key>col</key><integer>12</integer>
1267// CHECK-NEXT: <key>file</key><integer>0</integer>
1268// CHECK-NEXT: </dict>
1269// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001270// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001271// CHECK-NEXT: <key>col</key><integer>12</integer>
1272// CHECK-NEXT: <key>file</key><integer>0</integer>
1273// CHECK-NEXT: </dict>
1274// CHECK-NEXT: </array>
1275// CHECK-NEXT: <key>end</key>
1276// CHECK-NEXT: <array>
1277// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001278// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001279// CHECK-NEXT: <key>col</key><integer>3</integer>
1280// CHECK-NEXT: <key>file</key><integer>0</integer>
1281// CHECK-NEXT: </dict>
1282// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001283// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001284// CHECK-NEXT: <key>col</key><integer>5</integer>
1285// CHECK-NEXT: <key>file</key><integer>0</integer>
1286// CHECK-NEXT: </dict>
1287// CHECK-NEXT: </array>
1288// CHECK-NEXT: </dict>
1289// CHECK-NEXT: </array>
1290// CHECK-NEXT: </dict>
1291// CHECK-NEXT: <dict>
1292// CHECK-NEXT: <key>kind</key><string>event</string>
1293// CHECK-NEXT: <key>location</key>
1294// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001295// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001296// CHECK-NEXT: <key>col</key><integer>3</integer>
1297// CHECK-NEXT: <key>file</key><integer>0</integer>
1298// CHECK-NEXT: </dict>
1299// CHECK-NEXT: <key>ranges</key>
1300// CHECK-NEXT: <array>
1301// CHECK-NEXT: <array>
1302// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001303// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001304// CHECK-NEXT: <key>col</key><integer>3</integer>
1305// CHECK-NEXT: <key>file</key><integer>0</integer>
1306// CHECK-NEXT: </dict>
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>8</integer>
1310// CHECK-NEXT: <key>file</key><integer>0</integer>
1311// CHECK-NEXT: </dict>
1312// CHECK-NEXT: </array>
1313// CHECK-NEXT: </array>
1314// CHECK-NEXT: <key>depth</key><integer>0</integer>
1315// CHECK-NEXT: <key>extended_message</key>
1316// CHECK-NEXT: <string>Variable &apos;p&apos; initialized to a null pointer value</string>
1317// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001318// CHECK-NEXT: <string>Variable &apos;p&apos; initialized to a null pointer value</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001319// CHECK-NEXT: </dict>
1320// CHECK-NEXT: <dict>
1321// CHECK-NEXT: <key>kind</key><string>control</string>
1322// CHECK-NEXT: <key>edges</key>
1323// CHECK-NEXT: <array>
1324// CHECK-NEXT: <dict>
1325// CHECK-NEXT: <key>start</key>
1326// CHECK-NEXT: <array>
1327// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001328// CHECK-NEXT: <key>line</key><integer>66</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001329// CHECK-NEXT: <key>col</key><integer>3</integer>
1330// CHECK-NEXT: <key>file</key><integer>0</integer>
1331// CHECK-NEXT: </dict>
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>5</integer>
1335// CHECK-NEXT: <key>file</key><integer>0</integer>
1336// CHECK-NEXT: </dict>
1337// CHECK-NEXT: </array>
1338// CHECK-NEXT: <key>end</key>
1339// CHECK-NEXT: <array>
1340// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001341// CHECK-NEXT: <key>line</key><integer>70</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001342// CHECK-NEXT: <key>col</key><integer>3</integer>
1343// CHECK-NEXT: <key>file</key><integer>0</integer>
1344// CHECK-NEXT: </dict>
1345// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001346// CHECK-NEXT: <key>line</key><integer>70</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: </array>
1351// CHECK-NEXT: </dict>
1352// CHECK-NEXT: </array>
1353// CHECK-NEXT: </dict>
1354// CHECK-NEXT: <dict>
1355// CHECK-NEXT: <key>kind</key><string>event</string>
1356// CHECK-NEXT: <key>location</key>
1357// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001358// CHECK-NEXT: <key>line</key><integer>70</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001359// CHECK-NEXT: <key>col</key><integer>3</integer>
1360// CHECK-NEXT: <key>file</key><integer>0</integer>
1361// CHECK-NEXT: </dict>
1362// CHECK-NEXT: <key>ranges</key>
1363// CHECK-NEXT: <array>
1364// CHECK-NEXT: <array>
1365// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001366// CHECK-NEXT: <key>line</key><integer>70</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001367// CHECK-NEXT: <key>col</key><integer>4</integer>
1368// CHECK-NEXT: <key>file</key><integer>0</integer>
1369// CHECK-NEXT: </dict>
1370// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001371// CHECK-NEXT: <key>line</key><integer>70</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001372// CHECK-NEXT: <key>col</key><integer>4</integer>
1373// CHECK-NEXT: <key>file</key><integer>0</integer>
1374// CHECK-NEXT: </dict>
1375// CHECK-NEXT: </array>
1376// CHECK-NEXT: </array>
1377// CHECK-NEXT: <key>depth</key><integer>0</integer>
1378// CHECK-NEXT: <key>extended_message</key>
1379// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1380// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001381// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001382// CHECK-NEXT: </dict>
1383// CHECK-NEXT: </array>
1384// CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1385// CHECK-NEXT: <key>category</key><string>Logic error</string>
1386// CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string>
1387// CHECK-NEXT: <key>issue_context_kind</key><string>function</string>
1388// CHECK-NEXT: <key>issue_context</key><string>test_block_ret</string>
Jordan Rose106b037a2012-09-22 01:24:46 +00001389// CHECK-NEXT: <key>issue_hash</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001390// CHECK-NEXT: <key>location</key>
1391// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001392// CHECK-NEXT: <key>line</key><integer>70</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001393// CHECK-NEXT: <key>col</key><integer>3</integer>
1394// CHECK-NEXT: <key>file</key><integer>0</integer>
1395// CHECK-NEXT: </dict>
1396// CHECK-NEXT: </dict>
1397// CHECK-NEXT: <dict>
1398// CHECK-NEXT: <key>path</key>
1399// CHECK-NEXT: <array>
1400// CHECK-NEXT: <dict>
1401// CHECK-NEXT: <key>kind</key><string>control</string>
1402// CHECK-NEXT: <key>edges</key>
1403// CHECK-NEXT: <array>
1404// CHECK-NEXT: <dict>
1405// CHECK-NEXT: <key>start</key>
1406// CHECK-NEXT: <array>
1407// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001408// CHECK-NEXT: <key>line</key><integer>74</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001409// CHECK-NEXT: <key>col</key><integer>3</integer>
1410// CHECK-NEXT: <key>file</key><integer>0</integer>
1411// CHECK-NEXT: </dict>
1412// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001413// CHECK-NEXT: <key>line</key><integer>74</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001414// CHECK-NEXT: <key>col</key><integer>9</integer>
1415// CHECK-NEXT: <key>file</key><integer>0</integer>
1416// CHECK-NEXT: </dict>
1417// CHECK-NEXT: </array>
1418// CHECK-NEXT: <key>end</key>
1419// CHECK-NEXT: <array>
1420// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001421// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001422// CHECK-NEXT: <key>col</key><integer>3</integer>
1423// CHECK-NEXT: <key>file</key><integer>0</integer>
1424// CHECK-NEXT: </dict>
1425// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001426// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001427// CHECK-NEXT: <key>col</key><integer>3</integer>
1428// CHECK-NEXT: <key>file</key><integer>0</integer>
1429// CHECK-NEXT: </dict>
1430// CHECK-NEXT: </array>
1431// CHECK-NEXT: </dict>
1432// CHECK-NEXT: </array>
1433// CHECK-NEXT: </dict>
1434// CHECK-NEXT: <dict>
1435// CHECK-NEXT: <key>kind</key><string>event</string>
1436// CHECK-NEXT: <key>location</key>
1437// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001438// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001439// CHECK-NEXT: <key>col</key><integer>3</integer>
1440// CHECK-NEXT: <key>file</key><integer>0</integer>
1441// CHECK-NEXT: </dict>
1442// CHECK-NEXT: <key>ranges</key>
1443// CHECK-NEXT: <array>
1444// CHECK-NEXT: <array>
1445// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001446// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001447// CHECK-NEXT: <key>col</key><integer>3</integer>
1448// CHECK-NEXT: <key>file</key><integer>0</integer>
1449// CHECK-NEXT: </dict>
1450// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001451// CHECK-NEXT: <key>line</key><integer>77</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001452// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001453// CHECK-NEXT: <key>file</key><integer>0</integer>
1454// CHECK-NEXT: </dict>
1455// CHECK-NEXT: </array>
1456// CHECK-NEXT: </array>
1457// CHECK-NEXT: <key>depth</key><integer>0</integer>
1458// CHECK-NEXT: <key>extended_message</key>
1459// CHECK-NEXT: <string>Calling anonymous block</string>
1460// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001461// CHECK-NEXT: <string>Calling anonymous block</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001462// CHECK-NEXT: </dict>
1463// CHECK-NEXT: <dict>
1464// CHECK-NEXT: <key>kind</key><string>event</string>
1465// CHECK-NEXT: <key>location</key>
1466// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001467// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001468// CHECK-NEXT: <key>col</key><integer>3</integer>
1469// CHECK-NEXT: <key>file</key><integer>0</integer>
1470// CHECK-NEXT: </dict>
1471// CHECK-NEXT: <key>depth</key><integer>1</integer>
1472// CHECK-NEXT: <key>extended_message</key>
1473// CHECK-NEXT: <string>Entered call from &apos;test_block_blockvar&apos;</string>
1474// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001475// CHECK-NEXT: <string>Entered call from &apos;test_block_blockvar&apos;</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001476// CHECK-NEXT: </dict>
1477// CHECK-NEXT: <dict>
1478// CHECK-NEXT: <key>kind</key><string>control</string>
1479// CHECK-NEXT: <key>edges</key>
1480// CHECK-NEXT: <array>
1481// CHECK-NEXT: <dict>
1482// CHECK-NEXT: <key>start</key>
1483// CHECK-NEXT: <array>
1484// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001485// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001486// CHECK-NEXT: <key>col</key><integer>3</integer>
1487// CHECK-NEXT: <key>file</key><integer>0</integer>
1488// CHECK-NEXT: </dict>
1489// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001490// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001491// CHECK-NEXT: <key>col</key><integer>3</integer>
1492// CHECK-NEXT: <key>file</key><integer>0</integer>
1493// CHECK-NEXT: </dict>
1494// CHECK-NEXT: </array>
1495// CHECK-NEXT: <key>end</key>
1496// CHECK-NEXT: <array>
1497// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001498// CHECK-NEXT: <key>line</key><integer>76</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001499// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001500// CHECK-NEXT: <key>file</key><integer>0</integer>
1501// CHECK-NEXT: </dict>
1502// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001503// CHECK-NEXT: <key>line</key><integer>76</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001504// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001505// CHECK-NEXT: <key>file</key><integer>0</integer>
1506// CHECK-NEXT: </dict>
1507// CHECK-NEXT: </array>
1508// CHECK-NEXT: </dict>
1509// CHECK-NEXT: </array>
1510// CHECK-NEXT: </dict>
1511// CHECK-NEXT: <dict>
1512// CHECK-NEXT: <key>kind</key><string>event</string>
1513// CHECK-NEXT: <key>location</key>
1514// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001515// CHECK-NEXT: <key>line</key><integer>76</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001516// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001517// CHECK-NEXT: <key>file</key><integer>0</integer>
1518// CHECK-NEXT: </dict>
1519// CHECK-NEXT: <key>ranges</key>
1520// CHECK-NEXT: <array>
1521// CHECK-NEXT: <array>
1522// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001523// CHECK-NEXT: <key>line</key><integer>76</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001524// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001525// CHECK-NEXT: <key>file</key><integer>0</integer>
1526// CHECK-NEXT: </dict>
1527// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001528// CHECK-NEXT: <key>line</key><integer>76</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001529// CHECK-NEXT: <key>col</key><integer>9</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001530// CHECK-NEXT: <key>file</key><integer>0</integer>
1531// CHECK-NEXT: </dict>
1532// CHECK-NEXT: </array>
1533// CHECK-NEXT: </array>
1534// CHECK-NEXT: <key>depth</key><integer>1</integer>
1535// CHECK-NEXT: <key>extended_message</key>
1536// CHECK-NEXT: <string>Null pointer value stored to &apos;p&apos;</string>
1537// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001538// CHECK-NEXT: <string>Null pointer value stored to &apos;p&apos;</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001539// CHECK-NEXT: </dict>
1540// CHECK-NEXT: <dict>
1541// CHECK-NEXT: <key>kind</key><string>event</string>
1542// CHECK-NEXT: <key>location</key>
1543// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001544// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001545// CHECK-NEXT: <key>col</key><integer>3</integer>
1546// CHECK-NEXT: <key>file</key><integer>0</integer>
1547// CHECK-NEXT: </dict>
1548// CHECK-NEXT: <key>ranges</key>
1549// CHECK-NEXT: <array>
1550// CHECK-NEXT: <array>
1551// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001552// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001553// CHECK-NEXT: <key>col</key><integer>3</integer>
1554// CHECK-NEXT: <key>file</key><integer>0</integer>
1555// CHECK-NEXT: </dict>
1556// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001557// CHECK-NEXT: <key>line</key><integer>77</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001558// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001559// CHECK-NEXT: <key>file</key><integer>0</integer>
1560// CHECK-NEXT: </dict>
1561// CHECK-NEXT: </array>
1562// CHECK-NEXT: </array>
1563// CHECK-NEXT: <key>depth</key><integer>1</integer>
1564// CHECK-NEXT: <key>extended_message</key>
1565// CHECK-NEXT: <string>Returning to caller</string>
1566// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001567// CHECK-NEXT: <string>Returning to caller</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001568// CHECK-NEXT: </dict>
1569// CHECK-NEXT: <dict>
1570// CHECK-NEXT: <key>kind</key><string>control</string>
1571// CHECK-NEXT: <key>edges</key>
1572// CHECK-NEXT: <array>
1573// CHECK-NEXT: <dict>
1574// CHECK-NEXT: <key>start</key>
1575// CHECK-NEXT: <array>
1576// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001577// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001578// CHECK-NEXT: <key>col</key><integer>3</integer>
1579// CHECK-NEXT: <key>file</key><integer>0</integer>
1580// CHECK-NEXT: </dict>
1581// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001582// CHECK-NEXT: <key>line</key><integer>75</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001583// CHECK-NEXT: <key>col</key><integer>3</integer>
1584// CHECK-NEXT: <key>file</key><integer>0</integer>
1585// CHECK-NEXT: </dict>
1586// CHECK-NEXT: </array>
1587// CHECK-NEXT: <key>end</key>
1588// CHECK-NEXT: <array>
1589// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001590// CHECK-NEXT: <key>line</key><integer>78</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001591// CHECK-NEXT: <key>col</key><integer>3</integer>
1592// CHECK-NEXT: <key>file</key><integer>0</integer>
1593// CHECK-NEXT: </dict>
1594// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001595// CHECK-NEXT: <key>line</key><integer>78</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001596// CHECK-NEXT: <key>col</key><integer>3</integer>
1597// CHECK-NEXT: <key>file</key><integer>0</integer>
1598// CHECK-NEXT: </dict>
1599// CHECK-NEXT: </array>
1600// CHECK-NEXT: </dict>
1601// CHECK-NEXT: </array>
1602// CHECK-NEXT: </dict>
1603// CHECK-NEXT: <dict>
1604// CHECK-NEXT: <key>kind</key><string>event</string>
1605// CHECK-NEXT: <key>location</key>
1606// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001607// CHECK-NEXT: <key>line</key><integer>78</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001608// CHECK-NEXT: <key>col</key><integer>3</integer>
1609// CHECK-NEXT: <key>file</key><integer>0</integer>
1610// CHECK-NEXT: </dict>
1611// CHECK-NEXT: <key>ranges</key>
1612// CHECK-NEXT: <array>
1613// CHECK-NEXT: <array>
1614// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001615// CHECK-NEXT: <key>line</key><integer>78</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001616// CHECK-NEXT: <key>col</key><integer>4</integer>
1617// CHECK-NEXT: <key>file</key><integer>0</integer>
1618// CHECK-NEXT: </dict>
1619// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001620// CHECK-NEXT: <key>line</key><integer>78</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001621// CHECK-NEXT: <key>col</key><integer>4</integer>
1622// CHECK-NEXT: <key>file</key><integer>0</integer>
1623// CHECK-NEXT: </dict>
1624// CHECK-NEXT: </array>
1625// CHECK-NEXT: </array>
1626// CHECK-NEXT: <key>depth</key><integer>0</integer>
1627// CHECK-NEXT: <key>extended_message</key>
1628// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1629// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001630// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001631// CHECK-NEXT: </dict>
1632// CHECK-NEXT: </array>
1633// CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1634// CHECK-NEXT: <key>category</key><string>Logic error</string>
1635// CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string>
1636// CHECK-NEXT: <key>issue_context_kind</key><string>function</string>
1637// CHECK-NEXT: <key>issue_context</key><string>test_block_blockvar</string>
Jordan Rose106b037a2012-09-22 01:24:46 +00001638// CHECK-NEXT: <key>issue_hash</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001639// CHECK-NEXT: <key>location</key>
1640// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001641// CHECK-NEXT: <key>line</key><integer>78</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001642// CHECK-NEXT: <key>col</key><integer>3</integer>
1643// CHECK-NEXT: <key>file</key><integer>0</integer>
1644// CHECK-NEXT: </dict>
1645// CHECK-NEXT: </dict>
1646// CHECK-NEXT: <dict>
1647// CHECK-NEXT: <key>path</key>
1648// CHECK-NEXT: <array>
1649// CHECK-NEXT: <dict>
1650// CHECK-NEXT: <key>kind</key><string>control</string>
1651// CHECK-NEXT: <key>edges</key>
1652// CHECK-NEXT: <array>
1653// CHECK-NEXT: <dict>
1654// CHECK-NEXT: <key>start</key>
1655// CHECK-NEXT: <array>
1656// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001657// CHECK-NEXT: <key>line</key><integer>82</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001658// CHECK-NEXT: <key>col</key><integer>3</integer>
1659// CHECK-NEXT: <key>file</key><integer>0</integer>
1660// CHECK-NEXT: </dict>
1661// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001662// CHECK-NEXT: <key>line</key><integer>82</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001663// CHECK-NEXT: <key>col</key><integer>5</integer>
1664// CHECK-NEXT: <key>file</key><integer>0</integer>
1665// CHECK-NEXT: </dict>
1666// CHECK-NEXT: </array>
1667// CHECK-NEXT: <key>end</key>
1668// CHECK-NEXT: <array>
1669// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001670// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001671// CHECK-NEXT: <key>col</key><integer>3</integer>
1672// CHECK-NEXT: <key>file</key><integer>0</integer>
1673// CHECK-NEXT: </dict>
1674// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001675// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001676// CHECK-NEXT: <key>col</key><integer>3</integer>
1677// CHECK-NEXT: <key>file</key><integer>0</integer>
1678// CHECK-NEXT: </dict>
1679// CHECK-NEXT: </array>
1680// CHECK-NEXT: </dict>
1681// CHECK-NEXT: </array>
1682// CHECK-NEXT: </dict>
1683// CHECK-NEXT: <dict>
1684// CHECK-NEXT: <key>kind</key><string>event</string>
1685// CHECK-NEXT: <key>location</key>
1686// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001687// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001688// CHECK-NEXT: <key>col</key><integer>3</integer>
1689// CHECK-NEXT: <key>file</key><integer>0</integer>
1690// CHECK-NEXT: </dict>
1691// CHECK-NEXT: <key>ranges</key>
1692// CHECK-NEXT: <array>
1693// CHECK-NEXT: <array>
1694// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001695// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001696// CHECK-NEXT: <key>col</key><integer>3</integer>
1697// CHECK-NEXT: <key>file</key><integer>0</integer>
1698// CHECK-NEXT: </dict>
1699// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001700// CHECK-NEXT: <key>line</key><integer>85</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001701// CHECK-NEXT: <key>col</key><integer>7</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001702// CHECK-NEXT: <key>file</key><integer>0</integer>
1703// CHECK-NEXT: </dict>
1704// CHECK-NEXT: </array>
1705// CHECK-NEXT: </array>
1706// CHECK-NEXT: <key>depth</key><integer>0</integer>
1707// CHECK-NEXT: <key>extended_message</key>
1708// CHECK-NEXT: <string>Calling anonymous block</string>
1709// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001710// CHECK-NEXT: <string>Calling anonymous block</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001711// CHECK-NEXT: </dict>
1712// CHECK-NEXT: <dict>
1713// CHECK-NEXT: <key>kind</key><string>event</string>
1714// CHECK-NEXT: <key>location</key>
1715// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001716// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001717// CHECK-NEXT: <key>col</key><integer>3</integer>
1718// CHECK-NEXT: <key>file</key><integer>0</integer>
1719// CHECK-NEXT: </dict>
1720// CHECK-NEXT: <key>depth</key><integer>1</integer>
1721// CHECK-NEXT: <key>extended_message</key>
1722// CHECK-NEXT: <string>Entered call from &apos;test_block_arg&apos;</string>
1723// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001724// CHECK-NEXT: <string>Entered call from &apos;test_block_arg&apos;</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001725// CHECK-NEXT: </dict>
1726// CHECK-NEXT: <dict>
1727// CHECK-NEXT: <key>kind</key><string>control</string>
1728// CHECK-NEXT: <key>edges</key>
1729// CHECK-NEXT: <array>
1730// CHECK-NEXT: <dict>
1731// CHECK-NEXT: <key>start</key>
1732// CHECK-NEXT: <array>
1733// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001734// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001735// CHECK-NEXT: <key>col</key><integer>3</integer>
1736// CHECK-NEXT: <key>file</key><integer>0</integer>
1737// CHECK-NEXT: </dict>
1738// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001739// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001740// CHECK-NEXT: <key>col</key><integer>3</integer>
1741// CHECK-NEXT: <key>file</key><integer>0</integer>
1742// CHECK-NEXT: </dict>
1743// CHECK-NEXT: </array>
1744// CHECK-NEXT: <key>end</key>
1745// CHECK-NEXT: <array>
1746// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001747// CHECK-NEXT: <key>line</key><integer>84</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001748// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001749// CHECK-NEXT: <key>file</key><integer>0</integer>
1750// CHECK-NEXT: </dict>
1751// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001752// CHECK-NEXT: <key>line</key><integer>84</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001753// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001754// CHECK-NEXT: <key>file</key><integer>0</integer>
1755// CHECK-NEXT: </dict>
1756// CHECK-NEXT: </array>
1757// CHECK-NEXT: </dict>
1758// CHECK-NEXT: </array>
1759// CHECK-NEXT: </dict>
1760// CHECK-NEXT: <dict>
1761// CHECK-NEXT: <key>kind</key><string>event</string>
1762// CHECK-NEXT: <key>location</key>
1763// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001764// CHECK-NEXT: <key>line</key><integer>84</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001765// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001766// CHECK-NEXT: <key>file</key><integer>0</integer>
1767// CHECK-NEXT: </dict>
1768// CHECK-NEXT: <key>ranges</key>
1769// CHECK-NEXT: <array>
1770// CHECK-NEXT: <array>
1771// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001772// CHECK-NEXT: <key>line</key><integer>84</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001773// CHECK-NEXT: <key>col</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001774// CHECK-NEXT: <key>file</key><integer>0</integer>
1775// CHECK-NEXT: </dict>
1776// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001777// CHECK-NEXT: <key>line</key><integer>84</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001778// CHECK-NEXT: <key>col</key><integer>10</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001779// CHECK-NEXT: <key>file</key><integer>0</integer>
1780// CHECK-NEXT: </dict>
1781// CHECK-NEXT: </array>
1782// CHECK-NEXT: </array>
1783// CHECK-NEXT: <key>depth</key><integer>1</integer>
1784// CHECK-NEXT: <key>extended_message</key>
1785// CHECK-NEXT: <string>Null pointer value stored to &apos;p&apos;</string>
1786// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001787// CHECK-NEXT: <string>Null pointer value stored to &apos;p&apos;</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001788// CHECK-NEXT: </dict>
1789// CHECK-NEXT: <dict>
1790// CHECK-NEXT: <key>kind</key><string>event</string>
1791// CHECK-NEXT: <key>location</key>
1792// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001793// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001794// CHECK-NEXT: <key>col</key><integer>3</integer>
1795// CHECK-NEXT: <key>file</key><integer>0</integer>
1796// CHECK-NEXT: </dict>
1797// CHECK-NEXT: <key>ranges</key>
1798// CHECK-NEXT: <array>
1799// CHECK-NEXT: <array>
1800// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001801// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001802// CHECK-NEXT: <key>col</key><integer>3</integer>
1803// CHECK-NEXT: <key>file</key><integer>0</integer>
1804// CHECK-NEXT: </dict>
1805// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001806// CHECK-NEXT: <key>line</key><integer>85</integer>
Jordan Rose106b037a2012-09-22 01:24:46 +00001807// CHECK-NEXT: <key>col</key><integer>7</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001808// CHECK-NEXT: <key>file</key><integer>0</integer>
1809// CHECK-NEXT: </dict>
1810// CHECK-NEXT: </array>
1811// CHECK-NEXT: </array>
1812// CHECK-NEXT: <key>depth</key><integer>1</integer>
1813// CHECK-NEXT: <key>extended_message</key>
1814// CHECK-NEXT: <string>Returning to caller</string>
1815// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001816// CHECK-NEXT: <string>Returning to caller</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001817// CHECK-NEXT: </dict>
1818// CHECK-NEXT: <dict>
1819// CHECK-NEXT: <key>kind</key><string>control</string>
1820// CHECK-NEXT: <key>edges</key>
1821// CHECK-NEXT: <array>
1822// CHECK-NEXT: <dict>
1823// CHECK-NEXT: <key>start</key>
1824// CHECK-NEXT: <array>
1825// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001826// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001827// CHECK-NEXT: <key>col</key><integer>3</integer>
1828// CHECK-NEXT: <key>file</key><integer>0</integer>
1829// CHECK-NEXT: </dict>
1830// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001831// CHECK-NEXT: <key>line</key><integer>83</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001832// CHECK-NEXT: <key>col</key><integer>3</integer>
1833// CHECK-NEXT: <key>file</key><integer>0</integer>
1834// CHECK-NEXT: </dict>
1835// CHECK-NEXT: </array>
1836// CHECK-NEXT: <key>end</key>
1837// CHECK-NEXT: <array>
1838// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001839// CHECK-NEXT: <key>line</key><integer>86</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001840// CHECK-NEXT: <key>col</key><integer>3</integer>
1841// CHECK-NEXT: <key>file</key><integer>0</integer>
1842// CHECK-NEXT: </dict>
1843// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001844// CHECK-NEXT: <key>line</key><integer>86</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001845// CHECK-NEXT: <key>col</key><integer>3</integer>
1846// CHECK-NEXT: <key>file</key><integer>0</integer>
1847// CHECK-NEXT: </dict>
1848// CHECK-NEXT: </array>
1849// CHECK-NEXT: </dict>
1850// CHECK-NEXT: </array>
1851// CHECK-NEXT: </dict>
1852// CHECK-NEXT: <dict>
1853// CHECK-NEXT: <key>kind</key><string>event</string>
1854// CHECK-NEXT: <key>location</key>
1855// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001856// CHECK-NEXT: <key>line</key><integer>86</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001857// CHECK-NEXT: <key>col</key><integer>3</integer>
1858// CHECK-NEXT: <key>file</key><integer>0</integer>
1859// CHECK-NEXT: </dict>
1860// CHECK-NEXT: <key>ranges</key>
1861// CHECK-NEXT: <array>
1862// CHECK-NEXT: <array>
1863// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001864// CHECK-NEXT: <key>line</key><integer>86</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001865// CHECK-NEXT: <key>col</key><integer>4</integer>
1866// CHECK-NEXT: <key>file</key><integer>0</integer>
1867// CHECK-NEXT: </dict>
1868// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001869// CHECK-NEXT: <key>line</key><integer>86</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001870// CHECK-NEXT: <key>col</key><integer>4</integer>
1871// CHECK-NEXT: <key>file</key><integer>0</integer>
1872// CHECK-NEXT: </dict>
1873// CHECK-NEXT: </array>
1874// CHECK-NEXT: </array>
1875// CHECK-NEXT: <key>depth</key><integer>0</integer>
1876// CHECK-NEXT: <key>extended_message</key>
1877// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1878// CHECK-NEXT: <key>message</key>
Jordan Rose106b037a2012-09-22 01:24:46 +00001879// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001880// CHECK-NEXT: </dict>
1881// CHECK-NEXT: </array>
1882// CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable &apos;p&apos;)</string>
1883// CHECK-NEXT: <key>category</key><string>Logic error</string>
1884// CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string>
1885// CHECK-NEXT: <key>issue_context_kind</key><string>function</string>
1886// CHECK-NEXT: <key>issue_context</key><string>test_block_arg</string>
Jordan Rose106b037a2012-09-22 01:24:46 +00001887// CHECK-NEXT: <key>issue_hash</key><integer>5</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001888// CHECK-NEXT: <key>location</key>
1889// CHECK-NEXT: <dict>
Ted Kremeneka5958862012-10-25 22:07:10 +00001890// CHECK-NEXT: <key>line</key><integer>86</integer>
Ted Kremenekb0d1c702012-09-08 04:26:37 +00001891// CHECK-NEXT: <key>col</key><integer>3</integer>
1892// CHECK-NEXT: <key>file</key><integer>0</integer>
1893// CHECK-NEXT: </dict>
1894// CHECK-NEXT: </dict>
1895// CHECK-NEXT: </array>