blob: d08ed07d184c08dec94576f3bec7c5d6d4e9267b [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.
Anna Zaks56a938f2012-03-16 23:24:20 +000050// Also tests the stack hint for parameters, when they are passed directly or via pointer.
Anna Zaks368a0d52012-03-15 21:13:02 +000051void my_free(void *x) {
52 free(x);
53}
54void my_malloc_and_free(void **x) {
55 *x = malloc(100);
56 if (*x)
57 my_free(*x);
58 return;
59}
60void *test_double_action_call() {
61 void *buf;
62 my_malloc_and_free(&buf);
63 return buf;
64}
65
Anna Zaks56a938f2012-03-16 23:24:20 +000066// Test stack hint for 'reallocation failed'.
67char *my_realloc(char *buf) {
68 char *tmp;
69 tmp = (char*)realloc(buf, 0x1000000);
70 if (!tmp) {
71 return tmp;
72 }
73 return tmp;
74}
75void reallocIntra() {
76 char *buf = (char *)malloc(100);
77 buf = my_realloc(buf);
78 free(buf);
79}
80
81// Test stack hint when returning a result.
82static char *malloc_wrapper_ret() {
83 return (char*)malloc(12);
84}
85void use_ret() {
86 char *v;
87 v = malloc_wrapper_ret();
88}
89
Ted Kremenek11e35b62012-03-15 22:00:28 +000090// CHECK: <?xml version="1.0" encoding="UTF-8"?>
91// CHECK: <plist version="1.0">
92// CHECK: <dict>
93// CHECK: <key>files</key>
94// CHECK: <array>
95// CHECK: </array>
96// CHECK: <key>diagnostics</key>
97// CHECK: <array>
98// CHECK: <dict>
99// CHECK: <key>path</key>
100// CHECK: <array>
101// CHECK: <dict>
102// CHECK: <key>kind</key><string>control</string>
103// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000104// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000105// CHECK: <dict>
106// CHECK: <key>start</key>
107// CHECK: <array>
108// CHECK: <dict>
109// CHECK: <key>line</key><integer>10</integer>
110// CHECK: <key>col</key><integer>5</integer>
111// CHECK: <key>file</key><integer>0</integer>
112// CHECK: </dict>
113// CHECK: <dict>
114// CHECK: <key>line</key><integer>10</integer>
115// CHECK: <key>col</key><integer>5</integer>
116// CHECK: <key>file</key><integer>0</integer>
117// CHECK: </dict>
118// CHECK: </array>
119// CHECK: <key>end</key>
120// CHECK: <array>
121// CHECK: <dict>
122// CHECK: <key>line</key><integer>10</integer>
123// CHECK: <key>col</key><integer>9</integer>
124// CHECK: <key>file</key><integer>0</integer>
125// CHECK: </dict>
126// CHECK: <dict>
127// CHECK: <key>line</key><integer>10</integer>
128// CHECK: <key>col</key><integer>9</integer>
129// CHECK: <key>file</key><integer>0</integer>
130// CHECK: </dict>
131// CHECK: </array>
132// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000133// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000134// CHECK: </dict>
135// CHECK: <dict>
136// CHECK: <key>kind</key><string>control</string>
137// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000138// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000139// CHECK: <dict>
140// CHECK: <key>start</key>
141// CHECK: <array>
142// CHECK: <dict>
143// CHECK: <key>line</key><integer>10</integer>
144// CHECK: <key>col</key><integer>9</integer>
145// CHECK: <key>file</key><integer>0</integer>
146// CHECK: </dict>
147// CHECK: <dict>
148// CHECK: <key>line</key><integer>10</integer>
149// CHECK: <key>col</key><integer>9</integer>
150// CHECK: <key>file</key><integer>0</integer>
151// CHECK: </dict>
152// CHECK: </array>
153// CHECK: <key>end</key>
154// CHECK: <array>
155// CHECK: <dict>
156// CHECK: <key>line</key><integer>11</integer>
157// CHECK: <key>col</key><integer>9</integer>
158// CHECK: <key>file</key><integer>0</integer>
159// CHECK: </dict>
160// CHECK: <dict>
161// CHECK: <key>line</key><integer>11</integer>
162// CHECK: <key>col</key><integer>9</integer>
163// CHECK: <key>file</key><integer>0</integer>
164// CHECK: </dict>
165// CHECK: </array>
166// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000167// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000168// CHECK: </dict>
169// CHECK: <dict>
170// CHECK: <key>kind</key><string>control</string>
171// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000172// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000173// CHECK: <dict>
174// CHECK: <key>start</key>
175// CHECK: <array>
176// CHECK: <dict>
177// CHECK: <key>line</key><integer>11</integer>
178// CHECK: <key>col</key><integer>9</integer>
179// CHECK: <key>file</key><integer>0</integer>
180// CHECK: </dict>
181// CHECK: <dict>
182// CHECK: <key>line</key><integer>11</integer>
183// CHECK: <key>col</key><integer>9</integer>
184// CHECK: <key>file</key><integer>0</integer>
185// CHECK: </dict>
186// CHECK: </array>
187// CHECK: <key>end</key>
188// CHECK: <array>
189// CHECK: <dict>
190// CHECK: <key>line</key><integer>11</integer>
191// CHECK: <key>col</key><integer>18</integer>
192// CHECK: <key>file</key><integer>0</integer>
193// CHECK: </dict>
194// CHECK: <dict>
195// CHECK: <key>line</key><integer>11</integer>
196// CHECK: <key>col</key><integer>27</integer>
197// CHECK: <key>file</key><integer>0</integer>
198// CHECK: </dict>
199// CHECK: </array>
200// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000201// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000202// CHECK: </dict>
203// CHECK: <dict>
204// CHECK: <key>kind</key><string>event</string>
205// CHECK: <key>location</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000206// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000207// CHECK: <key>line</key><integer>11</integer>
208// CHECK: <key>col</key><integer>18</integer>
209// CHECK: <key>file</key><integer>0</integer>
210// CHECK: </dict>
211// CHECK: <key>ranges</key>
212// CHECK: <array>
Anna Zaksfe571602012-02-16 22:26:07 +0000213// CHECK: <array>
214// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000215// CHECK: <key>line</key><integer>11</integer>
216// CHECK: <key>col</key><integer>18</integer>
217// CHECK: <key>file</key><integer>0</integer>
Anna Zaksfe571602012-02-16 22:26:07 +0000218// CHECK: </dict>
Ted Kremenek76aadc32012-03-09 01:13:14 +0000219// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000220// CHECK: <key>line</key><integer>11</integer>
221// CHECK: <key>col</key><integer>27</integer>
222// CHECK: <key>file</key><integer>0</integer>
Ted Kremenek76aadc32012-03-09 01:13:14 +0000223// CHECK: </dict>
224// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000225// CHECK: </array>
226// CHECK: <key>depth</key><integer>0</integer>
227// CHECK: <key>extended_message</key>
228// CHECK: <string>Memory is allocated</string>
229// CHECK: <key>message</key>
230// CHECK: <string>Memory is allocated</string>
231// CHECK: </dict>
232// CHECK: <dict>
233// CHECK: <key>kind</key><string>control</string>
234// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000235// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000236// CHECK: <dict>
237// CHECK: <key>start</key>
238// CHECK: <array>
239// CHECK: <dict>
240// CHECK: <key>line</key><integer>11</integer>
241// CHECK: <key>col</key><integer>18</integer>
242// CHECK: <key>file</key><integer>0</integer>
243// CHECK: </dict>
244// CHECK: <dict>
245// CHECK: <key>line</key><integer>11</integer>
246// CHECK: <key>col</key><integer>27</integer>
247// CHECK: <key>file</key><integer>0</integer>
248// CHECK: </dict>
249// CHECK: </array>
250// CHECK: <key>end</key>
251// CHECK: <array>
252// CHECK: <dict>
253// CHECK: <key>line</key><integer>14</integer>
254// CHECK: <key>col</key><integer>5</integer>
255// CHECK: <key>file</key><integer>0</integer>
256// CHECK: </dict>
257// CHECK: <dict>
258// CHECK: <key>line</key><integer>14</integer>
259// CHECK: <key>col</key><integer>6</integer>
260// CHECK: <key>file</key><integer>0</integer>
261// CHECK: </dict>
262// CHECK: </array>
263// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000264// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000265// CHECK: </dict>
266// CHECK: <dict>
267// CHECK: <key>kind</key><string>event</string>
268// CHECK: <key>location</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000269// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000270// CHECK: <key>line</key><integer>14</integer>
271// CHECK: <key>col</key><integer>5</integer>
272// CHECK: <key>file</key><integer>0</integer>
273// CHECK: </dict>
274// CHECK: <key>ranges</key>
275// CHECK: <array>
Ted Kremenek76aadc32012-03-09 01:13:14 +0000276// CHECK: <array>
277// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000278// CHECK: <key>line</key><integer>14</integer>
279// CHECK: <key>col</key><integer>5</integer>
280// CHECK: <key>file</key><integer>0</integer>
Ted Kremenek76aadc32012-03-09 01:13:14 +0000281// CHECK: </dict>
Ted Kremenek76aadc32012-03-09 01:13:14 +0000282// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000283// CHECK: <key>line</key><integer>14</integer>
284// CHECK: <key>col</key><integer>6</integer>
285// CHECK: <key>file</key><integer>0</integer>
Ted Kremenek76aadc32012-03-09 01:13:14 +0000286// CHECK: </dict>
287// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000288// CHECK: </array>
289// CHECK: <key>depth</key><integer>0</integer>
290// CHECK: <key>extended_message</key>
291// CHECK: <string>Memory is never released; potential memory leak</string>
292// CHECK: <key>message</key>
293// CHECK: <string>Memory is never released; potential memory leak</string>
294// CHECK: </dict>
295// CHECK: </array>
296// CHECK: <key>description</key><string>Memory is never released; potential memory leak</string>
297// CHECK: <key>category</key><string>Memory Error</string>
298// CHECK: <key>type</key><string>Memory leak</string>
299// CHECK: <key>location</key>
300// CHECK: <dict>
301// CHECK: <key>line</key><integer>14</integer>
302// CHECK: <key>col</key><integer>5</integer>
303// CHECK: <key>file</key><integer>0</integer>
304// CHECK: </dict>
305// CHECK: </dict>
306// CHECK: <dict>
307// CHECK: <key>path</key>
308// CHECK: <array>
309// CHECK: <dict>
310// CHECK: <key>kind</key><string>control</string>
311// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000312// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000313// CHECK: <dict>
314// CHECK: <key>start</key>
315// CHECK: <array>
316// CHECK: <dict>
317// CHECK: <key>line</key><integer>18</integer>
318// CHECK: <key>col</key><integer>5</integer>
319// CHECK: <key>file</key><integer>0</integer>
320// CHECK: </dict>
321// CHECK: <dict>
322// CHECK: <key>line</key><integer>18</integer>
323// CHECK: <key>col</key><integer>5</integer>
324// CHECK: <key>file</key><integer>0</integer>
325// CHECK: </dict>
326// CHECK: </array>
327// CHECK: <key>end</key>
328// CHECK: <array>
329// CHECK: <dict>
330// CHECK: <key>line</key><integer>19</integer>
331// CHECK: <key>col</key><integer>5</integer>
332// CHECK: <key>file</key><integer>0</integer>
333// CHECK: </dict>
334// CHECK: <dict>
335// CHECK: <key>line</key><integer>19</integer>
336// CHECK: <key>col</key><integer>5</integer>
337// CHECK: <key>file</key><integer>0</integer>
338// CHECK: </dict>
339// CHECK: </array>
340// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000341// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000342// CHECK: </dict>
343// CHECK: <dict>
344// CHECK: <key>kind</key><string>control</string>
345// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000346// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000347// CHECK: <dict>
348// CHECK: <key>start</key>
349// CHECK: <array>
350// CHECK: <dict>
351// CHECK: <key>line</key><integer>19</integer>
352// CHECK: <key>col</key><integer>5</integer>
353// CHECK: <key>file</key><integer>0</integer>
354// CHECK: </dict>
355// CHECK: <dict>
356// CHECK: <key>line</key><integer>19</integer>
357// CHECK: <key>col</key><integer>5</integer>
358// CHECK: <key>file</key><integer>0</integer>
359// CHECK: </dict>
360// CHECK: </array>
361// CHECK: <key>end</key>
362// CHECK: <array>
363// CHECK: <dict>
364// CHECK: <key>line</key><integer>19</integer>
365// CHECK: <key>col</key><integer>9</integer>
366// CHECK: <key>file</key><integer>0</integer>
367// CHECK: </dict>
368// CHECK: <dict>
369// CHECK: <key>line</key><integer>19</integer>
370// CHECK: <key>col</key><integer>30</integer>
371// CHECK: <key>file</key><integer>0</integer>
372// CHECK: </dict>
373// CHECK: </array>
374// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000375// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000376// CHECK: </dict>
377// CHECK: <dict>
378// CHECK: <key>kind</key><string>event</string>
379// CHECK: <key>location</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000380// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000381// CHECK: <key>line</key><integer>19</integer>
382// CHECK: <key>col</key><integer>9</integer>
383// CHECK: <key>file</key><integer>0</integer>
384// CHECK: </dict>
385// CHECK: <key>ranges</key>
386// CHECK: <array>
Anna Zaks368a0d52012-03-15 21:13:02 +0000387// CHECK: <array>
388// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000389// CHECK: <key>line</key><integer>19</integer>
390// CHECK: <key>col</key><integer>9</integer>
391// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +0000392// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000393// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000394// CHECK: <key>line</key><integer>19</integer>
395// CHECK: <key>col</key><integer>30</integer>
396// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +0000397// CHECK: </dict>
398// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000399// CHECK: </array>
400// CHECK: <key>depth</key><integer>0</integer>
401// CHECK: <key>extended_message</key>
402// CHECK: <string>Memory is allocated</string>
403// CHECK: <key>message</key>
404// CHECK: <string>Memory is allocated</string>
405// CHECK: </dict>
406// CHECK: <dict>
407// CHECK: <key>kind</key><string>control</string>
408// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000409// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000410// CHECK: <dict>
411// CHECK: <key>start</key>
412// CHECK: <array>
413// CHECK: <dict>
414// CHECK: <key>line</key><integer>19</integer>
415// CHECK: <key>col</key><integer>9</integer>
416// CHECK: <key>file</key><integer>0</integer>
417// CHECK: </dict>
418// CHECK: <dict>
419// CHECK: <key>line</key><integer>19</integer>
420// CHECK: <key>col</key><integer>30</integer>
421// CHECK: <key>file</key><integer>0</integer>
422// CHECK: </dict>
423// CHECK: </array>
424// CHECK: <key>end</key>
425// CHECK: <array>
426// CHECK: <dict>
427// CHECK: <key>line</key><integer>21</integer>
428// CHECK: <key>col</key><integer>1</integer>
429// CHECK: <key>file</key><integer>0</integer>
430// CHECK: </dict>
431// CHECK: <dict>
432// CHECK: <key>line</key><integer>21</integer>
433// CHECK: <key>col</key><integer>1</integer>
434// CHECK: <key>file</key><integer>0</integer>
435// CHECK: </dict>
436// CHECK: </array>
437// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000438// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000439// CHECK: </dict>
440// CHECK: <dict>
441// CHECK: <key>kind</key><string>event</string>
442// CHECK: <key>location</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000443// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000444// CHECK: <key>line</key><integer>21</integer>
445// CHECK: <key>col</key><integer>1</integer>
446// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +0000447// CHECK: </dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000448// CHECK: <key>depth</key><integer>0</integer>
449// CHECK: <key>extended_message</key>
450// CHECK: <string>Memory is never released; potential memory leak</string>
451// CHECK: <key>message</key>
452// CHECK: <string>Memory is never released; potential memory leak</string>
453// CHECK: </dict>
454// CHECK: </array>
455// CHECK: <key>description</key><string>Memory is never released; potential memory leak</string>
456// CHECK: <key>category</key><string>Memory Error</string>
457// CHECK: <key>type</key><string>Memory leak</string>
458// CHECK: <key>location</key>
459// CHECK: <dict>
460// CHECK: <key>line</key><integer>21</integer>
461// CHECK: <key>col</key><integer>1</integer>
462// CHECK: <key>file</key><integer>0</integer>
463// CHECK: </dict>
464// CHECK: </dict>
465// CHECK: <dict>
466// CHECK: <key>path</key>
467// CHECK: <array>
468// CHECK: <dict>
469// CHECK: <key>kind</key><string>control</string>
470// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000471// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000472// CHECK: <dict>
473// CHECK: <key>start</key>
474// CHECK: <array>
475// CHECK: <dict>
476// CHECK: <key>line</key><integer>24</integer>
477// CHECK: <key>col</key><integer>5</integer>
478// CHECK: <key>file</key><integer>0</integer>
479// CHECK: </dict>
480// CHECK: <dict>
481// CHECK: <key>line</key><integer>24</integer>
482// CHECK: <key>col</key><integer>5</integer>
483// CHECK: <key>file</key><integer>0</integer>
484// CHECK: </dict>
485// CHECK: </array>
486// CHECK: <key>end</key>
487// CHECK: <array>
488// CHECK: <dict>
489// CHECK: <key>line</key><integer>24</integer>
490// CHECK: <key>col</key><integer>18</integer>
491// CHECK: <key>file</key><integer>0</integer>
492// CHECK: </dict>
493// CHECK: <dict>
494// CHECK: <key>line</key><integer>24</integer>
495// CHECK: <key>col</key><integer>28</integer>
496// CHECK: <key>file</key><integer>0</integer>
497// CHECK: </dict>
498// CHECK: </array>
499// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000500// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000501// CHECK: </dict>
502// CHECK: <dict>
503// CHECK: <key>kind</key><string>event</string>
504// CHECK: <key>location</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000505// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000506// CHECK: <key>line</key><integer>24</integer>
507// CHECK: <key>col</key><integer>18</integer>
508// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +0000509// CHECK: </dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000510// CHECK: <key>ranges</key>
511// CHECK: <array>
Anna Zaks368a0d52012-03-15 21:13:02 +0000512// CHECK: <array>
513// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000514// CHECK: <key>line</key><integer>24</integer>
515// CHECK: <key>col</key><integer>18</integer>
516// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +0000517// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000518// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000519// CHECK: <key>line</key><integer>24</integer>
520// CHECK: <key>col</key><integer>28</integer>
521// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +0000522// CHECK: </dict>
523// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000524// CHECK: </array>
525// CHECK: <key>depth</key><integer>0</integer>
526// CHECK: <key>extended_message</key>
527// CHECK: <string>Memory is allocated</string>
528// CHECK: <key>message</key>
529// CHECK: <string>Memory is allocated</string>
530// CHECK: </dict>
531// CHECK: <dict>
532// CHECK: <key>kind</key><string>control</string>
533// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000534// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000535// CHECK: <dict>
536// CHECK: <key>start</key>
537// CHECK: <array>
538// CHECK: <dict>
539// CHECK: <key>line</key><integer>24</integer>
540// CHECK: <key>col</key><integer>18</integer>
541// CHECK: <key>file</key><integer>0</integer>
542// CHECK: </dict>
543// CHECK: <dict>
544// CHECK: <key>line</key><integer>24</integer>
545// CHECK: <key>col</key><integer>28</integer>
546// CHECK: <key>file</key><integer>0</integer>
547// CHECK: </dict>
548// CHECK: </array>
549// CHECK: <key>end</key>
550// CHECK: <array>
551// CHECK: <dict>
552// CHECK: <key>line</key><integer>26</integer>
553// CHECK: <key>col</key><integer>5</integer>
554// CHECK: <key>file</key><integer>0</integer>
555// CHECK: </dict>
556// CHECK: <dict>
557// CHECK: <key>line</key><integer>26</integer>
558// CHECK: <key>col</key><integer>5</integer>
559// CHECK: <key>file</key><integer>0</integer>
560// CHECK: </dict>
561// CHECK: </array>
562// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000563// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000564// CHECK: </dict>
565// CHECK: <dict>
566// CHECK: <key>kind</key><string>control</string>
567// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000568// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000569// CHECK: <dict>
570// CHECK: <key>start</key>
571// CHECK: <array>
572// CHECK: <dict>
573// CHECK: <key>line</key><integer>26</integer>
574// CHECK: <key>col</key><integer>5</integer>
575// CHECK: <key>file</key><integer>0</integer>
576// CHECK: </dict>
577// CHECK: <dict>
578// CHECK: <key>line</key><integer>26</integer>
579// CHECK: <key>col</key><integer>5</integer>
580// CHECK: <key>file</key><integer>0</integer>
581// CHECK: </dict>
582// CHECK: </array>
583// CHECK: <key>end</key>
584// CHECK: <array>
585// CHECK: <dict>
586// 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>
594// CHECK: </dict>
595// CHECK: </array>
596// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000597// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000598// CHECK: </dict>
599// CHECK: <dict>
600// CHECK: <key>kind</key><string>event</string>
601// CHECK: <key>location</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000602// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000603// CHECK: <key>line</key><integer>26</integer>
604// CHECK: <key>col</key><integer>18</integer>
605// CHECK: <key>file</key><integer>0</integer>
606// CHECK: </dict>
607// CHECK: <key>ranges</key>
608// CHECK: <array>
Anna Zaks368a0d52012-03-15 21:13:02 +0000609// CHECK: <array>
610// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000611// 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>
Anna Zaks368a0d52012-03-15 21:13:02 +0000619// CHECK: </dict>
620// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000621// CHECK: </array>
622// CHECK: <key>depth</key><integer>0</integer>
623// CHECK: <key>extended_message</key>
624// CHECK: <string>Attempt to reallocate memory</string>
625// CHECK: <key>message</key>
626// CHECK: <string>Attempt to reallocate memory</string>
627// CHECK: </dict>
628// CHECK: <dict>
629// CHECK: <key>kind</key><string>control</string>
630// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000631// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000632// CHECK: <dict>
633// CHECK: <key>start</key>
634// CHECK: <array>
635// CHECK: <dict>
636// CHECK: <key>line</key><integer>26</integer>
637// CHECK: <key>col</key><integer>18</integer>
638// CHECK: <key>file</key><integer>0</integer>
639// CHECK: </dict>
640// CHECK: <dict>
641// CHECK: <key>line</key><integer>26</integer>
642// CHECK: <key>col</key><integer>40</integer>
643// CHECK: <key>file</key><integer>0</integer>
644// CHECK: </dict>
645// CHECK: </array>
646// CHECK: <key>end</key>
647// CHECK: <array>
648// CHECK: <dict>
649// CHECK: <key>line</key><integer>29</integer>
650// CHECK: <key>col</key><integer>5</integer>
651// CHECK: <key>file</key><integer>0</integer>
652// CHECK: </dict>
653// CHECK: <dict>
654// CHECK: <key>line</key><integer>29</integer>
655// CHECK: <key>col</key><integer>6</integer>
656// CHECK: <key>file</key><integer>0</integer>
657// CHECK: </dict>
658// CHECK: </array>
659// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000660// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000661// CHECK: </dict>
662// CHECK: <dict>
663// CHECK: <key>kind</key><string>event</string>
664// CHECK: <key>location</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000665// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000666// CHECK: <key>line</key><integer>29</integer>
667// CHECK: <key>col</key><integer>5</integer>
668// CHECK: <key>file</key><integer>0</integer>
669// CHECK: </dict>
670// CHECK: <key>ranges</key>
671// CHECK: <array>
Anna Zaks368a0d52012-03-15 21:13:02 +0000672// CHECK: <array>
673// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000674// CHECK: <key>line</key><integer>29</integer>
675// CHECK: <key>col</key><integer>5</integer>
676// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +0000677// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000678// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000679// CHECK: <key>line</key><integer>29</integer>
680// CHECK: <key>col</key><integer>6</integer>
681// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +0000682// CHECK: </dict>
683// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000684// CHECK: </array>
685// CHECK: <key>depth</key><integer>0</integer>
686// CHECK: <key>extended_message</key>
687// CHECK: <string>Reallocation failed</string>
688// CHECK: <key>message</key>
689// CHECK: <string>Reallocation failed</string>
690// CHECK: </dict>
691// CHECK: <dict>
692// CHECK: <key>kind</key><string>control</string>
693// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000694// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000695// CHECK: <dict>
696// CHECK: <key>start</key>
697// CHECK: <array>
698// CHECK: <dict>
699// CHECK: <key>line</key><integer>29</integer>
700// CHECK: <key>col</key><integer>5</integer>
701// CHECK: <key>file</key><integer>0</integer>
702// CHECK: </dict>
703// CHECK: <dict>
704// CHECK: <key>line</key><integer>29</integer>
705// CHECK: <key>col</key><integer>6</integer>
706// CHECK: <key>file</key><integer>0</integer>
707// CHECK: </dict>
708// CHECK: </array>
709// CHECK: <key>end</key>
710// CHECK: <array>
711// CHECK: <dict>
712// CHECK: <key>line</key><integer>29</integer>
713// CHECK: <key>col</key><integer>9</integer>
714// CHECK: <key>file</key><integer>0</integer>
715// CHECK: </dict>
716// CHECK: <dict>
717// CHECK: <key>line</key><integer>29</integer>
718// CHECK: <key>col</key><integer>12</integer>
719// CHECK: <key>file</key><integer>0</integer>
720// CHECK: </dict>
721// CHECK: </array>
722// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000723// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000724// CHECK: </dict>
725// CHECK: <dict>
726// CHECK: <key>kind</key><string>control</string>
727// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000728// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000729// CHECK: <dict>
730// CHECK: <key>start</key>
731// CHECK: <array>
732// CHECK: <dict>
733// CHECK: <key>line</key><integer>29</integer>
734// CHECK: <key>col</key><integer>9</integer>
735// CHECK: <key>file</key><integer>0</integer>
736// CHECK: </dict>
737// CHECK: <dict>
738// CHECK: <key>line</key><integer>29</integer>
739// CHECK: <key>col</key><integer>12</integer>
740// CHECK: <key>file</key><integer>0</integer>
741// CHECK: </dict>
742// CHECK: </array>
743// CHECK: <key>end</key>
744// CHECK: <array>
745// CHECK: <dict>
746// 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>
754// CHECK: </dict>
755// CHECK: </array>
756// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000757// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000758// CHECK: </dict>
759// CHECK: <dict>
760// CHECK: <key>kind</key><string>event</string>
761// CHECK: <key>location</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000762// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000763// CHECK: <key>line</key><integer>30</integer>
764// CHECK: <key>col</key><integer>9</integer>
765// CHECK: <key>file</key><integer>0</integer>
766// CHECK: </dict>
767// CHECK: <key>ranges</key>
768// CHECK: <array>
Anna Zaks368a0d52012-03-15 21:13:02 +0000769// CHECK: <array>
770// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000771// CHECK: <key>line</key><integer>30</integer>
772// CHECK: <key>col</key><integer>9</integer>
773// CHECK: <key>file</key><integer>0</integer>
774// CHECK: </dict>
775// CHECK: <dict>
776// CHECK: <key>line</key><integer>30</integer>
777// CHECK: <key>col</key><integer>14</integer>
778// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +0000779// CHECK: </dict>
780// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000781// CHECK: </array>
782// CHECK: <key>depth</key><integer>0</integer>
783// CHECK: <key>extended_message</key>
784// CHECK: <string>Memory is never released; potential memory leak</string>
785// CHECK: <key>message</key>
786// CHECK: <string>Memory is never released; potential memory leak</string>
787// CHECK: </dict>
788// CHECK: </array>
789// CHECK: <key>description</key><string>Memory is never released; potential memory leak</string>
790// CHECK: <key>category</key><string>Memory Error</string>
791// CHECK: <key>type</key><string>Memory leak</string>
792// CHECK: <key>location</key>
793// CHECK: <dict>
794// CHECK: <key>line</key><integer>30</integer>
795// CHECK: <key>col</key><integer>9</integer>
796// CHECK: <key>file</key><integer>0</integer>
797// CHECK: </dict>
798// CHECK: </dict>
799// CHECK: <dict>
800// CHECK: <key>path</key>
801// CHECK: <array>
802// CHECK: <dict>
803// CHECK: <key>kind</key><string>control</string>
804// CHECK: <key>edges</key>
805// CHECK: <array>
806// CHECK: <dict>
807// CHECK: <key>start</key>
808// CHECK: <array>
809// CHECK: <dict>
810// CHECK: <key>line</key><integer>45</integer>
811// CHECK: <key>col</key><integer>3</integer>
812// CHECK: <key>file</key><integer>0</integer>
813// CHECK: </dict>
814// CHECK: <dict>
815// CHECK: <key>line</key><integer>45</integer>
816// CHECK: <key>col</key><integer>3</integer>
817// CHECK: <key>file</key><integer>0</integer>
818// CHECK: </dict>
819// CHECK: </array>
820// CHECK: <key>end</key>
821// CHECK: <array>
822// CHECK: <dict>
823// 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>15</integer>
830// CHECK: <key>file</key><integer>0</integer>
831// CHECK: </dict>
832// CHECK: </array>
833// CHECK: </dict>
834// CHECK: </array>
835// CHECK: </dict>
836// CHECK: <dict>
837// CHECK: <key>kind</key><string>event</string>
838// CHECK: <key>location</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000839// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000840// CHECK: <key>line</key><integer>45</integer>
841// CHECK: <key>col</key><integer>15</integer>
842// CHECK: <key>file</key><integer>0</integer>
843// CHECK: </dict>
844// CHECK: <key>ranges</key>
845// CHECK: <array>
Anna Zaks368a0d52012-03-15 21:13:02 +0000846// CHECK: <array>
847// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000848// CHECK: <key>line</key><integer>45</integer>
849// CHECK: <key>col</key><integer>15</integer>
850// CHECK: <key>file</key><integer>0</integer>
851// CHECK: </dict>
852// CHECK: <dict>
853// CHECK: <key>line</key><integer>45</integer>
854// CHECK: <key>col</key><integer>23</integer>
855// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +0000856// CHECK: </dict>
857// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000858// CHECK: </array>
859// CHECK: <key>depth</key><integer>0</integer>
860// CHECK: <key>extended_message</key>
861// CHECK: <string>Calling &apos;wrapper&apos;</string>
862// CHECK: <key>message</key>
863// CHECK: <string>Calling &apos;wrapper&apos;</string>
864// CHECK: </dict>
865// CHECK: <dict>
866// CHECK: <key>kind</key><string>event</string>
867// CHECK: <key>location</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000868// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000869// CHECK: <key>line</key><integer>36</integer>
870// CHECK: <key>col</key><integer>1</integer>
871// CHECK: <key>file</key><integer>0</integer>
872// CHECK: </dict>
873// CHECK: <key>depth</key><integer>1</integer>
874// CHECK: <key>extended_message</key>
875// CHECK: <string>Entered call from &apos;test_wrapper&apos;</string>
876// CHECK: <key>message</key>
877// CHECK: <string>Entered call from &apos;test_wrapper&apos;</string>
878// CHECK: </dict>
879// CHECK: <dict>
880// CHECK: <key>kind</key><string>control</string>
881// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000882// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000883// CHECK: <dict>
884// CHECK: <key>start</key>
885// CHECK: <array>
886// CHECK: <dict>
887// CHECK: <key>line</key><integer>36</integer>
888// CHECK: <key>col</key><integer>1</integer>
889// CHECK: <key>file</key><integer>0</integer>
890// CHECK: </dict>
891// CHECK: <dict>
892// CHECK: <key>line</key><integer>36</integer>
893// CHECK: <key>col</key><integer>1</integer>
894// CHECK: <key>file</key><integer>0</integer>
895// CHECK: </dict>
896// CHECK: </array>
897// CHECK: <key>end</key>
898// CHECK: <array>
899// CHECK: <dict>
900// CHECK: <key>line</key><integer>37</integer>
901// CHECK: <key>col</key><integer>3</integer>
902// CHECK: <key>file</key><integer>0</integer>
903// CHECK: </dict>
904// CHECK: <dict>
905// CHECK: <key>line</key><integer>37</integer>
906// CHECK: <key>col</key><integer>3</integer>
907// CHECK: <key>file</key><integer>0</integer>
908// CHECK: </dict>
909// CHECK: </array>
910// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +0000911// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000912// CHECK: </dict>
913// CHECK: <dict>
914// CHECK: <key>kind</key><string>control</string>
915// CHECK: <key>edges</key>
916// CHECK: <array>
917// CHECK: <dict>
918// CHECK: <key>start</key>
919// CHECK: <array>
920// CHECK: <dict>
921// CHECK: <key>line</key><integer>37</integer>
922// CHECK: <key>col</key><integer>3</integer>
923// CHECK: <key>file</key><integer>0</integer>
924// CHECK: </dict>
925// CHECK: <dict>
926// CHECK: <key>line</key><integer>37</integer>
927// CHECK: <key>col</key><integer>3</integer>
928// CHECK: <key>file</key><integer>0</integer>
929// CHECK: </dict>
930// CHECK: </array>
931// CHECK: <key>end</key>
932// CHECK: <array>
933// CHECK: <dict>
934// 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>
942// CHECK: </dict>
943// CHECK: </array>
944// CHECK: </dict>
945// CHECK: </array>
946// CHECK: </dict>
947// CHECK: <dict>
948// CHECK: <key>kind</key><string>event</string>
949// CHECK: <key>location</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000950// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000951// CHECK: <key>line</key><integer>37</integer>
952// CHECK: <key>col</key><integer>13</integer>
953// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +0000954// CHECK: </dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000955// CHECK: <key>ranges</key>
956// CHECK: <array>
Anna Zaks368a0d52012-03-15 21:13:02 +0000957// CHECK: <array>
958// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000959// 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>
Anna Zaks368a0d52012-03-15 21:13:02 +0000967// CHECK: </dict>
968// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000969// CHECK: </array>
970// CHECK: <key>depth</key><integer>1</integer>
971// CHECK: <key>extended_message</key>
972// CHECK: <string>Memory is allocated</string>
973// CHECK: <key>message</key>
974// CHECK: <string>Memory is allocated</string>
975// CHECK: </dict>
976// CHECK: <dict>
977// CHECK: <key>kind</key><string>control</string>
978// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +0000979// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +0000980// CHECK: <dict>
981// CHECK: <key>start</key>
982// CHECK: <array>
983// CHECK: <dict>
984// CHECK: <key>line</key><integer>37</integer>
985// CHECK: <key>col</key><integer>13</integer>
986// CHECK: <key>file</key><integer>0</integer>
987// CHECK: </dict>
988// CHECK: <dict>
989// CHECK: <key>line</key><integer>37</integer>
990// CHECK: <key>col</key><integer>23</integer>
991// CHECK: <key>file</key><integer>0</integer>
992// CHECK: </dict>
993// CHECK: </array>
994// CHECK: <key>end</key>
995// CHECK: <array>
996// CHECK: <dict>
997// CHECK: <key>line</key><integer>39</integer>
998// CHECK: <key>col</key><integer>3</integer>
999// CHECK: <key>file</key><integer>0</integer>
1000// CHECK: </dict>
1001// CHECK: <dict>
1002// CHECK: <key>line</key><integer>39</integer>
1003// CHECK: <key>col</key><integer>3</integer>
1004// CHECK: <key>file</key><integer>0</integer>
1005// CHECK: </dict>
1006// CHECK: </array>
1007// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +00001008// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001009// CHECK: </dict>
1010// CHECK: <dict>
1011// CHECK: <key>kind</key><string>control</string>
1012// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +00001013// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001014// CHECK: <dict>
1015// CHECK: <key>start</key>
1016// CHECK: <array>
1017// CHECK: <dict>
1018// CHECK: <key>line</key><integer>39</integer>
1019// CHECK: <key>col</key><integer>3</integer>
1020// CHECK: <key>file</key><integer>0</integer>
1021// CHECK: </dict>
1022// CHECK: <dict>
1023// CHECK: <key>line</key><integer>39</integer>
1024// CHECK: <key>col</key><integer>3</integer>
1025// CHECK: <key>file</key><integer>0</integer>
1026// CHECK: </dict>
1027// CHECK: </array>
1028// CHECK: <key>end</key>
1029// CHECK: <array>
1030// CHECK: <dict>
1031// 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>
1039// CHECK: </dict>
1040// CHECK: </array>
1041// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +00001042// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001043// CHECK: </dict>
1044// CHECK: <dict>
1045// CHECK: <key>kind</key><string>event</string>
1046// CHECK: <key>location</key>
Anna Zaks368a0d52012-03-15 21:13:02 +00001047// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001048// CHECK: <key>line</key><integer>39</integer>
1049// CHECK: <key>col</key><integer>7</integer>
1050// CHECK: <key>file</key><integer>0</integer>
1051// CHECK: </dict>
1052// CHECK: <key>ranges</key>
1053// CHECK: <array>
Anna Zaks368a0d52012-03-15 21:13:02 +00001054// CHECK: <array>
1055// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001056// 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>
Anna Zaks368a0d52012-03-15 21:13:02 +00001064// CHECK: </dict>
1065// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001066// CHECK: </array>
1067// CHECK: <key>depth</key><integer>1</integer>
1068// CHECK: <key>extended_message</key>
1069// CHECK: <string>Assuming &apos;x&apos; is non-null</string>
1070// CHECK: <key>message</key>
1071// CHECK: <string>Assuming &apos;x&apos; is non-null</string>
1072// CHECK: </dict>
1073// CHECK: <dict>
1074// CHECK: <key>kind</key><string>control</string>
1075// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +00001076// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001077// CHECK: <dict>
1078// CHECK: <key>start</key>
1079// CHECK: <array>
1080// CHECK: <dict>
1081// CHECK: <key>line</key><integer>39</integer>
1082// CHECK: <key>col</key><integer>7</integer>
1083// CHECK: <key>file</key><integer>0</integer>
1084// CHECK: </dict>
1085// CHECK: <dict>
1086// CHECK: <key>line</key><integer>39</integer>
1087// CHECK: <key>col</key><integer>7</integer>
1088// CHECK: <key>file</key><integer>0</integer>
1089// CHECK: </dict>
1090// CHECK: </array>
1091// CHECK: <key>end</key>
1092// CHECK: <array>
1093// CHECK: <dict>
1094// CHECK: <key>line</key><integer>40</integer>
1095// CHECK: <key>col</key><integer>5</integer>
1096// CHECK: <key>file</key><integer>0</integer>
1097// CHECK: </dict>
1098// CHECK: <dict>
1099// CHECK: <key>line</key><integer>40</integer>
1100// CHECK: <key>col</key><integer>5</integer>
1101// CHECK: <key>file</key><integer>0</integer>
1102// CHECK: </dict>
1103// CHECK: </array>
1104// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +00001105// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001106// CHECK: </dict>
1107// CHECK: <dict>
1108// CHECK: <key>kind</key><string>event</string>
1109// CHECK: <key>location</key>
Anna Zaks368a0d52012-03-15 21:13:02 +00001110// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001111// CHECK: <key>line</key><integer>45</integer>
1112// CHECK: <key>col</key><integer>15</integer>
1113// CHECK: <key>file</key><integer>0</integer>
1114// CHECK: </dict>
1115// CHECK: <key>ranges</key>
1116// CHECK: <array>
Anna Zaks368a0d52012-03-15 21:13:02 +00001117// CHECK: <array>
1118// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001119// 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>
Anna Zaks368a0d52012-03-15 21:13:02 +00001127// CHECK: </dict>
1128// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001129// CHECK: </array>
1130// CHECK: <key>depth</key><integer>1</integer>
1131// CHECK: <key>extended_message</key>
Anna Zaks56a938f2012-03-16 23:24:20 +00001132// CHECK: <string>Returning from &apos;wrapper&apos;; allocated memory returned</string>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001133// CHECK: <key>message</key>
Anna Zaks56a938f2012-03-16 23:24:20 +00001134// CHECK: <string>Returning from &apos;wrapper&apos;; allocated memory returned</string>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001135// CHECK: </dict>
1136// CHECK: <dict>
1137// CHECK: <key>kind</key><string>control</string>
1138// CHECK: <key>edges</key>
Anna Zaks368a0d52012-03-15 21:13:02 +00001139// CHECK: <array>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001140// CHECK: <dict>
1141// CHECK: <key>start</key>
1142// CHECK: <array>
1143// CHECK: <dict>
1144// CHECK: <key>line</key><integer>45</integer>
1145// CHECK: <key>col</key><integer>15</integer>
1146// CHECK: <key>file</key><integer>0</integer>
1147// CHECK: </dict>
1148// CHECK: <dict>
1149// CHECK: <key>line</key><integer>45</integer>
1150// CHECK: <key>col</key><integer>23</integer>
1151// CHECK: <key>file</key><integer>0</integer>
1152// CHECK: </dict>
1153// CHECK: </array>
1154// CHECK: <key>end</key>
1155// CHECK: <array>
1156// CHECK: <dict>
1157// CHECK: <key>line</key><integer>47</integer>
1158// CHECK: <key>col</key><integer>1</integer>
1159// CHECK: <key>file</key><integer>0</integer>
1160// CHECK: </dict>
1161// CHECK: <dict>
1162// CHECK: <key>line</key><integer>47</integer>
1163// CHECK: <key>col</key><integer>1</integer>
1164// CHECK: <key>file</key><integer>0</integer>
1165// CHECK: </dict>
1166// CHECK: </array>
1167// CHECK: </dict>
Anna Zaks368a0d52012-03-15 21:13:02 +00001168// CHECK: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001169// CHECK: </dict>
1170// CHECK: <dict>
1171// CHECK: <key>kind</key><string>event</string>
1172// CHECK: <key>location</key>
1173// CHECK: <dict>
1174// CHECK: <key>line</key><integer>47</integer>
1175// CHECK: <key>col</key><integer>1</integer>
1176// CHECK: <key>file</key><integer>0</integer>
Anna Zaks368a0d52012-03-15 21:13:02 +00001177// CHECK: </dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001178// CHECK: <key>depth</key><integer>0</integer>
1179// CHECK: <key>extended_message</key>
1180// CHECK: <string>Memory is never released; potential memory leak</string>
1181// CHECK: <key>message</key>
1182// CHECK: <string>Memory is never released; potential memory leak</string>
1183// CHECK: </dict>
1184// CHECK: </array>
1185// CHECK: <key>description</key><string>Memory is never released; potential memory leak</string>
1186// CHECK: <key>category</key><string>Memory Error</string>
1187// CHECK: <key>type</key><string>Memory leak</string>
1188// CHECK: <key>location</key>
1189// CHECK: <dict>
1190// CHECK: <key>line</key><integer>47</integer>
1191// CHECK: <key>col</key><integer>1</integer>
1192// CHECK: <key>file</key><integer>0</integer>
1193// CHECK: </dict>
1194// CHECK: </dict>
1195// CHECK: <dict>
1196// CHECK: <key>path</key>
1197// CHECK: <array>
1198// CHECK: <dict>
1199// CHECK: <key>kind</key><string>control</string>
1200// CHECK: <key>edges</key>
1201// CHECK: <array>
1202// CHECK: <dict>
1203// CHECK: <key>start</key>
1204// CHECK: <array>
1205// CHECK: <dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001206// CHECK: <key>line</key><integer>61</integer>
1207// CHECK: <key>col</key><integer>5</integer>
1208// CHECK: <key>file</key><integer>0</integer>
1209// CHECK: </dict>
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: </array>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001216// CHECK: <key>end</key>
1217// CHECK: <array>
1218// CHECK: <dict>
1219// CHECK: <key>line</key><integer>62</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>62</integer>
Anna Zaks56a938f2012-03-16 23:24:20 +00001225// CHECK: <key>col</key><integer>5</integer>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001226// CHECK: <key>file</key><integer>0</integer>
1227// CHECK: </dict>
1228// CHECK: </array>
1229// CHECK: </dict>
1230// CHECK: </array>
1231// CHECK: </dict>
1232// CHECK: <dict>
1233// CHECK: <key>kind</key><string>event</string>
1234// CHECK: <key>location</key>
1235// CHECK: <dict>
1236// CHECK: <key>line</key><integer>62</integer>
1237// CHECK: <key>col</key><integer>5</integer>
1238// CHECK: <key>file</key><integer>0</integer>
1239// CHECK: </dict>
1240// CHECK: <key>ranges</key>
1241// CHECK: <array>
1242// CHECK: <array>
1243// CHECK: <dict>
1244// CHECK: <key>line</key><integer>62</integer>
Anna Zaks56a938f2012-03-16 23:24:20 +00001245// CHECK: <key>col</key><integer>5</integer>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001246// CHECK: <key>file</key><integer>0</integer>
1247// CHECK: </dict>
1248// CHECK: <dict>
1249// CHECK: <key>line</key><integer>62</integer>
Anna Zaks56a938f2012-03-16 23:24:20 +00001250// CHECK: <key>col</key><integer>28</integer>
1251// CHECK: <key>file</key><integer>0</integer>
1252// CHECK: </dict>
1253// CHECK: </array>
1254// CHECK: </array>
1255// CHECK: <key>depth</key><integer>0</integer>
1256// CHECK: <key>extended_message</key>
1257// CHECK: <string>Calling &apos;my_malloc_and_free&apos;</string>
1258// CHECK: <key>message</key>
1259// CHECK: <string>Calling &apos;my_malloc_and_free&apos;</string>
1260// CHECK: </dict>
1261// CHECK: <dict>
1262// CHECK: <key>kind</key><string>event</string>
1263// CHECK: <key>location</key>
1264// CHECK: <dict>
1265// CHECK: <key>line</key><integer>54</integer>
1266// CHECK: <key>col</key><integer>1</integer>
1267// CHECK: <key>file</key><integer>0</integer>
1268// CHECK: </dict>
1269// CHECK: <key>depth</key><integer>1</integer>
1270// CHECK: <key>extended_message</key>
1271// CHECK: <string>Entered call from &apos;test_double_action_call&apos;</string>
1272// CHECK: <key>message</key>
1273// CHECK: <string>Entered call from &apos;test_double_action_call&apos;</string>
1274// CHECK: </dict>
1275// CHECK: <dict>
1276// CHECK: <key>kind</key><string>control</string>
1277// CHECK: <key>edges</key>
1278// CHECK: <array>
1279// CHECK: <dict>
1280// CHECK: <key>start</key>
1281// CHECK: <array>
1282// CHECK: <dict>
1283// CHECK: <key>line</key><integer>54</integer>
1284// CHECK: <key>col</key><integer>1</integer>
1285// CHECK: <key>file</key><integer>0</integer>
1286// CHECK: </dict>
1287// CHECK: <dict>
1288// CHECK: <key>line</key><integer>54</integer>
1289// CHECK: <key>col</key><integer>1</integer>
1290// CHECK: <key>file</key><integer>0</integer>
1291// CHECK: </dict>
1292// CHECK: </array>
1293// CHECK: <key>end</key>
1294// CHECK: <array>
1295// CHECK: <dict>
1296// CHECK: <key>line</key><integer>55</integer>
1297// CHECK: <key>col</key><integer>5</integer>
1298// CHECK: <key>file</key><integer>0</integer>
1299// CHECK: </dict>
1300// CHECK: <dict>
1301// CHECK: <key>line</key><integer>55</integer>
1302// CHECK: <key>col</key><integer>5</integer>
1303// CHECK: <key>file</key><integer>0</integer>
1304// CHECK: </dict>
1305// CHECK: </array>
1306// CHECK: </dict>
1307// CHECK: </array>
1308// CHECK: </dict>
1309// CHECK: <dict>
1310// CHECK: <key>kind</key><string>control</string>
1311// CHECK: <key>edges</key>
1312// CHECK: <array>
1313// CHECK: <dict>
1314// CHECK: <key>start</key>
1315// CHECK: <array>
1316// CHECK: <dict>
1317// CHECK: <key>line</key><integer>55</integer>
1318// CHECK: <key>col</key><integer>5</integer>
1319// CHECK: <key>file</key><integer>0</integer>
1320// CHECK: </dict>
1321// CHECK: <dict>
1322// CHECK: <key>line</key><integer>55</integer>
1323// CHECK: <key>col</key><integer>5</integer>
1324// CHECK: <key>file</key><integer>0</integer>
1325// CHECK: </dict>
1326// CHECK: </array>
1327// CHECK: <key>end</key>
1328// CHECK: <array>
1329// CHECK: <dict>
1330// CHECK: <key>line</key><integer>55</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>55</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: </dict>
1341// CHECK: </array>
1342// CHECK: </dict>
1343// CHECK: <dict>
1344// CHECK: <key>kind</key><string>event</string>
1345// CHECK: <key>location</key>
1346// CHECK: <dict>
1347// CHECK: <key>line</key><integer>55</integer>
1348// CHECK: <key>col</key><integer>10</integer>
1349// CHECK: <key>file</key><integer>0</integer>
1350// CHECK: </dict>
1351// CHECK: <key>ranges</key>
1352// CHECK: <array>
1353// CHECK: <array>
1354// CHECK: <dict>
1355// CHECK: <key>line</key><integer>55</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>55</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: </array>
1366// CHECK: <key>depth</key><integer>1</integer>
1367// CHECK: <key>extended_message</key>
1368// CHECK: <string>Memory is allocated</string>
1369// CHECK: <key>message</key>
1370// CHECK: <string>Memory is allocated</string>
1371// CHECK: </dict>
1372// CHECK: <dict>
1373// CHECK: <key>kind</key><string>control</string>
1374// CHECK: <key>edges</key>
1375// CHECK: <array>
1376// CHECK: <dict>
1377// CHECK: <key>start</key>
1378// CHECK: <array>
1379// CHECK: <dict>
1380// CHECK: <key>line</key><integer>55</integer>
1381// CHECK: <key>col</key><integer>10</integer>
1382// CHECK: <key>file</key><integer>0</integer>
1383// CHECK: </dict>
1384// CHECK: <dict>
1385// CHECK: <key>line</key><integer>55</integer>
1386// CHECK: <key>col</key><integer>20</integer>
1387// CHECK: <key>file</key><integer>0</integer>
1388// CHECK: </dict>
1389// CHECK: </array>
1390// CHECK: <key>end</key>
1391// CHECK: <array>
1392// CHECK: <dict>
1393// CHECK: <key>line</key><integer>56</integer>
1394// CHECK: <key>col</key><integer>5</integer>
1395// CHECK: <key>file</key><integer>0</integer>
1396// CHECK: </dict>
1397// CHECK: <dict>
1398// CHECK: <key>line</key><integer>56</integer>
1399// CHECK: <key>col</key><integer>5</integer>
1400// CHECK: <key>file</key><integer>0</integer>
1401// CHECK: </dict>
1402// CHECK: </array>
1403// CHECK: </dict>
1404// CHECK: </array>
1405// CHECK: </dict>
1406// CHECK: <dict>
1407// CHECK: <key>kind</key><string>control</string>
1408// CHECK: <key>edges</key>
1409// CHECK: <array>
1410// CHECK: <dict>
1411// CHECK: <key>start</key>
1412// CHECK: <array>
1413// CHECK: <dict>
1414// CHECK: <key>line</key><integer>56</integer>
1415// CHECK: <key>col</key><integer>5</integer>
1416// CHECK: <key>file</key><integer>0</integer>
1417// CHECK: </dict>
1418// CHECK: <dict>
1419// CHECK: <key>line</key><integer>56</integer>
1420// CHECK: <key>col</key><integer>5</integer>
1421// CHECK: <key>file</key><integer>0</integer>
1422// CHECK: </dict>
1423// CHECK: </array>
1424// CHECK: <key>end</key>
1425// CHECK: <array>
1426// CHECK: <dict>
1427// CHECK: <key>line</key><integer>57</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>57</integer>
1433// CHECK: <key>col</key><integer>7</integer>
1434// CHECK: <key>file</key><integer>0</integer>
1435// CHECK: </dict>
1436// CHECK: </array>
1437// CHECK: </dict>
1438// CHECK: </array>
1439// CHECK: </dict>
1440// CHECK: <dict>
1441// CHECK: <key>kind</key><string>event</string>
1442// CHECK: <key>location</key>
1443// CHECK: <dict>
1444// CHECK: <key>line</key><integer>57</integer>
1445// CHECK: <key>col</key><integer>7</integer>
1446// CHECK: <key>file</key><integer>0</integer>
1447// CHECK: </dict>
1448// CHECK: <key>ranges</key>
1449// CHECK: <array>
1450// CHECK: <array>
1451// CHECK: <dict>
1452// CHECK: <key>line</key><integer>57</integer>
1453// CHECK: <key>col</key><integer>7</integer>
1454// CHECK: <key>file</key><integer>0</integer>
1455// CHECK: </dict>
1456// CHECK: <dict>
1457// CHECK: <key>line</key><integer>57</integer>
1458// CHECK: <key>col</key><integer>17</integer>
1459// CHECK: <key>file</key><integer>0</integer>
1460// CHECK: </dict>
1461// CHECK: </array>
1462// CHECK: </array>
1463// CHECK: <key>depth</key><integer>1</integer>
1464// CHECK: <key>extended_message</key>
1465// CHECK: <string>Calling &apos;my_free&apos;</string>
1466// CHECK: <key>message</key>
1467// CHECK: <string>Calling &apos;my_free&apos;</string>
1468// CHECK: </dict>
1469// CHECK: <dict>
1470// CHECK: <key>kind</key><string>event</string>
1471// CHECK: <key>location</key>
1472// CHECK: <dict>
1473// CHECK: <key>line</key><integer>51</integer>
1474// CHECK: <key>col</key><integer>1</integer>
1475// CHECK: <key>file</key><integer>0</integer>
1476// CHECK: </dict>
1477// CHECK: <key>depth</key><integer>2</integer>
1478// CHECK: <key>extended_message</key>
1479// CHECK: <string>Entered call from &apos;my_malloc_and_free&apos;</string>
1480// CHECK: <key>message</key>
1481// CHECK: <string>Entered call from &apos;my_malloc_and_free&apos;</string>
1482// CHECK: </dict>
1483// CHECK: <dict>
1484// CHECK: <key>kind</key><string>control</string>
1485// CHECK: <key>edges</key>
1486// CHECK: <array>
1487// CHECK: <dict>
1488// CHECK: <key>start</key>
1489// CHECK: <array>
1490// CHECK: <dict>
1491// CHECK: <key>line</key><integer>51</integer>
1492// CHECK: <key>col</key><integer>1</integer>
1493// CHECK: <key>file</key><integer>0</integer>
1494// CHECK: </dict>
1495// CHECK: <dict>
1496// CHECK: <key>line</key><integer>51</integer>
1497// CHECK: <key>col</key><integer>1</integer>
1498// CHECK: <key>file</key><integer>0</integer>
1499// CHECK: </dict>
1500// CHECK: </array>
1501// CHECK: <key>end</key>
1502// CHECK: <array>
1503// CHECK: <dict>
1504// CHECK: <key>line</key><integer>52</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>52</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: </dict>
1515// CHECK: </array>
1516// CHECK: </dict>
1517// CHECK: <dict>
1518// CHECK: <key>kind</key><string>event</string>
1519// CHECK: <key>location</key>
1520// CHECK: <dict>
1521// CHECK: <key>line</key><integer>52</integer>
1522// CHECK: <key>col</key><integer>5</integer>
1523// CHECK: <key>file</key><integer>0</integer>
1524// CHECK: </dict>
1525// CHECK: <key>ranges</key>
1526// CHECK: <array>
1527// CHECK: <array>
1528// CHECK: <dict>
1529// CHECK: <key>line</key><integer>52</integer>
1530// CHECK: <key>col</key><integer>5</integer>
1531// CHECK: <key>file</key><integer>0</integer>
1532// CHECK: </dict>
1533// CHECK: <dict>
1534// CHECK: <key>line</key><integer>52</integer>
1535// CHECK: <key>col</key><integer>11</integer>
1536// CHECK: <key>file</key><integer>0</integer>
1537// CHECK: </dict>
1538// CHECK: </array>
1539// CHECK: </array>
1540// CHECK: <key>depth</key><integer>2</integer>
1541// CHECK: <key>extended_message</key>
1542// CHECK: <string>Memory is released</string>
1543// CHECK: <key>message</key>
1544// CHECK: <string>Memory is released</string>
1545// CHECK: </dict>
1546// CHECK: <dict>
1547// CHECK: <key>kind</key><string>event</string>
1548// CHECK: <key>location</key>
1549// CHECK: <dict>
1550// CHECK: <key>line</key><integer>57</integer>
1551// CHECK: <key>col</key><integer>7</integer>
1552// CHECK: <key>file</key><integer>0</integer>
1553// CHECK: </dict>
1554// CHECK: <key>ranges</key>
1555// CHECK: <array>
1556// CHECK: <array>
1557// CHECK: <dict>
1558// CHECK: <key>line</key><integer>57</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>57</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: </array>
1569// CHECK: <key>depth</key><integer>2</integer>
1570// CHECK: <key>extended_message</key>
1571// CHECK: <string>Returning from &apos;my_free&apos;; released memory via 1st parameter</string>
1572// CHECK: <key>message</key>
1573// CHECK: <string>Returning from &apos;my_free&apos;; released memory via 1st parameter</string>
1574// CHECK: </dict>
1575// CHECK: <dict>
1576// CHECK: <key>kind</key><string>control</string>
1577// CHECK: <key>edges</key>
1578// CHECK: <array>
1579// CHECK: <dict>
1580// CHECK: <key>start</key>
1581// CHECK: <array>
1582// CHECK: <dict>
1583// CHECK: <key>line</key><integer>57</integer>
1584// CHECK: <key>col</key><integer>7</integer>
1585// CHECK: <key>file</key><integer>0</integer>
1586// CHECK: </dict>
1587// CHECK: <dict>
1588// CHECK: <key>line</key><integer>57</integer>
1589// CHECK: <key>col</key><integer>17</integer>
1590// CHECK: <key>file</key><integer>0</integer>
1591// CHECK: </dict>
1592// CHECK: </array>
1593// CHECK: <key>end</key>
1594// CHECK: <array>
1595// CHECK: <dict>
1596// CHECK: <key>line</key><integer>58</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>58</integer>
1602// CHECK: <key>col</key><integer>5</integer>
1603// CHECK: <key>file</key><integer>0</integer>
1604// CHECK: </dict>
1605// CHECK: </array>
1606// CHECK: </dict>
1607// CHECK: </array>
1608// CHECK: </dict>
1609// CHECK: <dict>
1610// CHECK: <key>kind</key><string>event</string>
1611// CHECK: <key>location</key>
1612// CHECK: <dict>
1613// CHECK: <key>line</key><integer>62</integer>
1614// CHECK: <key>col</key><integer>5</integer>
1615// CHECK: <key>file</key><integer>0</integer>
1616// CHECK: </dict>
1617// CHECK: <key>ranges</key>
1618// CHECK: <array>
1619// CHECK: <array>
1620// CHECK: <dict>
1621// CHECK: <key>line</key><integer>62</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>62</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: </array>
1632// CHECK: <key>depth</key><integer>1</integer>
1633// CHECK: <key>extended_message</key>
1634// CHECK: <string>Returning from &apos;my_malloc_and_free&apos;; released memory via 1st parameter</string>
1635// CHECK: <key>message</key>
1636// CHECK: <string>Returning from &apos;my_malloc_and_free&apos;; released memory via 1st parameter</string>
1637// CHECK: </dict>
1638// CHECK: <dict>
1639// CHECK: <key>kind</key><string>control</string>
1640// CHECK: <key>edges</key>
1641// CHECK: <array>
1642// CHECK: <dict>
1643// CHECK: <key>start</key>
1644// CHECK: <array>
1645// CHECK: <dict>
1646// CHECK: <key>line</key><integer>62</integer>
1647// CHECK: <key>col</key><integer>5</integer>
1648// CHECK: <key>file</key><integer>0</integer>
1649// CHECK: </dict>
1650// CHECK: <dict>
1651// CHECK: <key>line</key><integer>62</integer>
1652// CHECK: <key>col</key><integer>28</integer>
1653// CHECK: <key>file</key><integer>0</integer>
1654// CHECK: </dict>
1655// CHECK: </array>
1656// CHECK: <key>end</key>
1657// CHECK: <array>
1658// CHECK: <dict>
1659// CHECK: <key>line</key><integer>63</integer>
1660// CHECK: <key>col</key><integer>5</integer>
1661// CHECK: <key>file</key><integer>0</integer>
1662// CHECK: </dict>
1663// CHECK: <dict>
1664// CHECK: <key>line</key><integer>63</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: </dict>
1670// CHECK: </array>
1671// CHECK: </dict>
1672// CHECK: <dict>
1673// CHECK: <key>kind</key><string>event</string>
1674// CHECK: <key>location</key>
1675// CHECK: <dict>
1676// CHECK: <key>line</key><integer>63</integer>
1677// CHECK: <key>col</key><integer>5</integer>
1678// CHECK: <key>file</key><integer>0</integer>
1679// CHECK: </dict>
1680// CHECK: <key>ranges</key>
1681// CHECK: <array>
1682// CHECK: <array>
1683// CHECK: <dict>
1684// CHECK: <key>line</key><integer>63</integer>
1685// CHECK: <key>col</key><integer>12</integer>
1686// CHECK: <key>file</key><integer>0</integer>
1687// CHECK: </dict>
1688// CHECK: <dict>
1689// CHECK: <key>line</key><integer>63</integer>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001690// CHECK: <key>col</key><integer>14</integer>
1691// CHECK: <key>file</key><integer>0</integer>
1692// CHECK: </dict>
1693// CHECK: </array>
1694// CHECK: </array>
1695// CHECK: <key>depth</key><integer>0</integer>
1696// CHECK: <key>extended_message</key>
1697// CHECK: <string>Use of memory after it is freed</string>
1698// CHECK: <key>message</key>
1699// CHECK: <string>Use of memory after it is freed</string>
1700// CHECK: </dict>
1701// CHECK: </array>
1702// CHECK: <key>description</key><string>Use of memory after it is freed</string>
1703// CHECK: <key>category</key><string>Memory Error</string>
1704// CHECK: <key>type</key><string>Use-after-free</string>
1705// CHECK: <key>location</key>
1706// CHECK: <dict>
Anna Zaks56a938f2012-03-16 23:24:20 +00001707// CHECK: <key>line</key><integer>63</integer>
Ted Kremenek11e35b62012-03-15 22:00:28 +00001708// CHECK: <key>col</key><integer>5</integer>
1709// CHECK: <key>file</key><integer>0</integer>
1710// CHECK: </dict>
1711// CHECK: </dict>
Anna Zaks56a938f2012-03-16 23:24:20 +00001712// CHECK: <dict>
1713// CHECK: <key>path</key>
1714// CHECK: <array>
1715// CHECK: <dict>
1716// CHECK: <key>kind</key><string>control</string>
1717// CHECK: <key>edges</key>
1718// CHECK: <array>
1719// CHECK: <dict>
1720// CHECK: <key>start</key>
1721// CHECK: <array>
1722// CHECK: <dict>
1723// CHECK: <key>line</key><integer>76</integer>
1724// CHECK: <key>col</key><integer>5</integer>
1725// CHECK: <key>file</key><integer>0</integer>
1726// CHECK: </dict>
1727// CHECK: <dict>
1728// CHECK: <key>line</key><integer>76</integer>
1729// CHECK: <key>col</key><integer>5</integer>
1730// CHECK: <key>file</key><integer>0</integer>
1731// CHECK: </dict>
1732// CHECK: </array>
1733// CHECK: <key>end</key>
1734// CHECK: <array>
1735// CHECK: <dict>
1736// CHECK: <key>line</key><integer>76</integer>
1737// CHECK: <key>col</key><integer>25</integer>
1738// CHECK: <key>file</key><integer>0</integer>
1739// CHECK: </dict>
1740// CHECK: <dict>
1741// CHECK: <key>line</key><integer>76</integer>
1742// CHECK: <key>col</key><integer>35</integer>
1743// CHECK: <key>file</key><integer>0</integer>
1744// CHECK: </dict>
1745// CHECK: </array>
1746// CHECK: </dict>
1747// CHECK: </array>
1748// CHECK: </dict>
1749// CHECK: <dict>
1750// CHECK: <key>kind</key><string>event</string>
1751// CHECK: <key>location</key>
1752// CHECK: <dict>
1753// CHECK: <key>line</key><integer>76</integer>
1754// CHECK: <key>col</key><integer>25</integer>
1755// CHECK: <key>file</key><integer>0</integer>
1756// CHECK: </dict>
1757// CHECK: <key>ranges</key>
1758// CHECK: <array>
1759// CHECK: <array>
1760// CHECK: <dict>
1761// CHECK: <key>line</key><integer>76</integer>
1762// CHECK: <key>col</key><integer>25</integer>
1763// CHECK: <key>file</key><integer>0</integer>
1764// CHECK: </dict>
1765// CHECK: <dict>
1766// CHECK: <key>line</key><integer>76</integer>
1767// CHECK: <key>col</key><integer>35</integer>
1768// CHECK: <key>file</key><integer>0</integer>
1769// CHECK: </dict>
1770// CHECK: </array>
1771// CHECK: </array>
1772// CHECK: <key>depth</key><integer>0</integer>
1773// CHECK: <key>extended_message</key>
1774// CHECK: <string>Memory is allocated</string>
1775// CHECK: <key>message</key>
1776// CHECK: <string>Memory is allocated</string>
1777// CHECK: </dict>
1778// CHECK: <dict>
1779// CHECK: <key>kind</key><string>control</string>
1780// CHECK: <key>edges</key>
1781// CHECK: <array>
1782// CHECK: <dict>
1783// CHECK: <key>start</key>
1784// CHECK: <array>
1785// CHECK: <dict>
1786// CHECK: <key>line</key><integer>76</integer>
1787// CHECK: <key>col</key><integer>25</integer>
1788// CHECK: <key>file</key><integer>0</integer>
1789// CHECK: </dict>
1790// CHECK: <dict>
1791// CHECK: <key>line</key><integer>76</integer>
1792// CHECK: <key>col</key><integer>35</integer>
1793// CHECK: <key>file</key><integer>0</integer>
1794// CHECK: </dict>
1795// CHECK: </array>
1796// CHECK: <key>end</key>
1797// CHECK: <array>
1798// CHECK: <dict>
1799// CHECK: <key>line</key><integer>77</integer>
1800// CHECK: <key>col</key><integer>11</integer>
1801// CHECK: <key>file</key><integer>0</integer>
1802// CHECK: </dict>
1803// CHECK: <dict>
1804// CHECK: <key>line</key><integer>77</integer>
1805// CHECK: <key>col</key><integer>11</integer>
1806// CHECK: <key>file</key><integer>0</integer>
1807// CHECK: </dict>
1808// CHECK: </array>
1809// CHECK: </dict>
1810// CHECK: </array>
1811// CHECK: </dict>
1812// CHECK: <dict>
1813// CHECK: <key>kind</key><string>event</string>
1814// CHECK: <key>location</key>
1815// CHECK: <dict>
1816// CHECK: <key>line</key><integer>77</integer>
1817// CHECK: <key>col</key><integer>11</integer>
1818// CHECK: <key>file</key><integer>0</integer>
1819// CHECK: </dict>
1820// CHECK: <key>ranges</key>
1821// CHECK: <array>
1822// CHECK: <array>
1823// CHECK: <dict>
1824// CHECK: <key>line</key><integer>77</integer>
1825// CHECK: <key>col</key><integer>11</integer>
1826// CHECK: <key>file</key><integer>0</integer>
1827// CHECK: </dict>
1828// CHECK: <dict>
1829// CHECK: <key>line</key><integer>77</integer>
1830// CHECK: <key>col</key><integer>25</integer>
1831// CHECK: <key>file</key><integer>0</integer>
1832// CHECK: </dict>
1833// CHECK: </array>
1834// CHECK: </array>
1835// CHECK: <key>depth</key><integer>0</integer>
1836// CHECK: <key>extended_message</key>
1837// CHECK: <string>Calling &apos;my_realloc&apos;</string>
1838// CHECK: <key>message</key>
1839// CHECK: <string>Calling &apos;my_realloc&apos;</string>
1840// CHECK: </dict>
1841// CHECK: <dict>
1842// CHECK: <key>kind</key><string>event</string>
1843// CHECK: <key>location</key>
1844// CHECK: <dict>
1845// CHECK: <key>line</key><integer>67</integer>
1846// CHECK: <key>col</key><integer>1</integer>
1847// CHECK: <key>file</key><integer>0</integer>
1848// CHECK: </dict>
1849// CHECK: <key>depth</key><integer>1</integer>
1850// CHECK: <key>extended_message</key>
1851// CHECK: <string>Entered call from &apos;reallocIntra&apos;</string>
1852// CHECK: <key>message</key>
1853// CHECK: <string>Entered call from &apos;reallocIntra&apos;</string>
1854// CHECK: </dict>
1855// CHECK: <dict>
1856// CHECK: <key>kind</key><string>control</string>
1857// CHECK: <key>edges</key>
1858// CHECK: <array>
1859// CHECK: <dict>
1860// CHECK: <key>start</key>
1861// CHECK: <array>
1862// CHECK: <dict>
1863// CHECK: <key>line</key><integer>67</integer>
1864// CHECK: <key>col</key><integer>1</integer>
1865// CHECK: <key>file</key><integer>0</integer>
1866// CHECK: </dict>
1867// CHECK: <dict>
1868// CHECK: <key>line</key><integer>67</integer>
1869// CHECK: <key>col</key><integer>1</integer>
1870// CHECK: <key>file</key><integer>0</integer>
1871// CHECK: </dict>
1872// CHECK: </array>
1873// CHECK: <key>end</key>
1874// CHECK: <array>
1875// CHECK: <dict>
1876// CHECK: <key>line</key><integer>68</integer>
1877// CHECK: <key>col</key><integer>5</integer>
1878// CHECK: <key>file</key><integer>0</integer>
1879// CHECK: </dict>
1880// CHECK: <dict>
1881// CHECK: <key>line</key><integer>68</integer>
1882// CHECK: <key>col</key><integer>5</integer>
1883// CHECK: <key>file</key><integer>0</integer>
1884// CHECK: </dict>
1885// CHECK: </array>
1886// CHECK: </dict>
1887// CHECK: </array>
1888// CHECK: </dict>
1889// CHECK: <dict>
1890// CHECK: <key>kind</key><string>control</string>
1891// CHECK: <key>edges</key>
1892// CHECK: <array>
1893// CHECK: <dict>
1894// CHECK: <key>start</key>
1895// CHECK: <array>
1896// CHECK: <dict>
1897// CHECK: <key>line</key><integer>68</integer>
1898// CHECK: <key>col</key><integer>5</integer>
1899// CHECK: <key>file</key><integer>0</integer>
1900// CHECK: </dict>
1901// CHECK: <dict>
1902// CHECK: <key>line</key><integer>68</integer>
1903// CHECK: <key>col</key><integer>5</integer>
1904// CHECK: <key>file</key><integer>0</integer>
1905// CHECK: </dict>
1906// CHECK: </array>
1907// CHECK: <key>end</key>
1908// CHECK: <array>
1909// CHECK: <dict>
1910// CHECK: <key>line</key><integer>69</integer>
1911// CHECK: <key>col</key><integer>5</integer>
1912// CHECK: <key>file</key><integer>0</integer>
1913// CHECK: </dict>
1914// CHECK: <dict>
1915// CHECK: <key>line</key><integer>69</integer>
1916// CHECK: <key>col</key><integer>5</integer>
1917// CHECK: <key>file</key><integer>0</integer>
1918// CHECK: </dict>
1919// CHECK: </array>
1920// CHECK: </dict>
1921// CHECK: </array>
1922// CHECK: </dict>
1923// CHECK: <dict>
1924// CHECK: <key>kind</key><string>control</string>
1925// CHECK: <key>edges</key>
1926// CHECK: <array>
1927// CHECK: <dict>
1928// CHECK: <key>start</key>
1929// CHECK: <array>
1930// CHECK: <dict>
1931// CHECK: <key>line</key><integer>69</integer>
1932// CHECK: <key>col</key><integer>5</integer>
1933// CHECK: <key>file</key><integer>0</integer>
1934// CHECK: </dict>
1935// CHECK: <dict>
1936// CHECK: <key>line</key><integer>69</integer>
1937// CHECK: <key>col</key><integer>5</integer>
1938// CHECK: <key>file</key><integer>0</integer>
1939// CHECK: </dict>
1940// CHECK: </array>
1941// CHECK: <key>end</key>
1942// CHECK: <array>
1943// CHECK: <dict>
1944// CHECK: <key>line</key><integer>69</integer>
1945// CHECK: <key>col</key><integer>18</integer>
1946// CHECK: <key>file</key><integer>0</integer>
1947// CHECK: </dict>
1948// CHECK: <dict>
1949// CHECK: <key>line</key><integer>69</integer>
1950// CHECK: <key>col</key><integer>40</integer>
1951// CHECK: <key>file</key><integer>0</integer>
1952// CHECK: </dict>
1953// CHECK: </array>
1954// CHECK: </dict>
1955// CHECK: </array>
1956// CHECK: </dict>
1957// CHECK: <dict>
1958// CHECK: <key>kind</key><string>event</string>
1959// CHECK: <key>location</key>
1960// CHECK: <dict>
1961// CHECK: <key>line</key><integer>69</integer>
1962// CHECK: <key>col</key><integer>18</integer>
1963// CHECK: <key>file</key><integer>0</integer>
1964// CHECK: </dict>
1965// CHECK: <key>ranges</key>
1966// CHECK: <array>
1967// CHECK: <array>
1968// CHECK: <dict>
1969// CHECK: <key>line</key><integer>69</integer>
1970// CHECK: <key>col</key><integer>18</integer>
1971// CHECK: <key>file</key><integer>0</integer>
1972// CHECK: </dict>
1973// CHECK: <dict>
1974// CHECK: <key>line</key><integer>69</integer>
1975// CHECK: <key>col</key><integer>40</integer>
1976// CHECK: <key>file</key><integer>0</integer>
1977// CHECK: </dict>
1978// CHECK: </array>
1979// CHECK: </array>
1980// CHECK: <key>depth</key><integer>1</integer>
1981// CHECK: <key>extended_message</key>
1982// CHECK: <string>Attempt to reallocate memory</string>
1983// CHECK: <key>message</key>
1984// CHECK: <string>Attempt to reallocate memory</string>
1985// CHECK: </dict>
1986// CHECK: <dict>
1987// CHECK: <key>kind</key><string>control</string>
1988// CHECK: <key>edges</key>
1989// CHECK: <array>
1990// CHECK: <dict>
1991// CHECK: <key>start</key>
1992// CHECK: <array>
1993// CHECK: <dict>
1994// CHECK: <key>line</key><integer>69</integer>
1995// CHECK: <key>col</key><integer>18</integer>
1996// CHECK: <key>file</key><integer>0</integer>
1997// CHECK: </dict>
1998// CHECK: <dict>
1999// CHECK: <key>line</key><integer>69</integer>
2000// CHECK: <key>col</key><integer>40</integer>
2001// CHECK: <key>file</key><integer>0</integer>
2002// CHECK: </dict>
2003// CHECK: </array>
2004// CHECK: <key>end</key>
2005// CHECK: <array>
2006// CHECK: <dict>
2007// CHECK: <key>line</key><integer>70</integer>
2008// CHECK: <key>col</key><integer>5</integer>
2009// CHECK: <key>file</key><integer>0</integer>
2010// CHECK: </dict>
2011// CHECK: <dict>
2012// CHECK: <key>line</key><integer>70</integer>
2013// CHECK: <key>col</key><integer>6</integer>
2014// CHECK: <key>file</key><integer>0</integer>
2015// CHECK: </dict>
2016// CHECK: </array>
2017// CHECK: </dict>
2018// CHECK: </array>
2019// CHECK: </dict>
2020// CHECK: <dict>
2021// CHECK: <key>kind</key><string>event</string>
2022// CHECK: <key>location</key>
2023// CHECK: <dict>
2024// CHECK: <key>line</key><integer>70</integer>
2025// CHECK: <key>col</key><integer>5</integer>
2026// CHECK: <key>file</key><integer>0</integer>
2027// CHECK: </dict>
2028// CHECK: <key>ranges</key>
2029// CHECK: <array>
2030// CHECK: <array>
2031// CHECK: <dict>
2032// CHECK: <key>line</key><integer>70</integer>
2033// CHECK: <key>col</key><integer>5</integer>
2034// CHECK: <key>file</key><integer>0</integer>
2035// CHECK: </dict>
2036// CHECK: <dict>
2037// CHECK: <key>line</key><integer>70</integer>
2038// CHECK: <key>col</key><integer>6</integer>
2039// CHECK: <key>file</key><integer>0</integer>
2040// CHECK: </dict>
2041// CHECK: </array>
2042// CHECK: </array>
2043// CHECK: <key>depth</key><integer>1</integer>
2044// CHECK: <key>extended_message</key>
2045// CHECK: <string>Reallocation failed</string>
2046// CHECK: <key>message</key>
2047// CHECK: <string>Reallocation failed</string>
2048// CHECK: </dict>
2049// CHECK: <dict>
2050// CHECK: <key>kind</key><string>control</string>
2051// CHECK: <key>edges</key>
2052// CHECK: <array>
2053// CHECK: <dict>
2054// CHECK: <key>start</key>
2055// CHECK: <array>
2056// CHECK: <dict>
2057// CHECK: <key>line</key><integer>70</integer>
2058// CHECK: <key>col</key><integer>5</integer>
2059// CHECK: <key>file</key><integer>0</integer>
2060// CHECK: </dict>
2061// CHECK: <dict>
2062// CHECK: <key>line</key><integer>70</integer>
2063// CHECK: <key>col</key><integer>6</integer>
2064// CHECK: <key>file</key><integer>0</integer>
2065// CHECK: </dict>
2066// CHECK: </array>
2067// CHECK: <key>end</key>
2068// CHECK: <array>
2069// CHECK: <dict>
2070// CHECK: <key>line</key><integer>70</integer>
2071// CHECK: <key>col</key><integer>9</integer>
2072// CHECK: <key>file</key><integer>0</integer>
2073// CHECK: </dict>
2074// CHECK: <dict>
2075// CHECK: <key>line</key><integer>70</integer>
2076// CHECK: <key>col</key><integer>12</integer>
2077// CHECK: <key>file</key><integer>0</integer>
2078// CHECK: </dict>
2079// CHECK: </array>
2080// CHECK: </dict>
2081// CHECK: </array>
2082// CHECK: </dict>
2083// CHECK: <dict>
2084// CHECK: <key>kind</key><string>control</string>
2085// CHECK: <key>edges</key>
2086// CHECK: <array>
2087// CHECK: <dict>
2088// CHECK: <key>start</key>
2089// CHECK: <array>
2090// CHECK: <dict>
2091// CHECK: <key>line</key><integer>70</integer>
2092// CHECK: <key>col</key><integer>9</integer>
2093// CHECK: <key>file</key><integer>0</integer>
2094// CHECK: </dict>
2095// CHECK: <dict>
2096// CHECK: <key>line</key><integer>70</integer>
2097// CHECK: <key>col</key><integer>12</integer>
2098// CHECK: <key>file</key><integer>0</integer>
2099// CHECK: </dict>
2100// CHECK: </array>
2101// CHECK: <key>end</key>
2102// CHECK: <array>
2103// CHECK: <dict>
2104// CHECK: <key>line</key><integer>71</integer>
2105// CHECK: <key>col</key><integer>9</integer>
2106// CHECK: <key>file</key><integer>0</integer>
2107// CHECK: </dict>
2108// CHECK: <dict>
2109// CHECK: <key>line</key><integer>71</integer>
2110// CHECK: <key>col</key><integer>9</integer>
2111// CHECK: <key>file</key><integer>0</integer>
2112// CHECK: </dict>
2113// CHECK: </array>
2114// CHECK: </dict>
2115// CHECK: </array>
2116// CHECK: </dict>
2117// CHECK: <dict>
2118// CHECK: <key>kind</key><string>event</string>
2119// CHECK: <key>location</key>
2120// CHECK: <dict>
2121// CHECK: <key>line</key><integer>77</integer>
2122// CHECK: <key>col</key><integer>11</integer>
2123// CHECK: <key>file</key><integer>0</integer>
2124// CHECK: </dict>
2125// CHECK: <key>ranges</key>
2126// CHECK: <array>
2127// CHECK: <array>
2128// CHECK: <dict>
2129// CHECK: <key>line</key><integer>77</integer>
2130// CHECK: <key>col</key><integer>11</integer>
2131// CHECK: <key>file</key><integer>0</integer>
2132// CHECK: </dict>
2133// CHECK: <dict>
2134// CHECK: <key>line</key><integer>77</integer>
2135// CHECK: <key>col</key><integer>25</integer>
2136// CHECK: <key>file</key><integer>0</integer>
2137// CHECK: </dict>
2138// CHECK: </array>
2139// CHECK: </array>
2140// CHECK: <key>depth</key><integer>1</integer>
2141// CHECK: <key>extended_message</key>
2142// CHECK: <string>Returning from &apos;my_realloc&apos;; reallocation of 1st parameter failed</string>
2143// CHECK: <key>message</key>
2144// CHECK: <string>Returning from &apos;my_realloc&apos;; reallocation of 1st parameter failed</string>
2145// CHECK: </dict>
2146// CHECK: <dict>
2147// CHECK: <key>kind</key><string>control</string>
2148// CHECK: <key>edges</key>
2149// CHECK: <array>
2150// CHECK: <dict>
2151// CHECK: <key>start</key>
2152// CHECK: <array>
2153// CHECK: <dict>
2154// CHECK: <key>line</key><integer>77</integer>
2155// CHECK: <key>col</key><integer>11</integer>
2156// CHECK: <key>file</key><integer>0</integer>
2157// CHECK: </dict>
2158// CHECK: <dict>
2159// CHECK: <key>line</key><integer>77</integer>
2160// CHECK: <key>col</key><integer>25</integer>
2161// CHECK: <key>file</key><integer>0</integer>
2162// CHECK: </dict>
2163// CHECK: </array>
2164// CHECK: <key>end</key>
2165// CHECK: <array>
2166// CHECK: <dict>
2167// CHECK: <key>line</key><integer>78</integer>
2168// CHECK: <key>col</key><integer>5</integer>
2169// CHECK: <key>file</key><integer>0</integer>
2170// CHECK: </dict>
2171// CHECK: <dict>
2172// CHECK: <key>line</key><integer>78</integer>
2173// CHECK: <key>col</key><integer>13</integer>
2174// CHECK: <key>file</key><integer>0</integer>
2175// CHECK: </dict>
2176// CHECK: </array>
2177// CHECK: </dict>
2178// CHECK: </array>
2179// CHECK: </dict>
2180// CHECK: <dict>
2181// CHECK: <key>kind</key><string>event</string>
2182// CHECK: <key>location</key>
2183// CHECK: <dict>
2184// CHECK: <key>line</key><integer>78</integer>
2185// CHECK: <key>col</key><integer>5</integer>
2186// CHECK: <key>file</key><integer>0</integer>
2187// CHECK: </dict>
2188// CHECK: <key>ranges</key>
2189// CHECK: <array>
2190// CHECK: <array>
2191// CHECK: <dict>
2192// CHECK: <key>line</key><integer>78</integer>
2193// CHECK: <key>col</key><integer>5</integer>
2194// CHECK: <key>file</key><integer>0</integer>
2195// CHECK: </dict>
2196// CHECK: <dict>
2197// CHECK: <key>line</key><integer>78</integer>
2198// CHECK: <key>col</key><integer>13</integer>
2199// CHECK: <key>file</key><integer>0</integer>
2200// CHECK: </dict>
2201// CHECK: </array>
2202// CHECK: </array>
2203// CHECK: <key>depth</key><integer>0</integer>
2204// CHECK: <key>extended_message</key>
2205// CHECK: <string>Memory is never released; potential memory leak</string>
2206// CHECK: <key>message</key>
2207// CHECK: <string>Memory is never released; potential memory leak</string>
2208// CHECK: </dict>
2209// CHECK: </array>
2210// CHECK: <key>description</key><string>Memory is never released; potential memory leak</string>
2211// CHECK: <key>category</key><string>Memory Error</string>
2212// CHECK: <key>type</key><string>Memory leak</string>
2213// CHECK: <key>location</key>
2214// CHECK: <dict>
2215// CHECK: <key>line</key><integer>78</integer>
2216// CHECK: <key>col</key><integer>5</integer>
2217// CHECK: <key>file</key><integer>0</integer>
2218// CHECK: </dict>
2219// CHECK: </dict>
2220// CHECK: <dict>
2221// CHECK: <key>path</key>
2222// CHECK: <array>
2223// CHECK: <dict>
2224// CHECK: <key>kind</key><string>control</string>
2225// CHECK: <key>edges</key>
2226// CHECK: <array>
2227// CHECK: <dict>
2228// CHECK: <key>start</key>
2229// CHECK: <array>
2230// CHECK: <dict>
2231// CHECK: <key>line</key><integer>86</integer>
2232// CHECK: <key>col</key><integer>5</integer>
2233// CHECK: <key>file</key><integer>0</integer>
2234// CHECK: </dict>
2235// CHECK: <dict>
2236// CHECK: <key>line</key><integer>86</integer>
2237// CHECK: <key>col</key><integer>5</integer>
2238// CHECK: <key>file</key><integer>0</integer>
2239// CHECK: </dict>
2240// CHECK: </array>
2241// CHECK: <key>end</key>
2242// CHECK: <array>
2243// CHECK: <dict>
2244// CHECK: <key>line</key><integer>87</integer>
2245// CHECK: <key>col</key><integer>9</integer>
2246// CHECK: <key>file</key><integer>0</integer>
2247// CHECK: </dict>
2248// CHECK: <dict>
2249// CHECK: <key>line</key><integer>87</integer>
2250// CHECK: <key>col</key><integer>9</integer>
2251// CHECK: <key>file</key><integer>0</integer>
2252// CHECK: </dict>
2253// CHECK: </array>
2254// CHECK: </dict>
2255// CHECK: </array>
2256// CHECK: </dict>
2257// CHECK: <dict>
2258// CHECK: <key>kind</key><string>event</string>
2259// CHECK: <key>location</key>
2260// CHECK: <dict>
2261// CHECK: <key>line</key><integer>87</integer>
2262// CHECK: <key>col</key><integer>9</integer>
2263// CHECK: <key>file</key><integer>0</integer>
2264// CHECK: </dict>
2265// CHECK: <key>ranges</key>
2266// CHECK: <array>
2267// CHECK: <array>
2268// CHECK: <dict>
2269// CHECK: <key>line</key><integer>87</integer>
2270// CHECK: <key>col</key><integer>9</integer>
2271// CHECK: <key>file</key><integer>0</integer>
2272// CHECK: </dict>
2273// CHECK: <dict>
2274// CHECK: <key>line</key><integer>87</integer>
2275// CHECK: <key>col</key><integer>28</integer>
2276// CHECK: <key>file</key><integer>0</integer>
2277// CHECK: </dict>
2278// CHECK: </array>
2279// CHECK: </array>
2280// CHECK: <key>depth</key><integer>0</integer>
2281// CHECK: <key>extended_message</key>
2282// CHECK: <string>Calling &apos;malloc_wrapper_ret&apos;</string>
2283// CHECK: <key>message</key>
2284// CHECK: <string>Calling &apos;malloc_wrapper_ret&apos;</string>
2285// CHECK: </dict>
2286// CHECK: <dict>
2287// CHECK: <key>kind</key><string>event</string>
2288// CHECK: <key>location</key>
2289// CHECK: <dict>
2290// CHECK: <key>line</key><integer>82</integer>
2291// CHECK: <key>col</key><integer>1</integer>
2292// CHECK: <key>file</key><integer>0</integer>
2293// CHECK: </dict>
2294// CHECK: <key>depth</key><integer>1</integer>
2295// CHECK: <key>extended_message</key>
2296// CHECK: <string>Entered call from &apos;use_ret&apos;</string>
2297// CHECK: <key>message</key>
2298// CHECK: <string>Entered call from &apos;use_ret&apos;</string>
2299// CHECK: </dict>
2300// CHECK: <dict>
2301// CHECK: <key>kind</key><string>control</string>
2302// CHECK: <key>edges</key>
2303// CHECK: <array>
2304// CHECK: <dict>
2305// CHECK: <key>start</key>
2306// CHECK: <array>
2307// CHECK: <dict>
2308// CHECK: <key>line</key><integer>82</integer>
2309// CHECK: <key>col</key><integer>1</integer>
2310// CHECK: <key>file</key><integer>0</integer>
2311// CHECK: </dict>
2312// CHECK: <dict>
2313// CHECK: <key>line</key><integer>82</integer>
2314// CHECK: <key>col</key><integer>1</integer>
2315// CHECK: <key>file</key><integer>0</integer>
2316// CHECK: </dict>
2317// CHECK: </array>
2318// CHECK: <key>end</key>
2319// CHECK: <array>
2320// CHECK: <dict>
2321// CHECK: <key>line</key><integer>83</integer>
2322// CHECK: <key>col</key><integer>5</integer>
2323// CHECK: <key>file</key><integer>0</integer>
2324// CHECK: </dict>
2325// CHECK: <dict>
2326// CHECK: <key>line</key><integer>83</integer>
2327// CHECK: <key>col</key><integer>5</integer>
2328// CHECK: <key>file</key><integer>0</integer>
2329// CHECK: </dict>
2330// CHECK: </array>
2331// CHECK: </dict>
2332// CHECK: </array>
2333// CHECK: </dict>
2334// CHECK: <dict>
2335// CHECK: <key>kind</key><string>control</string>
2336// CHECK: <key>edges</key>
2337// CHECK: <array>
2338// CHECK: <dict>
2339// CHECK: <key>start</key>
2340// CHECK: <array>
2341// CHECK: <dict>
2342// CHECK: <key>line</key><integer>83</integer>
2343// CHECK: <key>col</key><integer>5</integer>
2344// CHECK: <key>file</key><integer>0</integer>
2345// CHECK: </dict>
2346// CHECK: <dict>
2347// CHECK: <key>line</key><integer>83</integer>
2348// CHECK: <key>col</key><integer>5</integer>
2349// CHECK: <key>file</key><integer>0</integer>
2350// CHECK: </dict>
2351// CHECK: </array>
2352// CHECK: <key>end</key>
2353// CHECK: <array>
2354// CHECK: <dict>
2355// CHECK: <key>line</key><integer>83</integer>
2356// CHECK: <key>col</key><integer>19</integer>
2357// CHECK: <key>file</key><integer>0</integer>
2358// CHECK: </dict>
2359// CHECK: <dict>
2360// CHECK: <key>line</key><integer>83</integer>
2361// CHECK: <key>col</key><integer>28</integer>
2362// CHECK: <key>file</key><integer>0</integer>
2363// CHECK: </dict>
2364// CHECK: </array>
2365// CHECK: </dict>
2366// CHECK: </array>
2367// CHECK: </dict>
2368// CHECK: <dict>
2369// CHECK: <key>kind</key><string>event</string>
2370// CHECK: <key>location</key>
2371// CHECK: <dict>
2372// CHECK: <key>line</key><integer>83</integer>
2373// CHECK: <key>col</key><integer>19</integer>
2374// CHECK: <key>file</key><integer>0</integer>
2375// CHECK: </dict>
2376// CHECK: <key>ranges</key>
2377// CHECK: <array>
2378// CHECK: <array>
2379// CHECK: <dict>
2380// CHECK: <key>line</key><integer>83</integer>
2381// CHECK: <key>col</key><integer>19</integer>
2382// CHECK: <key>file</key><integer>0</integer>
2383// CHECK: </dict>
2384// CHECK: <dict>
2385// CHECK: <key>line</key><integer>83</integer>
2386// CHECK: <key>col</key><integer>28</integer>
2387// CHECK: <key>file</key><integer>0</integer>
2388// CHECK: </dict>
2389// CHECK: </array>
2390// CHECK: </array>
2391// CHECK: <key>depth</key><integer>1</integer>
2392// CHECK: <key>extended_message</key>
2393// CHECK: <string>Memory is allocated</string>
2394// CHECK: <key>message</key>
2395// CHECK: <string>Memory is allocated</string>
2396// CHECK: </dict>
2397// CHECK: <dict>
2398// CHECK: <key>kind</key><string>event</string>
2399// CHECK: <key>location</key>
2400// CHECK: <dict>
2401// CHECK: <key>line</key><integer>87</integer>
2402// CHECK: <key>col</key><integer>9</integer>
2403// CHECK: <key>file</key><integer>0</integer>
2404// CHECK: </dict>
2405// CHECK: <key>ranges</key>
2406// CHECK: <array>
2407// CHECK: <array>
2408// CHECK: <dict>
2409// CHECK: <key>line</key><integer>87</integer>
2410// CHECK: <key>col</key><integer>9</integer>
2411// CHECK: <key>file</key><integer>0</integer>
2412// CHECK: </dict>
2413// CHECK: <dict>
2414// CHECK: <key>line</key><integer>87</integer>
2415// CHECK: <key>col</key><integer>28</integer>
2416// CHECK: <key>file</key><integer>0</integer>
2417// CHECK: </dict>
2418// CHECK: </array>
2419// CHECK: </array>
2420// CHECK: <key>depth</key><integer>1</integer>
2421// CHECK: <key>extended_message</key>
2422// CHECK: <string>Returning from &apos;malloc_wrapper_ret&apos;; allocated memory returned</string>
2423// CHECK: <key>message</key>
2424// CHECK: <string>Returning from &apos;malloc_wrapper_ret&apos;; allocated memory returned</string>
2425// CHECK: </dict>
2426// CHECK: <dict>
2427// CHECK: <key>kind</key><string>control</string>
2428// CHECK: <key>edges</key>
2429// CHECK: <array>
2430// CHECK: <dict>
2431// CHECK: <key>start</key>
2432// CHECK: <array>
2433// CHECK: <dict>
2434// CHECK: <key>line</key><integer>87</integer>
2435// CHECK: <key>col</key><integer>9</integer>
2436// CHECK: <key>file</key><integer>0</integer>
2437// CHECK: </dict>
2438// CHECK: <dict>
2439// CHECK: <key>line</key><integer>87</integer>
2440// CHECK: <key>col</key><integer>28</integer>
2441// CHECK: <key>file</key><integer>0</integer>
2442// CHECK: </dict>
2443// CHECK: </array>
2444// CHECK: <key>end</key>
2445// CHECK: <array>
2446// CHECK: <dict>
2447// CHECK: <key>line</key><integer>88</integer>
2448// CHECK: <key>col</key><integer>1</integer>
2449// CHECK: <key>file</key><integer>0</integer>
2450// CHECK: </dict>
2451// CHECK: <dict>
2452// CHECK: <key>line</key><integer>88</integer>
2453// CHECK: <key>col</key><integer>1</integer>
2454// CHECK: <key>file</key><integer>0</integer>
2455// CHECK: </dict>
2456// CHECK: </array>
2457// CHECK: </dict>
2458// CHECK: </array>
2459// CHECK: </dict>
2460// CHECK: <dict>
2461// CHECK: <key>kind</key><string>event</string>
2462// CHECK: <key>location</key>
2463// CHECK: <dict>
2464// CHECK: <key>line</key><integer>88</integer>
2465// CHECK: <key>col</key><integer>1</integer>
2466// CHECK: <key>file</key><integer>0</integer>
2467// CHECK: </dict>
2468// CHECK: <key>depth</key><integer>0</integer>
2469// CHECK: <key>extended_message</key>
2470// CHECK: <string>Memory is never released; potential memory leak</string>
2471// CHECK: <key>message</key>
2472// CHECK: <string>Memory is never released; potential memory leak</string>
2473// CHECK: </dict>
2474// CHECK: </array>
2475// CHECK: <key>description</key><string>Memory is never released; potential memory leak</string>
2476// CHECK: <key>category</key><string>Memory Error</string>
2477// CHECK: <key>type</key><string>Memory leak</string>
2478// CHECK: <key>location</key>
2479// CHECK: <dict>
2480// CHECK: <key>line</key><integer>88</integer>
2481// CHECK: <key>col</key><integer>1</integer>
2482// CHECK: <key>file</key><integer>0</integer>
2483// CHECK: </dict>
2484// CHECK: </dict>
Ted Kremenek11e35b62012-03-15 22:00:28 +00002485// CHECK: </array>
2486// CHECK: </dict>
2487// CHECK: </plist>