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