blob: f41c0c3a5b9b920ac6844886a65b090656f66c8b [file] [log] [blame]
Ted Kremenek76aadc32012-03-09 01:13:14 +00001// RUN: %clang_cc1 -analyze -analyzer-checker=unix.Malloc -analyzer-output=plist -o %t %s
2// RUN: FileCheck --input-file %t %s
Anna Zaks5a0917d2012-02-16 03:41:01 +00003
4typedef __typeof(sizeof(int)) size_t;
5void *malloc(size_t);
Anna Zaksfe571602012-02-16 22:26:07 +00006void free(void *);
7void *realloc(void *ptr, size_t size);
Anna Zaks5a0917d2012-02-16 03:41:01 +00008
9void diagnosticTest(int in) {
10 if (in > 5) {
11 int *p = malloc(12);
12 (*p)++;
13 }
14 in++; // expected-warning {{leak}}
15}
16
17void myArrayAllocation() {
18 int **A;
19 A = malloc(2*sizeof(int*));
20 A[0] = 0;// expected-warning {{leak}}
21}
22
Anna Zaksfe571602012-02-16 22:26:07 +000023void reallocDiagnostics() {
24 char * buf = malloc(100);
25 char * tmp;
26 tmp = (char*)realloc(buf, 0x1000000);
Ted Kremenek76aadc32012-03-09 01:13:14 +000027 // FIXME: we need a diagnostic for the null check.
28 // This requires propagating "interesting" for 'tmp'.
Anna Zaksfe571602012-02-16 22:26:07 +000029 if (!tmp) {
30 return;// expected-warning {{leak}}
31 }
32 buf = tmp;
33 free(buf);
34}
35
Ted Kremenek76aadc32012-03-09 01:13:14 +000036void *wrapper() {
37 void *x = malloc(100);
38 // This is intentionally done to test diagnostic emission.
39 if (x)
40 return x;
41 return 0;
42}
43
44void test_wrapper() {
45 void *buf = wrapper();
46 (void) buf;
47}
48
Anna Zaks368a0d52012-03-15 21:13:02 +000049// Test what happens when the same call frees and allocated memory.
50void my_free(void *x) {
51 free(x);
52}
53void my_malloc_and_free(void **x) {
54 *x = malloc(100);
55 if (*x)
56 my_free(*x);
57 return;
58}
59void *test_double_action_call() {
60 void *buf;
61 my_malloc_and_free(&buf);
62 return buf;
63}
64
Ted Kremenek11e35b62012-03-15 22:00:28 +000065// CHECK: <?xml version="1.0" encoding="UTF-8"?>
66// CHECK: <plist version="1.0">
67// CHECK: <dict>
68// CHECK: <key>files</key>
69// CHECK: <array>
70// CHECK: </array>
71// CHECK: <key>diagnostics</key>
72// CHECK: <array>
73// CHECK: <dict>
74// CHECK: <key>path</key>
75// CHECK: <array>
76// CHECK: <dict>
77// CHECK: <key>kind</key><string>control</string>
78// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +000079// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +000080// CHECK: <dict>
81// CHECK: <key>start</key>
82// CHECK: <array>
83// CHECK: <dict>
84// CHECK: <key>line</key><integer>10</integer>
85// CHECK: <key>col</key><integer>5</integer>
86// CHECK: <key>file</key><integer>0</integer>
87// CHECK: </dict>
88// CHECK: <dict>
89// CHECK: <key>line</key><integer>10</integer>
90// CHECK: <key>col</key><integer>5</integer>
91// CHECK: <key>file</key><integer>0</integer>
92// CHECK: </dict>
93// CHECK: </array>
94// CHECK: <key>end</key>
95// CHECK: <array>
96// CHECK: <dict>
97// CHECK: <key>line</key><integer>10</integer>
98// CHECK: <key>col</key><integer>9</integer>
99// CHECK: <key>file</key><integer>0</integer>
100// CHECK: </dict>
101// CHECK: <dict>
102// CHECK: <key>line</key><integer>10</integer>
103// CHECK: <key>col</key><integer>9</integer>
104// CHECK: <key>file</key><integer>0</integer>
105// CHECK: </dict>
106// CHECK: </array>
107// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000108// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000109// CHECK: </dict>
110// CHECK: <dict>
111// CHECK: <key>kind</key><string>control</string>
112// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000113// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000114// CHECK: <dict>
115// CHECK: <key>start</key>
116// CHECK: <array>
117// CHECK: <dict>
118// CHECK: <key>line</key><integer>10</integer>
119// CHECK: <key>col</key><integer>9</integer>
120// CHECK: <key>file</key><integer>0</integer>
121// CHECK: </dict>
122// CHECK: <dict>
123// CHECK: <key>line</key><integer>10</integer>
124// CHECK: <key>col</key><integer>9</integer>
125// CHECK: <key>file</key><integer>0</integer>
126// CHECK: </dict>
127// CHECK: </array>
128// CHECK: <key>end</key>
129// CHECK: <array>
130// CHECK: <dict>
131// CHECK: <key>line</key><integer>11</integer>
132// CHECK: <key>col</key><integer>9</integer>
133// CHECK: <key>file</key><integer>0</integer>
134// CHECK: </dict>
135// CHECK: <dict>
136// CHECK: <key>line</key><integer>11</integer>
137// CHECK: <key>col</key><integer>9</integer>
138// CHECK: <key>file</key><integer>0</integer>
139// CHECK: </dict>
140// CHECK: </array>
141// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000142// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000143// CHECK: </dict>
144// CHECK: <dict>
145// CHECK: <key>kind</key><string>control</string>
146// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000147// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000148// CHECK: <dict>
149// CHECK: <key>start</key>
150// CHECK: <array>
151// CHECK: <dict>
152// CHECK: <key>line</key><integer>11</integer>
153// CHECK: <key>col</key><integer>9</integer>
154// CHECK: <key>file</key><integer>0</integer>
155// CHECK: </dict>
156// CHECK: <dict>
157// CHECK: <key>line</key><integer>11</integer>
158// CHECK: <key>col</key><integer>9</integer>
159// CHECK: <key>file</key><integer>0</integer>
160// CHECK: </dict>
161// CHECK: </array>
162// CHECK: <key>end</key>
163// CHECK: <array>
164// CHECK: <dict>
165// CHECK: <key>line</key><integer>11</integer>
166// CHECK: <key>col</key><integer>18</integer>
167// CHECK: <key>file</key><integer>0</integer>
168// CHECK: </dict>
169// CHECK: <dict>
170// CHECK: <key>line</key><integer>11</integer>
171// CHECK: <key>col</key><integer>27</integer>
172// CHECK: <key>file</key><integer>0</integer>
173// CHECK: </dict>
174// CHECK: </array>
175// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000176// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000177// CHECK: </dict>
178// CHECK: <dict>
179// CHECK: <key>kind</key><string>event</string>
180// CHECK: <key>location</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000181// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000182// CHECK: <key>line</key><integer>11</integer>
183// CHECK: <key>col</key><integer>18</integer>
184// CHECK: <key>file</key><integer>0</integer>
185// CHECK: </dict>
186// CHECK: <key>ranges</key>
187// CHECK: <array>
Anna Zaksfe571602012-02-16 22:26:07 +0000188// CHECK: <array>
189// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000190// CHECK: <key>line</key><integer>11</integer>
191// CHECK: <key>col</key><integer>18</integer>
192// CHECK: <key>file</key><integer>0</integer>
Anna Zaksfe571602012-02-16 22:26:07 +0000193// CHECK: </dict>
Ted Kremenek76aadc32012-03-09 01:13:14 +0000194// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000195// CHECK: <key>line</key><integer>11</integer>
196// CHECK: <key>col</key><integer>27</integer>
197// CHECK: <key>file</key><integer>0</integer>
Ted Kremenek76aadc32012-03-09 01:13:14 +0000198// CHECK: </dict>
199// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000200// CHECK: </array>
201// CHECK: <key>depth</key><integer>0</integer>
202// CHECK: <key>extended_message</key>
203// CHECK: <string>Memory is allocated</string>
204// CHECK: <key>message</key>
205// CHECK: <string>Memory is allocated</string>
206// CHECK: </dict>
207// CHECK: <dict>
208// CHECK: <key>kind</key><string>control</string>
209// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000210// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000211// CHECK: <dict>
212// CHECK: <key>start</key>
213// CHECK: <array>
214// CHECK: <dict>
215// CHECK: <key>line</key><integer>11</integer>
216// CHECK: <key>col</key><integer>18</integer>
217// CHECK: <key>file</key><integer>0</integer>
218// CHECK: </dict>
219// CHECK: <dict>
220// CHECK: <key>line</key><integer>11</integer>
221// CHECK: <key>col</key><integer>27</integer>
222// CHECK: <key>file</key><integer>0</integer>
223// CHECK: </dict>
224// CHECK: </array>
225// CHECK: <key>end</key>
226// CHECK: <array>
227// CHECK: <dict>
228// CHECK: <key>line</key><integer>14</integer>
229// CHECK: <key>col</key><integer>5</integer>
230// CHECK: <key>file</key><integer>0</integer>
231// CHECK: </dict>
232// CHECK: <dict>
233// CHECK: <key>line</key><integer>14</integer>
234// CHECK: <key>col</key><integer>6</integer>
235// CHECK: <key>file</key><integer>0</integer>
236// CHECK: </dict>
237// CHECK: </array>
238// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000239// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000240// CHECK: </dict>
241// CHECK: <dict>
242// CHECK: <key>kind</key><string>event</string>
243// CHECK: <key>location</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000244// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000245// CHECK: <key>line</key><integer>14</integer>
246// CHECK: <key>col</key><integer>5</integer>
247// CHECK: <key>file</key><integer>0</integer>
248// CHECK: </dict>
249// CHECK: <key>ranges</key>
250// CHECK: <array>
Ted Kremenek76aadc32012-03-09 01:13:14 +0000251// CHECK: <array>
252// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000253// CHECK: <key>line</key><integer>14</integer>
254// CHECK: <key>col</key><integer>5</integer>
255// CHECK: <key>file</key><integer>0</integer>
Ted Kremenek76aadc32012-03-09 01:13:14 +0000256// CHECK: </dict>
Ted Kremenek76aadc32012-03-09 01:13:14 +0000257// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000258// CHECK: <key>line</key><integer>14</integer>
259// CHECK: <key>col</key><integer>6</integer>
260// CHECK: <key>file</key><integer>0</integer>
Ted Kremenek76aadc32012-03-09 01:13:14 +0000261// CHECK: </dict>
262// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000263// CHECK: </array>
264// CHECK: <key>depth</key><integer>0</integer>
265// CHECK: <key>extended_message</key>
266// CHECK: <string>Memory is never released; potential memory leak</string>
267// CHECK: <key>message</key>
268// CHECK: <string>Memory is never released; potential memory leak</string>
269// CHECK: </dict>
270// CHECK: </array>
271// CHECK: <key>description</key><string>Memory is never released; potential memory leak</string>
272// CHECK: <key>category</key><string>Memory Error</string>
273// CHECK: <key>type</key><string>Memory leak</string>
274// CHECK: <key>location</key>
275// CHECK: <dict>
276// CHECK: <key>line</key><integer>14</integer>
277// CHECK: <key>col</key><integer>5</integer>
278// CHECK: <key>file</key><integer>0</integer>
279// CHECK: </dict>
280// CHECK: </dict>
281// CHECK: <dict>
282// CHECK: <key>path</key>
283// CHECK: <array>
284// CHECK: <dict>
285// CHECK: <key>kind</key><string>control</string>
286// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000287// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000288// CHECK: <dict>
289// CHECK: <key>start</key>
290// CHECK: <array>
291// CHECK: <dict>
292// CHECK: <key>line</key><integer>18</integer>
293// CHECK: <key>col</key><integer>5</integer>
294// CHECK: <key>file</key><integer>0</integer>
295// CHECK: </dict>
296// CHECK: <dict>
297// CHECK: <key>line</key><integer>18</integer>
298// CHECK: <key>col</key><integer>5</integer>
299// CHECK: <key>file</key><integer>0</integer>
300// CHECK: </dict>
301// CHECK: </array>
302// CHECK: <key>end</key>
303// CHECK: <array>
304// CHECK: <dict>
305// CHECK: <key>line</key><integer>19</integer>
306// CHECK: <key>col</key><integer>5</integer>
307// CHECK: <key>file</key><integer>0</integer>
308// CHECK: </dict>
309// CHECK: <dict>
310// CHECK: <key>line</key><integer>19</integer>
311// CHECK: <key>col</key><integer>5</integer>
312// CHECK: <key>file</key><integer>0</integer>
313// CHECK: </dict>
314// CHECK: </array>
315// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000316// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000317// CHECK: </dict>
318// CHECK: <dict>
319// CHECK: <key>kind</key><string>control</string>
320// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000321// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000322// CHECK: <dict>
323// CHECK: <key>start</key>
324// CHECK: <array>
325// CHECK: <dict>
326// CHECK: <key>line</key><integer>19</integer>
327// CHECK: <key>col</key><integer>5</integer>
328// CHECK: <key>file</key><integer>0</integer>
329// CHECK: </dict>
330// CHECK: <dict>
331// CHECK: <key>line</key><integer>19</integer>
332// CHECK: <key>col</key><integer>5</integer>
333// CHECK: <key>file</key><integer>0</integer>
334// CHECK: </dict>
335// CHECK: </array>
336// CHECK: <key>end</key>
337// CHECK: <array>
338// CHECK: <dict>
339// CHECK: <key>line</key><integer>19</integer>
340// CHECK: <key>col</key><integer>9</integer>
341// CHECK: <key>file</key><integer>0</integer>
342// CHECK: </dict>
343// CHECK: <dict>
344// CHECK: <key>line</key><integer>19</integer>
345// CHECK: <key>col</key><integer>30</integer>
346// CHECK: <key>file</key><integer>0</integer>
347// CHECK: </dict>
348// CHECK: </array>
349// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000350// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000351// CHECK: </dict>
352// CHECK: <dict>
353// CHECK: <key>kind</key><string>event</string>
354// CHECK: <key>location</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000355// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000356// CHECK: <key>line</key><integer>19</integer>
357// CHECK: <key>col</key><integer>9</integer>
358// CHECK: <key>file</key><integer>0</integer>
359// CHECK: </dict>
360// CHECK: <key>ranges</key>
361// CHECK: <array>
Anna Zaks368a0d52012-03-15 21:13:02 +0000362// CHECK: <array>
363// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000364// CHECK: <key>line</key><integer>19</integer>
365// CHECK: <key>col</key><integer>9</integer>
366// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +0000367// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000368// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000369// CHECK: <key>line</key><integer>19</integer>
370// CHECK: <key>col</key><integer>30</integer>
371// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +0000372// CHECK: </dict>
373// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000374// CHECK: </array>
375// CHECK: <key>depth</key><integer>0</integer>
376// CHECK: <key>extended_message</key>
377// CHECK: <string>Memory is allocated</string>
378// CHECK: <key>message</key>
379// CHECK: <string>Memory is allocated</string>
380// CHECK: </dict>
381// CHECK: <dict>
382// CHECK: <key>kind</key><string>control</string>
383// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000384// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000385// CHECK: <dict>
386// CHECK: <key>start</key>
387// CHECK: <array>
388// CHECK: <dict>
389// CHECK: <key>line</key><integer>19</integer>
390// CHECK: <key>col</key><integer>9</integer>
391// CHECK: <key>file</key><integer>0</integer>
392// CHECK: </dict>
393// CHECK: <dict>
394// CHECK: <key>line</key><integer>19</integer>
395// CHECK: <key>col</key><integer>30</integer>
396// CHECK: <key>file</key><integer>0</integer>
397// CHECK: </dict>
398// CHECK: </array>
399// CHECK: <key>end</key>
400// CHECK: <array>
401// CHECK: <dict>
402// CHECK: <key>line</key><integer>21</integer>
403// CHECK: <key>col</key><integer>1</integer>
404// CHECK: <key>file</key><integer>0</integer>
405// CHECK: </dict>
406// CHECK: <dict>
407// CHECK: <key>line</key><integer>21</integer>
408// CHECK: <key>col</key><integer>1</integer>
409// CHECK: <key>file</key><integer>0</integer>
410// CHECK: </dict>
411// CHECK: </array>
412// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000413// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000414// CHECK: </dict>
415// CHECK: <dict>
416// CHECK: <key>kind</key><string>event</string>
417// CHECK: <key>location</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000418// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000419// CHECK: <key>line</key><integer>21</integer>
420// CHECK: <key>col</key><integer>1</integer>
421// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +0000422// CHECK: </dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000423// CHECK: <key>depth</key><integer>0</integer>
424// CHECK: <key>extended_message</key>
425// CHECK: <string>Memory is never released; potential memory leak</string>
426// CHECK: <key>message</key>
427// CHECK: <string>Memory is never released; potential memory leak</string>
428// CHECK: </dict>
429// CHECK: </array>
430// CHECK: <key>description</key><string>Memory is never released; potential memory leak</string>
431// CHECK: <key>category</key><string>Memory Error</string>
432// CHECK: <key>type</key><string>Memory leak</string>
433// CHECK: <key>location</key>
434// CHECK: <dict>
435// CHECK: <key>line</key><integer>21</integer>
436// CHECK: <key>col</key><integer>1</integer>
437// CHECK: <key>file</key><integer>0</integer>
438// CHECK: </dict>
439// CHECK: </dict>
440// CHECK: <dict>
441// CHECK: <key>path</key>
442// CHECK: <array>
443// CHECK: <dict>
444// CHECK: <key>kind</key><string>control</string>
445// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000446// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000447// CHECK: <dict>
448// CHECK: <key>start</key>
449// CHECK: <array>
450// CHECK: <dict>
451// CHECK: <key>line</key><integer>24</integer>
452// CHECK: <key>col</key><integer>5</integer>
453// CHECK: <key>file</key><integer>0</integer>
454// CHECK: </dict>
455// CHECK: <dict>
456// CHECK: <key>line</key><integer>24</integer>
457// CHECK: <key>col</key><integer>5</integer>
458// CHECK: <key>file</key><integer>0</integer>
459// CHECK: </dict>
460// CHECK: </array>
461// CHECK: <key>end</key>
462// CHECK: <array>
463// CHECK: <dict>
464// CHECK: <key>line</key><integer>24</integer>
465// CHECK: <key>col</key><integer>18</integer>
466// CHECK: <key>file</key><integer>0</integer>
467// CHECK: </dict>
468// CHECK: <dict>
469// CHECK: <key>line</key><integer>24</integer>
470// CHECK: <key>col</key><integer>28</integer>
471// CHECK: <key>file</key><integer>0</integer>
472// CHECK: </dict>
473// CHECK: </array>
474// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000475// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000476// CHECK: </dict>
477// CHECK: <dict>
478// CHECK: <key>kind</key><string>event</string>
479// CHECK: <key>location</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000480// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000481// CHECK: <key>line</key><integer>24</integer>
482// CHECK: <key>col</key><integer>18</integer>
483// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +0000484// CHECK: </dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000485// CHECK: <key>ranges</key>
486// CHECK: <array>
Anna Zaks368a0d52012-03-15 21:13:02 +0000487// CHECK: <array>
488// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000489// CHECK: <key>line</key><integer>24</integer>
490// CHECK: <key>col</key><integer>18</integer>
491// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +0000492// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000493// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000494// CHECK: <key>line</key><integer>24</integer>
495// CHECK: <key>col</key><integer>28</integer>
496// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +0000497// CHECK: </dict>
498// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000499// CHECK: </array>
500// CHECK: <key>depth</key><integer>0</integer>
501// CHECK: <key>extended_message</key>
502// CHECK: <string>Memory is allocated</string>
503// CHECK: <key>message</key>
504// CHECK: <string>Memory is allocated</string>
505// CHECK: </dict>
506// CHECK: <dict>
507// CHECK: <key>kind</key><string>control</string>
508// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000509// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000510// CHECK: <dict>
511// CHECK: <key>start</key>
512// CHECK: <array>
513// CHECK: <dict>
514// CHECK: <key>line</key><integer>24</integer>
515// CHECK: <key>col</key><integer>18</integer>
516// CHECK: <key>file</key><integer>0</integer>
517// CHECK: </dict>
518// CHECK: <dict>
519// CHECK: <key>line</key><integer>24</integer>
520// CHECK: <key>col</key><integer>28</integer>
521// CHECK: <key>file</key><integer>0</integer>
522// CHECK: </dict>
523// CHECK: </array>
524// CHECK: <key>end</key>
525// CHECK: <array>
526// CHECK: <dict>
527// CHECK: <key>line</key><integer>26</integer>
528// CHECK: <key>col</key><integer>5</integer>
529// CHECK: <key>file</key><integer>0</integer>
530// CHECK: </dict>
531// CHECK: <dict>
532// CHECK: <key>line</key><integer>26</integer>
533// CHECK: <key>col</key><integer>5</integer>
534// CHECK: <key>file</key><integer>0</integer>
535// CHECK: </dict>
536// CHECK: </array>
537// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000538// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000539// CHECK: </dict>
540// CHECK: <dict>
541// CHECK: <key>kind</key><string>control</string>
542// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000543// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000544// CHECK: <dict>
545// CHECK: <key>start</key>
546// CHECK: <array>
547// CHECK: <dict>
548// CHECK: <key>line</key><integer>26</integer>
549// CHECK: <key>col</key><integer>5</integer>
550// CHECK: <key>file</key><integer>0</integer>
551// CHECK: </dict>
552// CHECK: <dict>
553// CHECK: <key>line</key><integer>26</integer>
554// CHECK: <key>col</key><integer>5</integer>
555// CHECK: <key>file</key><integer>0</integer>
556// CHECK: </dict>
557// CHECK: </array>
558// CHECK: <key>end</key>
559// CHECK: <array>
560// CHECK: <dict>
561// CHECK: <key>line</key><integer>26</integer>
562// CHECK: <key>col</key><integer>18</integer>
563// CHECK: <key>file</key><integer>0</integer>
564// CHECK: </dict>
565// CHECK: <dict>
566// CHECK: <key>line</key><integer>26</integer>
567// CHECK: <key>col</key><integer>40</integer>
568// CHECK: <key>file</key><integer>0</integer>
569// CHECK: </dict>
570// CHECK: </array>
571// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000572// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000573// CHECK: </dict>
574// CHECK: <dict>
575// CHECK: <key>kind</key><string>event</string>
576// CHECK: <key>location</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000577// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000578// CHECK: <key>line</key><integer>26</integer>
579// CHECK: <key>col</key><integer>18</integer>
580// CHECK: <key>file</key><integer>0</integer>
581// CHECK: </dict>
582// CHECK: <key>ranges</key>
583// CHECK: <array>
Anna Zaks368a0d52012-03-15 21:13:02 +0000584// CHECK: <array>
585// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000586// CHECK: <key>line</key><integer>26</integer>
587// CHECK: <key>col</key><integer>18</integer>
588// CHECK: <key>file</key><integer>0</integer>
589// CHECK: </dict>
590// CHECK: <dict>
591// CHECK: <key>line</key><integer>26</integer>
592// CHECK: <key>col</key><integer>40</integer>
593// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +0000594// CHECK: </dict>
595// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000596// CHECK: </array>
597// CHECK: <key>depth</key><integer>0</integer>
598// CHECK: <key>extended_message</key>
599// CHECK: <string>Attempt to reallocate memory</string>
600// CHECK: <key>message</key>
601// CHECK: <string>Attempt to reallocate memory</string>
602// CHECK: </dict>
603// CHECK: <dict>
604// CHECK: <key>kind</key><string>control</string>
605// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000606// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000607// CHECK: <dict>
608// CHECK: <key>start</key>
609// CHECK: <array>
610// CHECK: <dict>
611// CHECK: <key>line</key><integer>26</integer>
612// CHECK: <key>col</key><integer>18</integer>
613// CHECK: <key>file</key><integer>0</integer>
614// CHECK: </dict>
615// CHECK: <dict>
616// CHECK: <key>line</key><integer>26</integer>
617// CHECK: <key>col</key><integer>40</integer>
618// CHECK: <key>file</key><integer>0</integer>
619// CHECK: </dict>
620// CHECK: </array>
621// CHECK: <key>end</key>
622// CHECK: <array>
623// CHECK: <dict>
624// CHECK: <key>line</key><integer>29</integer>
625// CHECK: <key>col</key><integer>5</integer>
626// CHECK: <key>file</key><integer>0</integer>
627// CHECK: </dict>
628// CHECK: <dict>
629// CHECK: <key>line</key><integer>29</integer>
630// CHECK: <key>col</key><integer>6</integer>
631// CHECK: <key>file</key><integer>0</integer>
632// CHECK: </dict>
633// CHECK: </array>
634// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000635// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000636// CHECK: </dict>
637// CHECK: <dict>
638// CHECK: <key>kind</key><string>event</string>
639// CHECK: <key>location</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000640// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000641// CHECK: <key>line</key><integer>29</integer>
642// CHECK: <key>col</key><integer>5</integer>
643// CHECK: <key>file</key><integer>0</integer>
644// CHECK: </dict>
645// CHECK: <key>ranges</key>
646// CHECK: <array>
Anna Zaks368a0d52012-03-15 21:13:02 +0000647// CHECK: <array>
648// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000649// CHECK: <key>line</key><integer>29</integer>
650// CHECK: <key>col</key><integer>5</integer>
651// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +0000652// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000653// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000654// CHECK: <key>line</key><integer>29</integer>
655// CHECK: <key>col</key><integer>6</integer>
656// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +0000657// CHECK: </dict>
658// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000659// CHECK: </array>
660// CHECK: <key>depth</key><integer>0</integer>
661// CHECK: <key>extended_message</key>
662// CHECK: <string>Reallocation failed</string>
663// CHECK: <key>message</key>
664// CHECK: <string>Reallocation failed</string>
665// CHECK: </dict>
666// CHECK: <dict>
667// CHECK: <key>kind</key><string>control</string>
668// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000669// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000670// CHECK: <dict>
671// CHECK: <key>start</key>
672// CHECK: <array>
673// CHECK: <dict>
674// CHECK: <key>line</key><integer>29</integer>
675// CHECK: <key>col</key><integer>5</integer>
676// CHECK: <key>file</key><integer>0</integer>
677// CHECK: </dict>
678// CHECK: <dict>
679// CHECK: <key>line</key><integer>29</integer>
680// CHECK: <key>col</key><integer>6</integer>
681// CHECK: <key>file</key><integer>0</integer>
682// CHECK: </dict>
683// CHECK: </array>
684// CHECK: <key>end</key>
685// CHECK: <array>
686// CHECK: <dict>
687// CHECK: <key>line</key><integer>29</integer>
688// CHECK: <key>col</key><integer>9</integer>
689// CHECK: <key>file</key><integer>0</integer>
690// CHECK: </dict>
691// CHECK: <dict>
692// CHECK: <key>line</key><integer>29</integer>
693// CHECK: <key>col</key><integer>12</integer>
694// CHECK: <key>file</key><integer>0</integer>
695// CHECK: </dict>
696// CHECK: </array>
697// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000698// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000699// CHECK: </dict>
700// CHECK: <dict>
701// CHECK: <key>kind</key><string>control</string>
702// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000703// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000704// CHECK: <dict>
705// CHECK: <key>start</key>
706// CHECK: <array>
707// CHECK: <dict>
708// CHECK: <key>line</key><integer>29</integer>
709// CHECK: <key>col</key><integer>9</integer>
710// CHECK: <key>file</key><integer>0</integer>
711// CHECK: </dict>
712// CHECK: <dict>
713// CHECK: <key>line</key><integer>29</integer>
714// CHECK: <key>col</key><integer>12</integer>
715// CHECK: <key>file</key><integer>0</integer>
716// CHECK: </dict>
717// CHECK: </array>
718// CHECK: <key>end</key>
719// CHECK: <array>
720// CHECK: <dict>
721// CHECK: <key>line</key><integer>30</integer>
722// CHECK: <key>col</key><integer>9</integer>
723// CHECK: <key>file</key><integer>0</integer>
724// CHECK: </dict>
725// CHECK: <dict>
726// CHECK: <key>line</key><integer>30</integer>
727// CHECK: <key>col</key><integer>14</integer>
728// CHECK: <key>file</key><integer>0</integer>
729// CHECK: </dict>
730// CHECK: </array>
731// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000732// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000733// CHECK: </dict>
734// CHECK: <dict>
735// CHECK: <key>kind</key><string>event</string>
736// CHECK: <key>location</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000737// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000738// CHECK: <key>line</key><integer>30</integer>
739// CHECK: <key>col</key><integer>9</integer>
740// CHECK: <key>file</key><integer>0</integer>
741// CHECK: </dict>
742// CHECK: <key>ranges</key>
743// CHECK: <array>
Anna Zaks368a0d52012-03-15 21:13:02 +0000744// CHECK: <array>
745// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000746// CHECK: <key>line</key><integer>30</integer>
747// CHECK: <key>col</key><integer>9</integer>
748// CHECK: <key>file</key><integer>0</integer>
749// CHECK: </dict>
750// CHECK: <dict>
751// CHECK: <key>line</key><integer>30</integer>
752// CHECK: <key>col</key><integer>14</integer>
753// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +0000754// CHECK: </dict>
755// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000756// CHECK: </array>
757// CHECK: <key>depth</key><integer>0</integer>
758// CHECK: <key>extended_message</key>
759// CHECK: <string>Memory is never released; potential memory leak</string>
760// CHECK: <key>message</key>
761// CHECK: <string>Memory is never released; potential memory leak</string>
762// CHECK: </dict>
763// CHECK: </array>
764// CHECK: <key>description</key><string>Memory is never released; potential memory leak</string>
765// CHECK: <key>category</key><string>Memory Error</string>
766// CHECK: <key>type</key><string>Memory leak</string>
767// CHECK: <key>location</key>
768// CHECK: <dict>
769// CHECK: <key>line</key><integer>30</integer>
770// CHECK: <key>col</key><integer>9</integer>
771// CHECK: <key>file</key><integer>0</integer>
772// CHECK: </dict>
773// CHECK: </dict>
774// CHECK: <dict>
775// CHECK: <key>path</key>
776// CHECK: <array>
777// CHECK: <dict>
778// CHECK: <key>kind</key><string>control</string>
779// CHECK: <key>edges</key>
780// CHECK: <array>
781// CHECK: <dict>
782// CHECK: <key>start</key>
783// CHECK: <array>
784// CHECK: <dict>
785// CHECK: <key>line</key><integer>45</integer>
786// CHECK: <key>col</key><integer>3</integer>
787// CHECK: <key>file</key><integer>0</integer>
788// CHECK: </dict>
789// CHECK: <dict>
790// CHECK: <key>line</key><integer>45</integer>
791// CHECK: <key>col</key><integer>3</integer>
792// CHECK: <key>file</key><integer>0</integer>
793// CHECK: </dict>
794// CHECK: </array>
795// CHECK: <key>end</key>
796// CHECK: <array>
797// CHECK: <dict>
798// CHECK: <key>line</key><integer>45</integer>
799// CHECK: <key>col</key><integer>15</integer>
800// CHECK: <key>file</key><integer>0</integer>
801// CHECK: </dict>
802// CHECK: <dict>
803// CHECK: <key>line</key><integer>45</integer>
804// CHECK: <key>col</key><integer>15</integer>
805// CHECK: <key>file</key><integer>0</integer>
806// CHECK: </dict>
807// CHECK: </array>
808// CHECK: </dict>
809// CHECK: </array>
810// CHECK: </dict>
811// CHECK: <dict>
812// CHECK: <key>kind</key><string>event</string>
813// CHECK: <key>location</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000814// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000815// CHECK: <key>line</key><integer>45</integer>
816// CHECK: <key>col</key><integer>15</integer>
817// CHECK: <key>file</key><integer>0</integer>
818// CHECK: </dict>
819// CHECK: <key>ranges</key>
820// CHECK: <array>
Anna Zaks368a0d52012-03-15 21:13:02 +0000821// CHECK: <array>
822// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000823// CHECK: <key>line</key><integer>45</integer>
824// CHECK: <key>col</key><integer>15</integer>
825// CHECK: <key>file</key><integer>0</integer>
826// CHECK: </dict>
827// CHECK: <dict>
828// CHECK: <key>line</key><integer>45</integer>
829// CHECK: <key>col</key><integer>23</integer>
830// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +0000831// CHECK: </dict>
832// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000833// CHECK: </array>
834// CHECK: <key>depth</key><integer>0</integer>
835// CHECK: <key>extended_message</key>
836// CHECK: <string>Calling &apos;wrapper&apos;</string>
837// CHECK: <key>message</key>
838// CHECK: <string>Calling &apos;wrapper&apos;</string>
839// CHECK: </dict>
840// CHECK: <dict>
841// CHECK: <key>kind</key><string>event</string>
842// CHECK: <key>location</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000843// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000844// CHECK: <key>line</key><integer>36</integer>
845// CHECK: <key>col</key><integer>1</integer>
846// CHECK: <key>file</key><integer>0</integer>
847// CHECK: </dict>
848// CHECK: <key>depth</key><integer>1</integer>
849// CHECK: <key>extended_message</key>
850// CHECK: <string>Entered call from &apos;test_wrapper&apos;</string>
851// CHECK: <key>message</key>
852// CHECK: <string>Entered call from &apos;test_wrapper&apos;</string>
853// CHECK: </dict>
854// CHECK: <dict>
855// CHECK: <key>kind</key><string>control</string>
856// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000857// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000858// CHECK: <dict>
859// CHECK: <key>start</key>
860// CHECK: <array>
861// CHECK: <dict>
862// CHECK: <key>line</key><integer>36</integer>
863// CHECK: <key>col</key><integer>1</integer>
864// CHECK: <key>file</key><integer>0</integer>
865// CHECK: </dict>
866// CHECK: <dict>
867// CHECK: <key>line</key><integer>36</integer>
868// CHECK: <key>col</key><integer>1</integer>
869// CHECK: <key>file</key><integer>0</integer>
870// CHECK: </dict>
871// CHECK: </array>
872// CHECK: <key>end</key>
873// CHECK: <array>
874// CHECK: <dict>
875// CHECK: <key>line</key><integer>37</integer>
876// CHECK: <key>col</key><integer>3</integer>
877// CHECK: <key>file</key><integer>0</integer>
878// CHECK: </dict>
879// CHECK: <dict>
880// CHECK: <key>line</key><integer>37</integer>
881// CHECK: <key>col</key><integer>3</integer>
882// CHECK: <key>file</key><integer>0</integer>
883// CHECK: </dict>
884// CHECK: </array>
885// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000886// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000887// CHECK: </dict>
888// CHECK: <dict>
889// CHECK: <key>kind</key><string>control</string>
890// CHECK: <key>edges</key>
891// CHECK: <array>
892// CHECK: <dict>
893// CHECK: <key>start</key>
894// CHECK: <array>
895// CHECK: <dict>
896// CHECK: <key>line</key><integer>37</integer>
897// CHECK: <key>col</key><integer>3</integer>
898// CHECK: <key>file</key><integer>0</integer>
899// CHECK: </dict>
900// CHECK: <dict>
901// CHECK: <key>line</key><integer>37</integer>
902// CHECK: <key>col</key><integer>3</integer>
903// CHECK: <key>file</key><integer>0</integer>
904// CHECK: </dict>
905// CHECK: </array>
906// CHECK: <key>end</key>
907// CHECK: <array>
908// CHECK: <dict>
909// CHECK: <key>line</key><integer>37</integer>
910// CHECK: <key>col</key><integer>13</integer>
911// CHECK: <key>file</key><integer>0</integer>
912// CHECK: </dict>
913// CHECK: <dict>
914// CHECK: <key>line</key><integer>37</integer>
915// CHECK: <key>col</key><integer>23</integer>
916// CHECK: <key>file</key><integer>0</integer>
917// CHECK: </dict>
918// CHECK: </array>
919// CHECK: </dict>
920// CHECK: </array>
921// CHECK: </dict>
922// CHECK: <dict>
923// CHECK: <key>kind</key><string>event</string>
924// CHECK: <key>location</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000925// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000926// CHECK: <key>line</key><integer>37</integer>
927// CHECK: <key>col</key><integer>13</integer>
928// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +0000929// CHECK: </dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000930// CHECK: <key>ranges</key>
931// CHECK: <array>
Anna Zaks368a0d52012-03-15 21:13:02 +0000932// CHECK: <array>
933// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000934// CHECK: <key>line</key><integer>37</integer>
935// CHECK: <key>col</key><integer>13</integer>
936// CHECK: <key>file</key><integer>0</integer>
937// CHECK: </dict>
938// CHECK: <dict>
939// CHECK: <key>line</key><integer>37</integer>
940// CHECK: <key>col</key><integer>23</integer>
941// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +0000942// CHECK: </dict>
943// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000944// CHECK: </array>
945// CHECK: <key>depth</key><integer>1</integer>
946// CHECK: <key>extended_message</key>
947// CHECK: <string>Memory is allocated</string>
948// CHECK: <key>message</key>
949// CHECK: <string>Memory is allocated</string>
950// CHECK: </dict>
951// CHECK: <dict>
952// CHECK: <key>kind</key><string>control</string>
953// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000954// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000955// CHECK: <dict>
956// CHECK: <key>start</key>
957// CHECK: <array>
958// CHECK: <dict>
959// CHECK: <key>line</key><integer>37</integer>
960// CHECK: <key>col</key><integer>13</integer>
961// CHECK: <key>file</key><integer>0</integer>
962// CHECK: </dict>
963// CHECK: <dict>
964// CHECK: <key>line</key><integer>37</integer>
965// CHECK: <key>col</key><integer>23</integer>
966// CHECK: <key>file</key><integer>0</integer>
967// CHECK: </dict>
968// CHECK: </array>
969// CHECK: <key>end</key>
970// CHECK: <array>
971// CHECK: <dict>
972// CHECK: <key>line</key><integer>39</integer>
973// CHECK: <key>col</key><integer>3</integer>
974// CHECK: <key>file</key><integer>0</integer>
975// CHECK: </dict>
976// CHECK: <dict>
977// CHECK: <key>line</key><integer>39</integer>
978// CHECK: <key>col</key><integer>3</integer>
979// CHECK: <key>file</key><integer>0</integer>
980// CHECK: </dict>
981// CHECK: </array>
982// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000983// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000984// CHECK: </dict>
985// CHECK: <dict>
986// CHECK: <key>kind</key><string>control</string>
987// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000988// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000989// CHECK: <dict>
990// CHECK: <key>start</key>
991// CHECK: <array>
992// CHECK: <dict>
993// CHECK: <key>line</key><integer>39</integer>
994// CHECK: <key>col</key><integer>3</integer>
995// CHECK: <key>file</key><integer>0</integer>
996// CHECK: </dict>
997// CHECK: <dict>
998// CHECK: <key>line</key><integer>39</integer>
999// CHECK: <key>col</key><integer>3</integer>
1000// CHECK: <key>file</key><integer>0</integer>
1001// CHECK: </dict>
1002// CHECK: </array>
1003// CHECK: <key>end</key>
1004// CHECK: <array>
1005// CHECK: <dict>
1006// CHECK: <key>line</key><integer>39</integer>
1007// CHECK: <key>col</key><integer>7</integer>
1008// CHECK: <key>file</key><integer>0</integer>
1009// CHECK: </dict>
1010// CHECK: <dict>
1011// CHECK: <key>line</key><integer>39</integer>
1012// CHECK: <key>col</key><integer>7</integer>
1013// CHECK: <key>file</key><integer>0</integer>
1014// CHECK: </dict>
1015// CHECK: </array>
1016// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +00001017// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001018// CHECK: </dict>
1019// CHECK: <dict>
1020// CHECK: <key>kind</key><string>event</string>
1021// CHECK: <key>location</key>
Anna Zaks368a0d52012-03-15 21:13:02 +00001022// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001023// CHECK: <key>line</key><integer>39</integer>
1024// CHECK: <key>col</key><integer>7</integer>
1025// CHECK: <key>file</key><integer>0</integer>
1026// CHECK: </dict>
1027// CHECK: <key>ranges</key>
1028// CHECK: <array>
Anna Zaks368a0d52012-03-15 21:13:02 +00001029// CHECK: <array>
1030// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001031// CHECK: <key>line</key><integer>39</integer>
1032// CHECK: <key>col</key><integer>7</integer>
1033// CHECK: <key>file</key><integer>0</integer>
1034// CHECK: </dict>
1035// CHECK: <dict>
1036// CHECK: <key>line</key><integer>39</integer>
1037// CHECK: <key>col</key><integer>7</integer>
1038// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +00001039// CHECK: </dict>
1040// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001041// CHECK: </array>
1042// CHECK: <key>depth</key><integer>1</integer>
1043// CHECK: <key>extended_message</key>
1044// CHECK: <string>Assuming &apos;x&apos; is non-null</string>
1045// CHECK: <key>message</key>
1046// CHECK: <string>Assuming &apos;x&apos; is non-null</string>
1047// CHECK: </dict>
1048// CHECK: <dict>
1049// CHECK: <key>kind</key><string>control</string>
1050// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +00001051// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001052// CHECK: <dict>
1053// CHECK: <key>start</key>
1054// CHECK: <array>
1055// CHECK: <dict>
1056// CHECK: <key>line</key><integer>39</integer>
1057// CHECK: <key>col</key><integer>7</integer>
1058// CHECK: <key>file</key><integer>0</integer>
1059// CHECK: </dict>
1060// CHECK: <dict>
1061// CHECK: <key>line</key><integer>39</integer>
1062// CHECK: <key>col</key><integer>7</integer>
1063// CHECK: <key>file</key><integer>0</integer>
1064// CHECK: </dict>
1065// CHECK: </array>
1066// CHECK: <key>end</key>
1067// CHECK: <array>
1068// CHECK: <dict>
1069// CHECK: <key>line</key><integer>40</integer>
1070// CHECK: <key>col</key><integer>5</integer>
1071// CHECK: <key>file</key><integer>0</integer>
1072// CHECK: </dict>
1073// CHECK: <dict>
1074// CHECK: <key>line</key><integer>40</integer>
1075// CHECK: <key>col</key><integer>5</integer>
1076// CHECK: <key>file</key><integer>0</integer>
1077// CHECK: </dict>
1078// CHECK: </array>
1079// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +00001080// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001081// CHECK: </dict>
1082// CHECK: <dict>
1083// CHECK: <key>kind</key><string>event</string>
1084// CHECK: <key>location</key>
Anna Zaks368a0d52012-03-15 21:13:02 +00001085// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001086// CHECK: <key>line</key><integer>45</integer>
1087// CHECK: <key>col</key><integer>15</integer>
1088// CHECK: <key>file</key><integer>0</integer>
1089// CHECK: </dict>
1090// CHECK: <key>ranges</key>
1091// CHECK: <array>
Anna Zaks368a0d52012-03-15 21:13:02 +00001092// CHECK: <array>
1093// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001094// CHECK: <key>line</key><integer>45</integer>
1095// CHECK: <key>col</key><integer>15</integer>
1096// CHECK: <key>file</key><integer>0</integer>
1097// CHECK: </dict>
1098// CHECK: <dict>
1099// CHECK: <key>line</key><integer>45</integer>
1100// CHECK: <key>col</key><integer>23</integer>
1101// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +00001102// CHECK: </dict>
1103// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001104// CHECK: </array>
1105// CHECK: <key>depth</key><integer>1</integer>
1106// CHECK: <key>extended_message</key>
1107// CHECK: <string>Returning from &apos;wrapper&apos;, which allocated memory</string>
1108// CHECK: <key>message</key>
1109// CHECK: <string>Returning from &apos;wrapper&apos;, which allocated memory</string>
1110// CHECK: </dict>
1111// CHECK: <dict>
1112// CHECK: <key>kind</key><string>control</string>
1113// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +00001114// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001115// CHECK: <dict>
1116// CHECK: <key>start</key>
1117// CHECK: <array>
1118// CHECK: <dict>
1119// CHECK: <key>line</key><integer>45</integer>
1120// CHECK: <key>col</key><integer>15</integer>
1121// CHECK: <key>file</key><integer>0</integer>
1122// CHECK: </dict>
1123// CHECK: <dict>
1124// CHECK: <key>line</key><integer>45</integer>
1125// CHECK: <key>col</key><integer>23</integer>
1126// CHECK: <key>file</key><integer>0</integer>
1127// CHECK: </dict>
1128// CHECK: </array>
1129// CHECK: <key>end</key>
1130// CHECK: <array>
1131// CHECK: <dict>
1132// CHECK: <key>line</key><integer>47</integer>
1133// CHECK: <key>col</key><integer>1</integer>
1134// CHECK: <key>file</key><integer>0</integer>
1135// CHECK: </dict>
1136// CHECK: <dict>
1137// CHECK: <key>line</key><integer>47</integer>
1138// CHECK: <key>col</key><integer>1</integer>
1139// CHECK: <key>file</key><integer>0</integer>
1140// CHECK: </dict>
1141// CHECK: </array>
1142// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +00001143// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001144// CHECK: </dict>
1145// CHECK: <dict>
1146// CHECK: <key>kind</key><string>event</string>
1147// CHECK: <key>location</key>
1148// CHECK: <dict>
1149// CHECK: <key>line</key><integer>47</integer>
1150// CHECK: <key>col</key><integer>1</integer>
1151// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +00001152// CHECK: </dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001153// CHECK: <key>depth</key><integer>0</integer>
1154// CHECK: <key>extended_message</key>
1155// CHECK: <string>Memory is never released; potential memory leak</string>
1156// CHECK: <key>message</key>
1157// CHECK: <string>Memory is never released; potential memory leak</string>
1158// CHECK: </dict>
1159// CHECK: </array>
1160// CHECK: <key>description</key><string>Memory is never released; potential memory leak</string>
1161// CHECK: <key>category</key><string>Memory Error</string>
1162// CHECK: <key>type</key><string>Memory leak</string>
1163// CHECK: <key>location</key>
1164// CHECK: <dict>
1165// CHECK: <key>line</key><integer>47</integer>
1166// CHECK: <key>col</key><integer>1</integer>
1167// CHECK: <key>file</key><integer>0</integer>
1168// CHECK: </dict>
1169// CHECK: </dict>
1170// CHECK: <dict>
1171// CHECK: <key>path</key>
1172// CHECK: <array>
1173// CHECK: <dict>
1174// CHECK: <key>kind</key><string>control</string>
1175// CHECK: <key>edges</key>
1176// CHECK: <array>
1177// CHECK: <dict>
1178// CHECK: <key>start</key>
1179// CHECK: <array>
1180// CHECK: <dict>
1181// CHECK: <key>line</key><integer>60</integer>
1182// CHECK: <key>col</key><integer>5</integer>
1183// CHECK: <key>file</key><integer>0</integer>
1184// CHECK: </dict>
1185// CHECK: <dict>
1186// CHECK: <key>line</key><integer>60</integer>
1187// CHECK: <key>col</key><integer>5</integer>
1188// CHECK: <key>file</key><integer>0</integer>
1189// CHECK: </dict>
1190// CHECK: </array>
1191// CHECK: <key>end</key>
1192// CHECK: <array>
1193// CHECK: <dict>
1194// CHECK: <key>line</key><integer>61</integer>
1195// CHECK: <key>col</key><integer>5</integer>
1196// CHECK: <key>file</key><integer>0</integer>
1197// CHECK: </dict>
1198// CHECK: <dict>
1199// CHECK: <key>line</key><integer>61</integer>
1200// CHECK: <key>col</key><integer>5</integer>
1201// CHECK: <key>file</key><integer>0</integer>
1202// CHECK: </dict>
1203// CHECK: </array>
1204// CHECK: </dict>
1205// CHECK: </array>
1206// CHECK: </dict>
1207// CHECK: <dict>
1208// CHECK: <key>kind</key><string>event</string>
1209// CHECK: <key>location</key>
1210// CHECK: <dict>
1211// CHECK: <key>line</key><integer>61</integer>
1212// CHECK: <key>col</key><integer>5</integer>
1213// CHECK: <key>file</key><integer>0</integer>
1214// CHECK: </dict>
1215// CHECK: <key>ranges</key>
1216// CHECK: <array>
1217// CHECK: <array>
1218// CHECK: <dict>
1219// CHECK: <key>line</key><integer>61</integer>
1220// CHECK: <key>col</key><integer>5</integer>
1221// CHECK: <key>file</key><integer>0</integer>
1222// CHECK: </dict>
1223// CHECK: <dict>
1224// CHECK: <key>line</key><integer>61</integer>
1225// CHECK: <key>col</key><integer>28</integer>
1226// CHECK: <key>file</key><integer>0</integer>
1227// CHECK: </dict>
1228// CHECK: </array>
1229// CHECK: </array>
1230// CHECK: <key>depth</key><integer>0</integer>
1231// CHECK: <key>extended_message</key>
1232// CHECK: <string>Calling &apos;my_malloc_and_free&apos;</string>
1233// CHECK: <key>message</key>
1234// CHECK: <string>Calling &apos;my_malloc_and_free&apos;</string>
1235// CHECK: </dict>
1236// CHECK: <dict>
1237// CHECK: <key>kind</key><string>event</string>
1238// CHECK: <key>location</key>
1239// CHECK: <dict>
1240// CHECK: <key>line</key><integer>53</integer>
1241// CHECK: <key>col</key><integer>1</integer>
1242// CHECK: <key>file</key><integer>0</integer>
1243// CHECK: </dict>
1244// CHECK: <key>depth</key><integer>1</integer>
1245// CHECK: <key>extended_message</key>
1246// CHECK: <string>Entered call from &apos;test_double_action_call&apos;</string>
1247// CHECK: <key>message</key>
1248// CHECK: <string>Entered call from &apos;test_double_action_call&apos;</string>
1249// CHECK: </dict>
1250// CHECK: <dict>
1251// CHECK: <key>kind</key><string>control</string>
1252// CHECK: <key>edges</key>
1253// CHECK: <array>
1254// CHECK: <dict>
1255// CHECK: <key>start</key>
1256// CHECK: <array>
1257// CHECK: <dict>
1258// CHECK: <key>line</key><integer>53</integer>
1259// CHECK: <key>col</key><integer>1</integer>
1260// CHECK: <key>file</key><integer>0</integer>
1261// CHECK: </dict>
1262// CHECK: <dict>
1263// CHECK: <key>line</key><integer>53</integer>
1264// CHECK: <key>col</key><integer>1</integer>
1265// CHECK: <key>file</key><integer>0</integer>
1266// CHECK: </dict>
1267// CHECK: </array>
1268// CHECK: <key>end</key>
1269// CHECK: <array>
1270// CHECK: <dict>
1271// CHECK: <key>line</key><integer>54</integer>
1272// CHECK: <key>col</key><integer>5</integer>
1273// CHECK: <key>file</key><integer>0</integer>
1274// CHECK: </dict>
1275// CHECK: <dict>
1276// CHECK: <key>line</key><integer>54</integer>
1277// CHECK: <key>col</key><integer>5</integer>
1278// CHECK: <key>file</key><integer>0</integer>
1279// CHECK: </dict>
1280// CHECK: </array>
1281// CHECK: </dict>
1282// CHECK: </array>
1283// CHECK: </dict>
1284// CHECK: <dict>
1285// CHECK: <key>kind</key><string>control</string>
1286// CHECK: <key>edges</key>
1287// CHECK: <array>
1288// CHECK: <dict>
1289// CHECK: <key>start</key>
1290// CHECK: <array>
1291// CHECK: <dict>
1292// CHECK: <key>line</key><integer>54</integer>
1293// CHECK: <key>col</key><integer>5</integer>
1294// CHECK: <key>file</key><integer>0</integer>
1295// CHECK: </dict>
1296// CHECK: <dict>
1297// CHECK: <key>line</key><integer>54</integer>
1298// CHECK: <key>col</key><integer>5</integer>
1299// CHECK: <key>file</key><integer>0</integer>
1300// CHECK: </dict>
1301// CHECK: </array>
1302// CHECK: <key>end</key>
1303// CHECK: <array>
1304// CHECK: <dict>
1305// CHECK: <key>line</key><integer>54</integer>
1306// CHECK: <key>col</key><integer>10</integer>
1307// CHECK: <key>file</key><integer>0</integer>
1308// CHECK: </dict>
1309// CHECK: <dict>
1310// CHECK: <key>line</key><integer>54</integer>
1311// CHECK: <key>col</key><integer>20</integer>
1312// CHECK: <key>file</key><integer>0</integer>
1313// CHECK: </dict>
1314// CHECK: </array>
1315// CHECK: </dict>
1316// CHECK: </array>
1317// CHECK: </dict>
1318// CHECK: <dict>
1319// CHECK: <key>kind</key><string>event</string>
1320// CHECK: <key>location</key>
1321// CHECK: <dict>
1322// CHECK: <key>line</key><integer>54</integer>
1323// CHECK: <key>col</key><integer>10</integer>
1324// CHECK: <key>file</key><integer>0</integer>
1325// CHECK: </dict>
1326// CHECK: <key>ranges</key>
1327// CHECK: <array>
1328// CHECK: <array>
1329// CHECK: <dict>
1330// CHECK: <key>line</key><integer>54</integer>
1331// CHECK: <key>col</key><integer>10</integer>
1332// CHECK: <key>file</key><integer>0</integer>
1333// CHECK: </dict>
1334// CHECK: <dict>
1335// CHECK: <key>line</key><integer>54</integer>
1336// CHECK: <key>col</key><integer>20</integer>
1337// CHECK: <key>file</key><integer>0</integer>
1338// CHECK: </dict>
1339// CHECK: </array>
1340// CHECK: </array>
1341// CHECK: <key>depth</key><integer>1</integer>
1342// CHECK: <key>extended_message</key>
1343// CHECK: <string>Memory is allocated</string>
1344// CHECK: <key>message</key>
1345// CHECK: <string>Memory is allocated</string>
1346// CHECK: </dict>
1347// CHECK: <dict>
1348// CHECK: <key>kind</key><string>control</string>
1349// CHECK: <key>edges</key>
1350// CHECK: <array>
1351// CHECK: <dict>
1352// CHECK: <key>start</key>
1353// CHECK: <array>
1354// CHECK: <dict>
1355// CHECK: <key>line</key><integer>54</integer>
1356// CHECK: <key>col</key><integer>10</integer>
1357// CHECK: <key>file</key><integer>0</integer>
1358// CHECK: </dict>
1359// CHECK: <dict>
1360// CHECK: <key>line</key><integer>54</integer>
1361// CHECK: <key>col</key><integer>20</integer>
1362// CHECK: <key>file</key><integer>0</integer>
1363// CHECK: </dict>
1364// CHECK: </array>
1365// CHECK: <key>end</key>
1366// CHECK: <array>
1367// CHECK: <dict>
1368// CHECK: <key>line</key><integer>55</integer>
1369// CHECK: <key>col</key><integer>5</integer>
1370// CHECK: <key>file</key><integer>0</integer>
1371// CHECK: </dict>
1372// CHECK: <dict>
1373// CHECK: <key>line</key><integer>55</integer>
1374// CHECK: <key>col</key><integer>5</integer>
1375// CHECK: <key>file</key><integer>0</integer>
1376// CHECK: </dict>
1377// CHECK: </array>
1378// CHECK: </dict>
1379// CHECK: </array>
1380// CHECK: </dict>
1381// CHECK: <dict>
1382// CHECK: <key>kind</key><string>control</string>
1383// CHECK: <key>edges</key>
1384// CHECK: <array>
1385// CHECK: <dict>
1386// CHECK: <key>start</key>
1387// CHECK: <array>
1388// CHECK: <dict>
1389// CHECK: <key>line</key><integer>55</integer>
1390// CHECK: <key>col</key><integer>5</integer>
1391// CHECK: <key>file</key><integer>0</integer>
1392// CHECK: </dict>
1393// CHECK: <dict>
1394// CHECK: <key>line</key><integer>55</integer>
1395// CHECK: <key>col</key><integer>5</integer>
1396// CHECK: <key>file</key><integer>0</integer>
1397// CHECK: </dict>
1398// CHECK: </array>
1399// CHECK: <key>end</key>
1400// CHECK: <array>
1401// CHECK: <dict>
1402// CHECK: <key>line</key><integer>56</integer>
1403// CHECK: <key>col</key><integer>7</integer>
1404// CHECK: <key>file</key><integer>0</integer>
1405// CHECK: </dict>
1406// CHECK: <dict>
1407// CHECK: <key>line</key><integer>56</integer>
1408// CHECK: <key>col</key><integer>7</integer>
1409// CHECK: <key>file</key><integer>0</integer>
1410// CHECK: </dict>
1411// CHECK: </array>
1412// CHECK: </dict>
1413// CHECK: </array>
1414// CHECK: </dict>
1415// CHECK: <dict>
1416// CHECK: <key>kind</key><string>event</string>
1417// CHECK: <key>location</key>
1418// CHECK: <dict>
1419// CHECK: <key>line</key><integer>56</integer>
1420// CHECK: <key>col</key><integer>7</integer>
1421// CHECK: <key>file</key><integer>0</integer>
1422// CHECK: </dict>
1423// CHECK: <key>ranges</key>
1424// CHECK: <array>
1425// CHECK: <array>
1426// CHECK: <dict>
1427// CHECK: <key>line</key><integer>56</integer>
1428// CHECK: <key>col</key><integer>7</integer>
1429// CHECK: <key>file</key><integer>0</integer>
1430// CHECK: </dict>
1431// CHECK: <dict>
1432// CHECK: <key>line</key><integer>56</integer>
1433// CHECK: <key>col</key><integer>17</integer>
1434// CHECK: <key>file</key><integer>0</integer>
1435// CHECK: </dict>
1436// CHECK: </array>
1437// CHECK: </array>
1438// CHECK: <key>depth</key><integer>1</integer>
1439// CHECK: <key>extended_message</key>
1440// CHECK: <string>Calling &apos;my_free&apos;</string>
1441// CHECK: <key>message</key>
1442// CHECK: <string>Calling &apos;my_free&apos;</string>
1443// CHECK: </dict>
1444// CHECK: <dict>
1445// CHECK: <key>kind</key><string>event</string>
1446// CHECK: <key>location</key>
1447// CHECK: <dict>
1448// CHECK: <key>line</key><integer>50</integer>
1449// CHECK: <key>col</key><integer>1</integer>
1450// CHECK: <key>file</key><integer>0</integer>
1451// CHECK: </dict>
1452// CHECK: <key>depth</key><integer>2</integer>
1453// CHECK: <key>extended_message</key>
1454// CHECK: <string>Entered call from &apos;my_malloc_and_free&apos;</string>
1455// CHECK: <key>message</key>
1456// CHECK: <string>Entered call from &apos;my_malloc_and_free&apos;</string>
1457// CHECK: </dict>
1458// CHECK: <dict>
1459// CHECK: <key>kind</key><string>control</string>
1460// CHECK: <key>edges</key>
1461// CHECK: <array>
1462// CHECK: <dict>
1463// CHECK: <key>start</key>
1464// CHECK: <array>
1465// CHECK: <dict>
1466// CHECK: <key>line</key><integer>50</integer>
1467// CHECK: <key>col</key><integer>1</integer>
1468// CHECK: <key>file</key><integer>0</integer>
1469// CHECK: </dict>
1470// CHECK: <dict>
1471// CHECK: <key>line</key><integer>50</integer>
1472// CHECK: <key>col</key><integer>1</integer>
1473// CHECK: <key>file</key><integer>0</integer>
1474// CHECK: </dict>
1475// CHECK: </array>
1476// CHECK: <key>end</key>
1477// CHECK: <array>
1478// CHECK: <dict>
1479// CHECK: <key>line</key><integer>51</integer>
1480// CHECK: <key>col</key><integer>5</integer>
1481// CHECK: <key>file</key><integer>0</integer>
1482// CHECK: </dict>
1483// CHECK: <dict>
1484// CHECK: <key>line</key><integer>51</integer>
1485// CHECK: <key>col</key><integer>11</integer>
1486// CHECK: <key>file</key><integer>0</integer>
1487// CHECK: </dict>
1488// CHECK: </array>
1489// CHECK: </dict>
1490// CHECK: </array>
1491// CHECK: </dict>
1492// CHECK: <dict>
1493// CHECK: <key>kind</key><string>event</string>
1494// CHECK: <key>location</key>
1495// CHECK: <dict>
1496// CHECK: <key>line</key><integer>51</integer>
1497// CHECK: <key>col</key><integer>5</integer>
1498// CHECK: <key>file</key><integer>0</integer>
1499// CHECK: </dict>
1500// CHECK: <key>ranges</key>
1501// CHECK: <array>
1502// CHECK: <array>
1503// CHECK: <dict>
1504// CHECK: <key>line</key><integer>51</integer>
1505// CHECK: <key>col</key><integer>5</integer>
1506// CHECK: <key>file</key><integer>0</integer>
1507// CHECK: </dict>
1508// CHECK: <dict>
1509// CHECK: <key>line</key><integer>51</integer>
1510// CHECK: <key>col</key><integer>11</integer>
1511// CHECK: <key>file</key><integer>0</integer>
1512// CHECK: </dict>
1513// CHECK: </array>
1514// CHECK: </array>
1515// CHECK: <key>depth</key><integer>2</integer>
1516// CHECK: <key>extended_message</key>
1517// CHECK: <string>Memory is released</string>
1518// CHECK: <key>message</key>
1519// CHECK: <string>Memory is released</string>
1520// CHECK: </dict>
1521// CHECK: <dict>
1522// CHECK: <key>kind</key><string>event</string>
1523// CHECK: <key>location</key>
1524// CHECK: <dict>
1525// CHECK: <key>line</key><integer>56</integer>
1526// CHECK: <key>col</key><integer>7</integer>
1527// CHECK: <key>file</key><integer>0</integer>
1528// CHECK: </dict>
1529// CHECK: <key>ranges</key>
1530// CHECK: <array>
1531// CHECK: <array>
1532// CHECK: <dict>
1533// CHECK: <key>line</key><integer>56</integer>
1534// CHECK: <key>col</key><integer>7</integer>
1535// CHECK: <key>file</key><integer>0</integer>
1536// CHECK: </dict>
1537// CHECK: <dict>
1538// CHECK: <key>line</key><integer>56</integer>
1539// CHECK: <key>col</key><integer>17</integer>
1540// CHECK: <key>file</key><integer>0</integer>
1541// CHECK: </dict>
1542// CHECK: </array>
1543// CHECK: </array>
1544// CHECK: <key>depth</key><integer>2</integer>
1545// CHECK: <key>extended_message</key>
1546// CHECK: <string>Returning from &apos;my_free&apos;, which released memory</string>
1547// CHECK: <key>message</key>
1548// CHECK: <string>Returning from &apos;my_free&apos;, which released memory</string>
1549// CHECK: </dict>
1550// CHECK: <dict>
1551// CHECK: <key>kind</key><string>control</string>
1552// CHECK: <key>edges</key>
1553// CHECK: <array>
1554// CHECK: <dict>
1555// CHECK: <key>start</key>
1556// CHECK: <array>
1557// CHECK: <dict>
1558// CHECK: <key>line</key><integer>56</integer>
1559// CHECK: <key>col</key><integer>7</integer>
1560// CHECK: <key>file</key><integer>0</integer>
1561// CHECK: </dict>
1562// CHECK: <dict>
1563// CHECK: <key>line</key><integer>56</integer>
1564// CHECK: <key>col</key><integer>17</integer>
1565// CHECK: <key>file</key><integer>0</integer>
1566// CHECK: </dict>
1567// CHECK: </array>
1568// CHECK: <key>end</key>
1569// CHECK: <array>
1570// CHECK: <dict>
1571// CHECK: <key>line</key><integer>57</integer>
1572// CHECK: <key>col</key><integer>5</integer>
1573// CHECK: <key>file</key><integer>0</integer>
1574// CHECK: </dict>
1575// CHECK: <dict>
1576// CHECK: <key>line</key><integer>57</integer>
1577// CHECK: <key>col</key><integer>5</integer>
1578// CHECK: <key>file</key><integer>0</integer>
1579// CHECK: </dict>
1580// CHECK: </array>
1581// CHECK: </dict>
1582// CHECK: </array>
1583// CHECK: </dict>
1584// CHECK: <dict>
1585// CHECK: <key>kind</key><string>event</string>
1586// CHECK: <key>location</key>
1587// CHECK: <dict>
1588// CHECK: <key>line</key><integer>61</integer>
1589// CHECK: <key>col</key><integer>5</integer>
1590// CHECK: <key>file</key><integer>0</integer>
1591// CHECK: </dict>
1592// CHECK: <key>ranges</key>
1593// CHECK: <array>
1594// CHECK: <array>
1595// CHECK: <dict>
1596// CHECK: <key>line</key><integer>61</integer>
1597// CHECK: <key>col</key><integer>5</integer>
1598// CHECK: <key>file</key><integer>0</integer>
1599// CHECK: </dict>
1600// CHECK: <dict>
1601// CHECK: <key>line</key><integer>61</integer>
1602// CHECK: <key>col</key><integer>28</integer>
1603// CHECK: <key>file</key><integer>0</integer>
1604// CHECK: </dict>
1605// CHECK: </array>
1606// CHECK: </array>
1607// CHECK: <key>depth</key><integer>1</integer>
1608// CHECK: <key>extended_message</key>
1609// CHECK: <string>Returning from &apos;my_malloc_and_free&apos;, which released memory</string>
1610// CHECK: <key>message</key>
1611// CHECK: <string>Returning from &apos;my_malloc_and_free&apos;, which released memory</string>
1612// CHECK: </dict>
1613// CHECK: <dict>
1614// CHECK: <key>kind</key><string>control</string>
1615// CHECK: <key>edges</key>
1616// CHECK: <array>
1617// CHECK: <dict>
1618// CHECK: <key>start</key>
1619// CHECK: <array>
1620// CHECK: <dict>
1621// CHECK: <key>line</key><integer>61</integer>
1622// CHECK: <key>col</key><integer>5</integer>
1623// CHECK: <key>file</key><integer>0</integer>
1624// CHECK: </dict>
1625// CHECK: <dict>
1626// CHECK: <key>line</key><integer>61</integer>
1627// CHECK: <key>col</key><integer>28</integer>
1628// CHECK: <key>file</key><integer>0</integer>
1629// CHECK: </dict>
1630// CHECK: </array>
1631// CHECK: <key>end</key>
1632// CHECK: <array>
1633// CHECK: <dict>
1634// CHECK: <key>line</key><integer>62</integer>
1635// CHECK: <key>col</key><integer>5</integer>
1636// CHECK: <key>file</key><integer>0</integer>
1637// CHECK: </dict>
1638// CHECK: <dict>
1639// CHECK: <key>line</key><integer>62</integer>
1640// CHECK: <key>col</key><integer>14</integer>
1641// CHECK: <key>file</key><integer>0</integer>
1642// CHECK: </dict>
1643// CHECK: </array>
1644// CHECK: </dict>
1645// CHECK: </array>
1646// CHECK: </dict>
1647// CHECK: <dict>
1648// CHECK: <key>kind</key><string>event</string>
1649// CHECK: <key>location</key>
1650// CHECK: <dict>
1651// CHECK: <key>line</key><integer>62</integer>
1652// CHECK: <key>col</key><integer>5</integer>
1653// CHECK: <key>file</key><integer>0</integer>
1654// CHECK: </dict>
1655// CHECK: <key>ranges</key>
1656// CHECK: <array>
1657// CHECK: <array>
1658// CHECK: <dict>
1659// CHECK: <key>line</key><integer>62</integer>
1660// CHECK: <key>col</key><integer>12</integer>
1661// CHECK: <key>file</key><integer>0</integer>
1662// CHECK: </dict>
1663// CHECK: <dict>
1664// CHECK: <key>line</key><integer>62</integer>
1665// CHECK: <key>col</key><integer>14</integer>
1666// CHECK: <key>file</key><integer>0</integer>
1667// CHECK: </dict>
1668// CHECK: </array>
1669// CHECK: </array>
1670// CHECK: <key>depth</key><integer>0</integer>
1671// CHECK: <key>extended_message</key>
1672// CHECK: <string>Use of memory after it is freed</string>
1673// CHECK: <key>message</key>
1674// CHECK: <string>Use of memory after it is freed</string>
1675// CHECK: </dict>
1676// CHECK: </array>
1677// CHECK: <key>description</key><string>Use of memory after it is freed</string>
1678// CHECK: <key>category</key><string>Memory Error</string>
1679// CHECK: <key>type</key><string>Use-after-free</string>
1680// CHECK: <key>location</key>
1681// CHECK: <dict>
1682// CHECK: <key>line</key><integer>62</integer>
1683// CHECK: <key>col</key><integer>5</integer>
1684// CHECK: <key>file</key><integer>0</integer>
1685// CHECK: </dict>
1686// CHECK: </dict>
1687// CHECK: </array>
1688// CHECK: </dict>
1689// CHECK: </plist>