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