[analyzer] Allow checkers to supply call stack diagnostic hints for the
BugVisitor DiagnosticPieces.

When checkers create a DiagnosticPieceEvent, they can supply an extra
string, which will be concatenated with the call exit message for every
call on the stack between the diagnostic event and the final bug report.
(This is a simple version, which could be/will be further enhanced.)

For example, this is used in Malloc checker to produce the ",
which allocated memory" in the following example:

static char *malloc_wrapper() { // 2. Entered call from 'use'
    return malloc(12);    // 3. Memory is allocated
}

void use() {
    char *v;
    v = malloc_wrapper(); // 1. Calling 'malloc_wrappers'
        // 4. Returning from 'malloc_wrapper', which allocated memory
}                         // 5. Memory is never released; potential
memory leak

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@152837 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/test/Analysis/malloc-plist.c b/test/Analysis/malloc-plist.c
index 154d756..71c071c 100644
--- a/test/Analysis/malloc-plist.c
+++ b/test/Analysis/malloc-plist.c
@@ -46,1097 +46,1638 @@
   (void) buf;
 }
 
-// CHECK: <?xml version="1.0" encoding="UTF-8"?>
-// CHECK: <plist version="1.0">
-// CHECK: <dict>
-// CHECK:  <key>files</key>
-// CHECK:  <array>
-// CHECK:  </array>
-// CHECK:  <key>diagnostics</key>
-// CHECK:  <array>
-// CHECK:   <dict>
-// CHECK:    <key>path</key>
-// CHECK:    <array>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>control</string>
-// CHECK:      <key>edges</key>
-// CHECK:       <array>
-// CHECK:        <dict>
-// CHECK:         <key>start</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>10</integer>
-// CHECK:            <key>col</key><integer>5</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>10</integer>
-// CHECK:            <key>col</key><integer>5</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:         <key>end</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>10</integer>
-// CHECK:            <key>col</key><integer>9</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>10</integer>
-// CHECK:            <key>col</key><integer>9</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:        </dict>
-// CHECK:       </array>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>control</string>
-// CHECK:      <key>edges</key>
-// CHECK:       <array>
-// CHECK:        <dict>
-// CHECK:         <key>start</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>10</integer>
-// CHECK:            <key>col</key><integer>9</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>10</integer>
-// CHECK:            <key>col</key><integer>9</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:         <key>end</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>11</integer>
-// CHECK:            <key>col</key><integer>9</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>11</integer>
-// CHECK:            <key>col</key><integer>9</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:        </dict>
-// CHECK:       </array>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>control</string>
-// CHECK:      <key>edges</key>
-// CHECK:       <array>
-// CHECK:        <dict>
-// CHECK:         <key>start</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>11</integer>
-// CHECK:            <key>col</key><integer>9</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>11</integer>
-// CHECK:            <key>col</key><integer>9</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:         <key>end</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>11</integer>
-// CHECK:            <key>col</key><integer>18</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>11</integer>
-// CHECK:            <key>col</key><integer>27</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:        </dict>
-// CHECK:       </array>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>event</string>
-// CHECK:      <key>location</key>
+// Test what happens when the same call frees and allocated memory.
+void my_free(void *x) {
+    free(x);
+}
+void my_malloc_and_free(void **x) {
+    *x = malloc(100);
+    if (*x)
+      my_free(*x);
+    return;
+}
+void *test_double_action_call() {
+    void *buf;
+    my_malloc_and_free(&buf);
+    return buf;
+}
+
+// CHECK:   <key>diagnostics</key>
+// CHECK:   <array>
+// CHECK:    <dict>
+// CHECK:     <key>path</key>
+// CHECK:     <array>
 // CHECK:      <dict>
-// CHECK:       <key>line</key><integer>11</integer>
-// CHECK:       <key>col</key><integer>18</integer>
-// CHECK:       <key>file</key><integer>0</integer>
-// CHECK:      </dict>
-// CHECK:      <key>ranges</key>
-// CHECK:      <array>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
 // CHECK:        <array>
 // CHECK:         <dict>
-// CHECK:          <key>line</key><integer>11</integer>
-// CHECK:          <key>col</key><integer>18</integer>
-// CHECK:          <key>file</key><integer>0</integer>
-// CHECK:         </dict>
-// CHECK:         <dict>
-// CHECK:          <key>line</key><integer>11</integer>
-// CHECK:          <key>col</key><integer>27</integer>
-// CHECK:          <key>file</key><integer>0</integer>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>10</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>10</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>10</integer>
+// CHECK:             <key>col</key><integer>9</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>10</integer>
+// CHECK:             <key>col</key><integer>9</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
 // CHECK:         </dict>
 // CHECK:        </array>
-// CHECK:      </array>
-// CHECK:      <key>extended_message</key>
-// CHECK:      <string>Memory is allocated</string>
-// CHECK:      <key>message</key>
-// CHECK: <string>Memory is allocated</string>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>control</string>
-// CHECK:      <key>edges</key>
-// CHECK:       <array>
-// CHECK:        <dict>
-// CHECK:         <key>start</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>11</integer>
-// CHECK:            <key>col</key><integer>18</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>11</integer>
-// CHECK:            <key>col</key><integer>27</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:         <key>end</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>14</integer>
-// CHECK:            <key>col</key><integer>5</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>14</integer>
-// CHECK:            <key>col</key><integer>6</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:        </dict>
-// CHECK:       </array>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>event</string>
-// CHECK:      <key>location</key>
-// CHECK:      <dict>
-// CHECK:       <key>line</key><integer>14</integer>
-// CHECK:       <key>col</key><integer>5</integer>
-// CHECK:       <key>file</key><integer>0</integer>
 // CHECK:      </dict>
-// CHECK:      <key>ranges</key>
-// CHECK:      <array>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
 // CHECK:        <array>
 // CHECK:         <dict>
-// CHECK:          <key>line</key><integer>14</integer>
-// CHECK:          <key>col</key><integer>5</integer>
-// CHECK:          <key>file</key><integer>0</integer>
-// CHECK:         </dict>
-// CHECK:         <dict>
-// CHECK:          <key>line</key><integer>14</integer>
-// CHECK:          <key>col</key><integer>6</integer>
-// CHECK:          <key>file</key><integer>0</integer>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>10</integer>
+// CHECK:             <key>col</key><integer>9</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>10</integer>
+// CHECK:             <key>col</key><integer>9</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>11</integer>
+// CHECK:             <key>col</key><integer>9</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>11</integer>
+// CHECK:             <key>col</key><integer>9</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
 // CHECK:         </dict>
 // CHECK:        </array>
-// CHECK:      </array>
-// CHECK:      <key>extended_message</key>
-// CHECK:      <string>Memory is never released; potential memory leak</string>
-// CHECK:      <key>message</key>
-// CHECK: <string>Memory is never released; potential memory leak</string>
-// CHECK:     </dict>
-// CHECK:    </array>
-// CHECK:    <key>description</key><string>Memory is never released; potential memory leak</string>
-// CHECK:    <key>category</key><string>Memory Error</string>
-// CHECK:    <key>type</key><string>Memory leak</string>
-// CHECK:   <key>location</key>
-// CHECK:   <dict>
-// CHECK:    <key>line</key><integer>14</integer>
-// CHECK:    <key>col</key><integer>5</integer>
-// CHECK:    <key>file</key><integer>0</integer>
-// CHECK:   </dict>
-// CHECK:   </dict>
-// CHECK:   <dict>
-// CHECK:    <key>path</key>
-// CHECK:    <array>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>control</string>
-// CHECK:      <key>edges</key>
-// CHECK:       <array>
-// CHECK:        <dict>
-// CHECK:         <key>start</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>18</integer>
-// CHECK:            <key>col</key><integer>5</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>18</integer>
-// CHECK:            <key>col</key><integer>5</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:         <key>end</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>19</integer>
-// CHECK:            <key>col</key><integer>5</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>19</integer>
-// CHECK:            <key>col</key><integer>5</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:        </dict>
-// CHECK:       </array>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>control</string>
-// CHECK:      <key>edges</key>
-// CHECK:       <array>
-// CHECK:        <dict>
-// CHECK:         <key>start</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>19</integer>
-// CHECK:            <key>col</key><integer>5</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>19</integer>
-// CHECK:            <key>col</key><integer>5</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:         <key>end</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>19</integer>
-// CHECK:            <key>col</key><integer>9</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>19</integer>
-// CHECK:            <key>col</key><integer>30</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:        </dict>
-// CHECK:       </array>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>event</string>
-// CHECK:      <key>location</key>
-// CHECK:      <dict>
-// CHECK:       <key>line</key><integer>19</integer>
-// CHECK:       <key>col</key><integer>9</integer>
-// CHECK:       <key>file</key><integer>0</integer>
 // CHECK:      </dict>
-// CHECK:      <key>ranges</key>
-// CHECK:      <array>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
 // CHECK:        <array>
 // CHECK:         <dict>
-// CHECK:          <key>line</key><integer>19</integer>
-// CHECK:          <key>col</key><integer>9</integer>
-// CHECK:          <key>file</key><integer>0</integer>
-// CHECK:         </dict>
-// CHECK:         <dict>
-// CHECK:          <key>line</key><integer>19</integer>
-// CHECK:          <key>col</key><integer>30</integer>
-// CHECK:          <key>file</key><integer>0</integer>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>11</integer>
+// CHECK:             <key>col</key><integer>9</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>11</integer>
+// CHECK:             <key>col</key><integer>9</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>11</integer>
+// CHECK:             <key>col</key><integer>18</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>11</integer>
+// CHECK:             <key>col</key><integer>27</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
 // CHECK:         </dict>
 // CHECK:        </array>
-// CHECK:      </array>
-// CHECK:      <key>extended_message</key>
-// CHECK:      <string>Memory is allocated</string>
-// CHECK:      <key>message</key>
-// CHECK: <string>Memory is allocated</string>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>control</string>
-// CHECK:      <key>edges</key>
-// CHECK:       <array>
-// CHECK:        <dict>
-// CHECK:         <key>start</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>19</integer>
-// CHECK:            <key>col</key><integer>9</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>19</integer>
-// CHECK:            <key>col</key><integer>30</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:         <key>end</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>21</integer>
-// CHECK:            <key>col</key><integer>1</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>21</integer>
-// CHECK:            <key>col</key><integer>1</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:        </dict>
-// CHECK:       </array>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>event</string>
-// CHECK:      <key>location</key>
-// CHECK:      <dict>
-// CHECK:       <key>line</key><integer>21</integer>
-// CHECK:       <key>col</key><integer>1</integer>
-// CHECK:       <key>file</key><integer>0</integer>
 // CHECK:      </dict>
-// CHECK:      <key>extended_message</key>
-// CHECK:      <string>Memory is never released; potential memory leak</string>
-// CHECK:      <key>message</key>
-// CHECK: <string>Memory is never released; potential memory leak</string>
-// CHECK:     </dict>
-// CHECK:    </array>
-// CHECK:    <key>description</key><string>Memory is never released; potential memory leak</string>
-// CHECK:    <key>category</key><string>Memory Error</string>
-// CHECK:    <key>type</key><string>Memory leak</string>
-// CHECK:   <key>location</key>
-// CHECK:   <dict>
-// CHECK:    <key>line</key><integer>21</integer>
-// CHECK:    <key>col</key><integer>1</integer>
-// CHECK:    <key>file</key><integer>0</integer>
-// CHECK:   </dict>
-// CHECK:   </dict>
-// CHECK:   <dict>
-// CHECK:    <key>path</key>
-// CHECK:    <array>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>control</string>
-// CHECK:      <key>edges</key>
-// CHECK:       <array>
-// CHECK:        <dict>
-// CHECK:         <key>start</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>24</integer>
-// CHECK:            <key>col</key><integer>5</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>24</integer>
-// CHECK:            <key>col</key><integer>5</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:         <key>end</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>24</integer>
-// CHECK:            <key>col</key><integer>18</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>24</integer>
-// CHECK:            <key>col</key><integer>28</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:        </dict>
-// CHECK:       </array>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>event</string>
-// CHECK:      <key>location</key>
 // CHECK:      <dict>
-// CHECK:       <key>line</key><integer>24</integer>
-// CHECK:       <key>col</key><integer>18</integer>
-// CHECK:       <key>file</key><integer>0</integer>
+// CHECK:       <key>kind</key><string>event</string>
+// CHECK:       <key>location</key>
+// CHECK:       <dict>
+// CHECK:        <key>line</key><integer>11</integer>
+// CHECK:        <key>col</key><integer>18</integer>
+// CHECK:        <key>file</key><integer>0</integer>
+// CHECK:       </dict>
+// CHECK:       <key>ranges</key>
+// CHECK:       <array>
+// CHECK:         <array>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>11</integer>
+// CHECK:           <key>col</key><integer>18</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>11</integer>
+// CHECK:           <key>col</key><integer>27</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:         </array>
+// CHECK:       </array>
+// CHECK:       <key>depth</key><integer>0</integer>
+// CHECK:       <key>extended_message</key>
+// CHECK:       <string>Memory is allocated</string>
+// CHECK:       <key>message</key>
+// CHECK:  <string>Memory is allocated</string>
 // CHECK:      </dict>
-// CHECK:      <key>ranges</key>
-// CHECK:      <array>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
 // CHECK:        <array>
 // CHECK:         <dict>
-// CHECK:          <key>line</key><integer>24</integer>
-// CHECK:          <key>col</key><integer>18</integer>
-// CHECK:          <key>file</key><integer>0</integer>
-// CHECK:         </dict>
-// CHECK:         <dict>
-// CHECK:          <key>line</key><integer>24</integer>
-// CHECK:          <key>col</key><integer>28</integer>
-// CHECK:          <key>file</key><integer>0</integer>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>11</integer>
+// CHECK:             <key>col</key><integer>18</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>11</integer>
+// CHECK:             <key>col</key><integer>27</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>14</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>14</integer>
+// CHECK:             <key>col</key><integer>6</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
 // CHECK:         </dict>
 // CHECK:        </array>
-// CHECK:      </array>
-// CHECK:      <key>extended_message</key>
-// CHECK:      <string>Memory is allocated</string>
-// CHECK:      <key>message</key>
-// CHECK: <string>Memory is allocated</string>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>control</string>
-// CHECK:      <key>edges</key>
-// CHECK:       <array>
-// CHECK:        <dict>
-// CHECK:         <key>start</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>24</integer>
-// CHECK:            <key>col</key><integer>18</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>24</integer>
-// CHECK:            <key>col</key><integer>28</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:         <key>end</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>26</integer>
-// CHECK:            <key>col</key><integer>5</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>26</integer>
-// CHECK:            <key>col</key><integer>5</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:        </dict>
-// CHECK:       </array>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>control</string>
-// CHECK:      <key>edges</key>
-// CHECK:       <array>
-// CHECK:        <dict>
-// CHECK:         <key>start</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>26</integer>
-// CHECK:            <key>col</key><integer>5</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>26</integer>
-// CHECK:            <key>col</key><integer>5</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:         <key>end</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>26</integer>
-// CHECK:            <key>col</key><integer>18</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>26</integer>
-// CHECK:            <key>col</key><integer>40</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:        </dict>
-// CHECK:       </array>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>event</string>
-// CHECK:      <key>location</key>
-// CHECK:      <dict>
-// CHECK:       <key>line</key><integer>26</integer>
-// CHECK:       <key>col</key><integer>18</integer>
-// CHECK:       <key>file</key><integer>0</integer>
 // CHECK:      </dict>
-// CHECK:      <key>ranges</key>
-// CHECK:      <array>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>event</string>
+// CHECK:       <key>location</key>
+// CHECK:       <dict>
+// CHECK:        <key>line</key><integer>14</integer>
+// CHECK:        <key>col</key><integer>5</integer>
+// CHECK:        <key>file</key><integer>0</integer>
+// CHECK:       </dict>
+// CHECK:       <key>ranges</key>
+// CHECK:       <array>
+// CHECK:         <array>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>14</integer>
+// CHECK:           <key>col</key><integer>5</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>14</integer>
+// CHECK:           <key>col</key><integer>6</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:         </array>
+// CHECK:       </array>
+// CHECK:       <key>depth</key><integer>0</integer>
+// CHECK:       <key>extended_message</key>
+// CHECK:       <string>Memory is never released; potential memory leak</string>
+// CHECK:       <key>message</key>
+// CHECK:  <string>Memory is never released; potential memory leak</string>
+// CHECK:      </dict>
+// CHECK:     </array>
+// CHECK:     <key>description</key><string>Memory is never released; potential memory leak</string>
+// CHECK:     <key>category</key><string>Memory Error</string>
+// CHECK:     <key>type</key><string>Memory leak</string>
+// CHECK:    <key>location</key>
+// CHECK:    <dict>
+// CHECK:     <key>line</key><integer>14</integer>
+// CHECK:     <key>col</key><integer>5</integer>
+// CHECK:     <key>file</key><integer>0</integer>
+// CHECK:    </dict>
+// CHECK:    </dict>
+// CHECK:    <dict>
+// CHECK:     <key>path</key>
+// CHECK:     <array>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
 // CHECK:        <array>
 // CHECK:         <dict>
-// CHECK:          <key>line</key><integer>26</integer>
-// CHECK:          <key>col</key><integer>18</integer>
-// CHECK:          <key>file</key><integer>0</integer>
-// CHECK:         </dict>
-// CHECK:         <dict>
-// CHECK:          <key>line</key><integer>26</integer>
-// CHECK:          <key>col</key><integer>40</integer>
-// CHECK:          <key>file</key><integer>0</integer>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>18</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>18</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>19</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>19</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
 // CHECK:         </dict>
 // CHECK:        </array>
-// CHECK:      </array>
-// CHECK:      <key>extended_message</key>
-// CHECK:      <string>Attempt to reallocate memory</string>
-// CHECK:      <key>message</key>
-// CHECK: <string>Attempt to reallocate memory</string>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>control</string>
-// CHECK:      <key>edges</key>
-// CHECK:       <array>
-// CHECK:        <dict>
-// CHECK:         <key>start</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>26</integer>
-// CHECK:            <key>col</key><integer>18</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>26</integer>
-// CHECK:            <key>col</key><integer>40</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:         <key>end</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>29</integer>
-// CHECK:            <key>col</key><integer>5</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>29</integer>
-// CHECK:            <key>col</key><integer>6</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:        </dict>
-// CHECK:       </array>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>event</string>
-// CHECK:      <key>location</key>
-// CHECK:      <dict>
-// CHECK:       <key>line</key><integer>29</integer>
-// CHECK:       <key>col</key><integer>5</integer>
-// CHECK:       <key>file</key><integer>0</integer>
 // CHECK:      </dict>
-// CHECK:      <key>ranges</key>
-// CHECK:      <array>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
 // CHECK:        <array>
 // CHECK:         <dict>
-// CHECK:          <key>line</key><integer>29</integer>
-// CHECK:          <key>col</key><integer>5</integer>
-// CHECK:          <key>file</key><integer>0</integer>
-// CHECK:         </dict>
-// CHECK:         <dict>
-// CHECK:          <key>line</key><integer>29</integer>
-// CHECK:          <key>col</key><integer>6</integer>
-// CHECK:          <key>file</key><integer>0</integer>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>19</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>19</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>19</integer>
+// CHECK:             <key>col</key><integer>9</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>19</integer>
+// CHECK:             <key>col</key><integer>30</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
 // CHECK:         </dict>
 // CHECK:        </array>
-// CHECK:      </array>
-// CHECK:      <key>extended_message</key>
-// CHECK:      <string>Reallocation failed</string>
-// CHECK:      <key>message</key>
-// CHECK: <string>Reallocation failed</string>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>control</string>
-// CHECK:      <key>edges</key>
-// CHECK:       <array>
-// CHECK:        <dict>
-// CHECK:         <key>start</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>29</integer>
-// CHECK:            <key>col</key><integer>5</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>29</integer>
-// CHECK:            <key>col</key><integer>6</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:         <key>end</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>29</integer>
-// CHECK:            <key>col</key><integer>9</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>29</integer>
-// CHECK:            <key>col</key><integer>12</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:        </dict>
-// CHECK:       </array>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>control</string>
-// CHECK:      <key>edges</key>
-// CHECK:       <array>
-// CHECK:        <dict>
-// CHECK:         <key>start</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>29</integer>
-// CHECK:            <key>col</key><integer>9</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>29</integer>
-// CHECK:            <key>col</key><integer>12</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:         <key>end</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>30</integer>
-// CHECK:            <key>col</key><integer>9</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>30</integer>
-// CHECK:            <key>col</key><integer>14</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:        </dict>
-// CHECK:       </array>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>event</string>
-// CHECK:      <key>location</key>
-// CHECK:      <dict>
-// CHECK:       <key>line</key><integer>30</integer>
-// CHECK:       <key>col</key><integer>9</integer>
-// CHECK:       <key>file</key><integer>0</integer>
 // CHECK:      </dict>
-// CHECK:      <key>ranges</key>
-// CHECK:      <array>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>event</string>
+// CHECK:       <key>location</key>
+// CHECK:       <dict>
+// CHECK:        <key>line</key><integer>19</integer>
+// CHECK:        <key>col</key><integer>9</integer>
+// CHECK:        <key>file</key><integer>0</integer>
+// CHECK:       </dict>
+// CHECK:       <key>ranges</key>
+// CHECK:       <array>
+// CHECK:         <array>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>19</integer>
+// CHECK:           <key>col</key><integer>9</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>19</integer>
+// CHECK:           <key>col</key><integer>30</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:         </array>
+// CHECK:       </array>
+// CHECK:       <key>depth</key><integer>0</integer>
+// CHECK:       <key>extended_message</key>
+// CHECK:       <string>Memory is allocated</string>
+// CHECK:       <key>message</key>
+// CHECK:  <string>Memory is allocated</string>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
 // CHECK:        <array>
 // CHECK:         <dict>
-// CHECK:          <key>line</key><integer>30</integer>
-// CHECK:          <key>col</key><integer>9</integer>
-// CHECK:          <key>file</key><integer>0</integer>
-// CHECK:         </dict>
-// CHECK:         <dict>
-// CHECK:          <key>line</key><integer>30</integer>
-// CHECK:          <key>col</key><integer>14</integer>
-// CHECK:          <key>file</key><integer>0</integer>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>19</integer>
+// CHECK:             <key>col</key><integer>9</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>19</integer>
+// CHECK:             <key>col</key><integer>30</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>21</integer>
+// CHECK:             <key>col</key><integer>1</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>21</integer>
+// CHECK:             <key>col</key><integer>1</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
 // CHECK:         </dict>
 // CHECK:        </array>
-// CHECK:      </array>
-// CHECK:      <key>extended_message</key>
-// CHECK:      <string>Memory is never released; potential memory leak</string>
-// CHECK:      <key>message</key>
-// CHECK: <string>Memory is never released; potential memory leak</string>
-// CHECK:     </dict>
-// CHECK:    </array>
-// CHECK:    <key>description</key><string>Memory is never released; potential memory leak</string>
-// CHECK:    <key>category</key><string>Memory Error</string>
-// CHECK:    <key>type</key><string>Memory leak</string>
-// CHECK:   <key>location</key>
-// CHECK:   <dict>
-// CHECK:    <key>line</key><integer>30</integer>
-// CHECK:    <key>col</key><integer>9</integer>
-// CHECK:    <key>file</key><integer>0</integer>
-// CHECK:   </dict>
-// CHECK:   </dict>
-// CHECK:   <dict>
-// CHECK:    <key>path</key>
-// CHECK:    <array>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>control</string>
-// CHECK:      <key>edges</key>
-// CHECK:       <array>
-// CHECK:        <dict>
-// CHECK:         <key>start</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>45</integer>
-// CHECK:            <key>col</key><integer>3</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>45</integer>
-// CHECK:            <key>col</key><integer>3</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:         <key>end</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>45</integer>
-// CHECK:            <key>col</key><integer>15</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>45</integer>
-// CHECK:            <key>col</key><integer>15</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:        </dict>
-// CHECK:       </array>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>event</string>
-// CHECK:      <key>location</key>
-// CHECK:      <dict>
-// CHECK:       <key>line</key><integer>45</integer>
-// CHECK:       <key>col</key><integer>15</integer>
-// CHECK:       <key>file</key><integer>0</integer>
 // CHECK:      </dict>
-// CHECK:      <key>ranges</key>
-// CHECK:      <array>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>event</string>
+// CHECK:       <key>location</key>
+// CHECK:       <dict>
+// CHECK:        <key>line</key><integer>21</integer>
+// CHECK:        <key>col</key><integer>1</integer>
+// CHECK:        <key>file</key><integer>0</integer>
+// CHECK:       </dict>
+// CHECK:       <key>depth</key><integer>0</integer>
+// CHECK:       <key>extended_message</key>
+// CHECK:       <string>Memory is never released; potential memory leak</string>
+// CHECK:       <key>message</key>
+// CHECK:  <string>Memory is never released; potential memory leak</string>
+// CHECK:      </dict>
+// CHECK:     </array>
+// CHECK:     <key>description</key><string>Memory is never released; potential memory leak</string>
+// CHECK:     <key>category</key><string>Memory Error</string>
+// CHECK:     <key>type</key><string>Memory leak</string>
+// CHECK:    <key>location</key>
+// CHECK:    <dict>
+// CHECK:     <key>line</key><integer>21</integer>
+// CHECK:     <key>col</key><integer>1</integer>
+// CHECK:     <key>file</key><integer>0</integer>
+// CHECK:    </dict>
+// CHECK:    </dict>
+// CHECK:    <dict>
+// CHECK:     <key>path</key>
+// CHECK:     <array>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
 // CHECK:        <array>
 // CHECK:         <dict>
-// CHECK:          <key>line</key><integer>45</integer>
-// CHECK:          <key>col</key><integer>15</integer>
-// CHECK:          <key>file</key><integer>0</integer>
-// CHECK:         </dict>
-// CHECK:         <dict>
-// CHECK:          <key>line</key><integer>45</integer>
-// CHECK:          <key>col</key><integer>23</integer>
-// CHECK:          <key>file</key><integer>0</integer>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>24</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>24</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>24</integer>
+// CHECK:             <key>col</key><integer>18</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>24</integer>
+// CHECK:             <key>col</key><integer>28</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
 // CHECK:         </dict>
 // CHECK:        </array>
-// CHECK:      </array>
-// CHECK:      <key>extended_message</key>
-// CHECK:      <string>Calling &apos;wrapper&apos;</string>
-// CHECK:      <key>message</key>
-// CHECK: <string>Calling &apos;wrapper&apos;</string>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>event</string>
-// CHECK:      <key>location</key>
-// CHECK:      <dict>
-// CHECK:       <key>line</key><integer>36</integer>
-// CHECK:       <key>col</key><integer>1</integer>
-// CHECK:       <key>file</key><integer>0</integer>
 // CHECK:      </dict>
-// CHECK:      <key>extended_message</key>
-// CHECK:      <string>Entered call from &apos;test_wrapper&apos;</string>
-// CHECK:      <key>message</key>
-// CHECK: <string>Entered call from &apos;test_wrapper&apos;</string>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>control</string>
-// CHECK:      <key>edges</key>
-// CHECK:       <array>
-// CHECK:        <dict>
-// CHECK:         <key>start</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>36</integer>
-// CHECK:            <key>col</key><integer>1</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>36</integer>
-// CHECK:            <key>col</key><integer>1</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:         <key>end</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>37</integer>
-// CHECK:            <key>col</key><integer>3</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>37</integer>
-// CHECK:            <key>col</key><integer>3</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:        </dict>
-// CHECK:       </array>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>control</string>
-// CHECK:      <key>edges</key>
-// CHECK:       <array>
-// CHECK:        <dict>
-// CHECK:         <key>start</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>37</integer>
-// CHECK:            <key>col</key><integer>3</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>37</integer>
-// CHECK:            <key>col</key><integer>3</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:         <key>end</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>37</integer>
-// CHECK:            <key>col</key><integer>13</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>37</integer>
-// CHECK:            <key>col</key><integer>23</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:        </dict>
-// CHECK:       </array>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>event</string>
-// CHECK:      <key>location</key>
 // CHECK:      <dict>
-// CHECK:       <key>line</key><integer>37</integer>
-// CHECK:       <key>col</key><integer>13</integer>
-// CHECK:       <key>file</key><integer>0</integer>
+// CHECK:       <key>kind</key><string>event</string>
+// CHECK:       <key>location</key>
+// CHECK:       <dict>
+// CHECK:        <key>line</key><integer>24</integer>
+// CHECK:        <key>col</key><integer>18</integer>
+// CHECK:        <key>file</key><integer>0</integer>
+// CHECK:       </dict>
+// CHECK:       <key>ranges</key>
+// CHECK:       <array>
+// CHECK:         <array>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>24</integer>
+// CHECK:           <key>col</key><integer>18</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>24</integer>
+// CHECK:           <key>col</key><integer>28</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:         </array>
+// CHECK:       </array>
+// CHECK:       <key>depth</key><integer>0</integer>
+// CHECK:       <key>extended_message</key>
+// CHECK:       <string>Memory is allocated</string>
+// CHECK:       <key>message</key>
+// CHECK:  <string>Memory is allocated</string>
 // CHECK:      </dict>
-// CHECK:      <key>ranges</key>
-// CHECK:      <array>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
 // CHECK:        <array>
 // CHECK:         <dict>
-// CHECK:          <key>line</key><integer>37</integer>
-// CHECK:          <key>col</key><integer>13</integer>
-// CHECK:          <key>file</key><integer>0</integer>
-// CHECK:         </dict>
-// CHECK:         <dict>
-// CHECK:          <key>line</key><integer>37</integer>
-// CHECK:          <key>col</key><integer>23</integer>
-// CHECK:          <key>file</key><integer>0</integer>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>24</integer>
+// CHECK:             <key>col</key><integer>18</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>24</integer>
+// CHECK:             <key>col</key><integer>28</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>26</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>26</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
 // CHECK:         </dict>
 // CHECK:        </array>
-// CHECK:      </array>
-// CHECK:      <key>extended_message</key>
-// CHECK:      <string>Memory is allocated</string>
-// CHECK:      <key>message</key>
-// CHECK: <string>Memory is allocated</string>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>control</string>
-// CHECK:      <key>edges</key>
-// CHECK:       <array>
-// CHECK:        <dict>
-// CHECK:         <key>start</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>37</integer>
-// CHECK:            <key>col</key><integer>13</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>37</integer>
-// CHECK:            <key>col</key><integer>23</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:         <key>end</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>39</integer>
-// CHECK:            <key>col</key><integer>3</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>39</integer>
-// CHECK:            <key>col</key><integer>3</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:        </dict>
-// CHECK:       </array>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>control</string>
-// CHECK:      <key>edges</key>
-// CHECK:       <array>
-// CHECK:        <dict>
-// CHECK:         <key>start</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>39</integer>
-// CHECK:            <key>col</key><integer>3</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>39</integer>
-// CHECK:            <key>col</key><integer>3</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:         <key>end</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>39</integer>
-// CHECK:            <key>col</key><integer>7</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>39</integer>
-// CHECK:            <key>col</key><integer>7</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:        </dict>
-// CHECK:       </array>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>event</string>
-// CHECK:      <key>location</key>
-// CHECK:      <dict>
-// CHECK:       <key>line</key><integer>39</integer>
-// CHECK:       <key>col</key><integer>7</integer>
-// CHECK:       <key>file</key><integer>0</integer>
 // CHECK:      </dict>
-// CHECK:      <key>ranges</key>
-// CHECK:      <array>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
 // CHECK:        <array>
 // CHECK:         <dict>
-// CHECK:          <key>line</key><integer>39</integer>
-// CHECK:          <key>col</key><integer>7</integer>
-// CHECK:          <key>file</key><integer>0</integer>
-// CHECK:         </dict>
-// CHECK:         <dict>
-// CHECK:          <key>line</key><integer>39</integer>
-// CHECK:          <key>col</key><integer>7</integer>
-// CHECK:          <key>file</key><integer>0</integer>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>26</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>26</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>26</integer>
+// CHECK:             <key>col</key><integer>18</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>26</integer>
+// CHECK:             <key>col</key><integer>40</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
 // CHECK:         </dict>
 // CHECK:        </array>
-// CHECK:      </array>
-// CHECK:      <key>extended_message</key>
-// CHECK:      <string>Assuming &apos;x&apos; is non-null</string>
-// CHECK:      <key>message</key>
-// CHECK: <string>Assuming &apos;x&apos; is non-null</string>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>control</string>
-// CHECK:      <key>edges</key>
-// CHECK:       <array>
-// CHECK:        <dict>
-// CHECK:         <key>start</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>39</integer>
-// CHECK:            <key>col</key><integer>7</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>39</integer>
-// CHECK:            <key>col</key><integer>7</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:         <key>end</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>40</integer>
-// CHECK:            <key>col</key><integer>5</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>40</integer>
-// CHECK:            <key>col</key><integer>5</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:        </dict>
-// CHECK:       </array>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>event</string>
-// CHECK:      <key>location</key>
-// CHECK:      <dict>
-// CHECK:       <key>line</key><integer>45</integer>
-// CHECK:       <key>col</key><integer>15</integer>
-// CHECK:       <key>file</key><integer>0</integer>
 // CHECK:      </dict>
-// CHECK:      <key>ranges</key>
-// CHECK:      <array>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>event</string>
+// CHECK:       <key>location</key>
+// CHECK:       <dict>
+// CHECK:        <key>line</key><integer>26</integer>
+// CHECK:        <key>col</key><integer>18</integer>
+// CHECK:        <key>file</key><integer>0</integer>
+// CHECK:       </dict>
+// CHECK:       <key>ranges</key>
+// CHECK:       <array>
+// CHECK:         <array>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>26</integer>
+// CHECK:           <key>col</key><integer>18</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>26</integer>
+// CHECK:           <key>col</key><integer>40</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:         </array>
+// CHECK:       </array>
+// CHECK:       <key>depth</key><integer>0</integer>
+// CHECK:       <key>extended_message</key>
+// CHECK:       <string>Attempt to reallocate memory</string>
+// CHECK:       <key>message</key>
+// CHECK:  <string>Attempt to reallocate memory</string>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
 // CHECK:        <array>
 // CHECK:         <dict>
-// CHECK:          <key>line</key><integer>45</integer>
-// CHECK:          <key>col</key><integer>15</integer>
-// CHECK:          <key>file</key><integer>0</integer>
-// CHECK:         </dict>
-// CHECK:         <dict>
-// CHECK:          <key>line</key><integer>45</integer>
-// CHECK:          <key>col</key><integer>23</integer>
-// CHECK:          <key>file</key><integer>0</integer>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>26</integer>
+// CHECK:             <key>col</key><integer>18</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>26</integer>
+// CHECK:             <key>col</key><integer>40</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>29</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>29</integer>
+// CHECK:             <key>col</key><integer>6</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
 // CHECK:         </dict>
 // CHECK:        </array>
-// CHECK:      </array>
-// CHECK:      <key>extended_message</key>
-// CHECK:      <string>Returning from &apos;wrapper&apos;</string>
-// CHECK:      <key>message</key>
-// CHECK: <string>Returning from &apos;wrapper&apos;</string>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>control</string>
-// CHECK:      <key>edges</key>
-// CHECK:       <array>
-// CHECK:        <dict>
-// CHECK:         <key>start</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>45</integer>
-// CHECK:            <key>col</key><integer>15</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>45</integer>
-// CHECK:            <key>col</key><integer>23</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:         <key>end</key>
-// CHECK:          <array>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>47</integer>
-// CHECK:            <key>col</key><integer>1</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:           <dict>
-// CHECK:            <key>line</key><integer>47</integer>
-// CHECK:            <key>col</key><integer>1</integer>
-// CHECK:            <key>file</key><integer>0</integer>
-// CHECK:           </dict>
-// CHECK:          </array>
-// CHECK:        </dict>
-// CHECK:       </array>
-// CHECK:     </dict>
-// CHECK:     <dict>
-// CHECK:      <key>kind</key><string>event</string>
-// CHECK:      <key>location</key>
-// CHECK:      <dict>
-// CHECK:       <key>line</key><integer>47</integer>
-// CHECK:       <key>col</key><integer>1</integer>
-// CHECK:       <key>file</key><integer>0</integer>
 // CHECK:      </dict>
-// CHECK:      <key>extended_message</key>
-// CHECK:      <string>Memory is never released; potential memory leak</string>
-// CHECK:      <key>message</key>
-// CHECK: <string>Memory is never released; potential memory leak</string>
-// CHECK:     </dict>
-// CHECK:    </array>
-// CHECK:    <key>description</key><string>Memory is never released; potential memory leak</string>
-// CHECK:    <key>category</key><string>Memory Error</string>
-// CHECK:    <key>type</key><string>Memory leak</string>
-// CHECK:   <key>location</key>
-// CHECK:   <dict>
-// CHECK:    <key>line</key><integer>47</integer>
-// CHECK:    <key>col</key><integer>1</integer>
-// CHECK:    <key>file</key><integer>0</integer>
-// CHECK:   </dict>
-// CHECK:   </dict>
-// CHECK:  </array>
-// CHECK: </dict>
-// CHECK: </plist>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>event</string>
+// CHECK:       <key>location</key>
+// CHECK:       <dict>
+// CHECK:        <key>line</key><integer>29</integer>
+// CHECK:        <key>col</key><integer>5</integer>
+// CHECK:        <key>file</key><integer>0</integer>
+// CHECK:       </dict>
+// CHECK:       <key>ranges</key>
+// CHECK:       <array>
+// CHECK:         <array>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>29</integer>
+// CHECK:           <key>col</key><integer>5</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>29</integer>
+// CHECK:           <key>col</key><integer>6</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:         </array>
+// CHECK:       </array>
+// CHECK:       <key>depth</key><integer>0</integer>
+// CHECK:       <key>extended_message</key>
+// CHECK:       <string>Reallocation failed</string>
+// CHECK:       <key>message</key>
+// CHECK:  <string>Reallocation failed</string>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
+// CHECK:        <array>
+// CHECK:         <dict>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>29</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>29</integer>
+// CHECK:             <key>col</key><integer>6</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>29</integer>
+// CHECK:             <key>col</key><integer>9</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>29</integer>
+// CHECK:             <key>col</key><integer>12</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:         </dict>
+// CHECK:        </array>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
+// CHECK:        <array>
+// CHECK:         <dict>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>29</integer>
+// CHECK:             <key>col</key><integer>9</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>29</integer>
+// CHECK:             <key>col</key><integer>12</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>30</integer>
+// CHECK:             <key>col</key><integer>9</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>30</integer>
+// CHECK:             <key>col</key><integer>14</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:         </dict>
+// CHECK:        </array>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>event</string>
+// CHECK:       <key>location</key>
+// CHECK:       <dict>
+// CHECK:        <key>line</key><integer>30</integer>
+// CHECK:        <key>col</key><integer>9</integer>
+// CHECK:        <key>file</key><integer>0</integer>
+// CHECK:       </dict>
+// CHECK:       <key>ranges</key>
+// CHECK:       <array>
+// CHECK:         <array>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>30</integer>
+// CHECK:           <key>col</key><integer>9</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>30</integer>
+// CHECK:           <key>col</key><integer>14</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:         </array>
+// CHECK:       </array>
+// CHECK:       <key>depth</key><integer>0</integer>
+// CHECK:       <key>extended_message</key>
+// CHECK:       <string>Memory is never released; potential memory leak</string>
+// CHECK:       <key>message</key>
+// CHECK:  <string>Memory is never released; potential memory leak</string>
+// CHECK:      </dict>
+// CHECK:     </array>
+// CHECK:     <key>description</key><string>Memory is never released; potential memory leak</string>
+// CHECK:     <key>category</key><string>Memory Error</string>
+// CHECK:     <key>type</key><string>Memory leak</string>
+// CHECK:    <key>location</key>
+// CHECK:    <dict>
+// CHECK:     <key>line</key><integer>30</integer>
+// CHECK:     <key>col</key><integer>9</integer>
+// CHECK:     <key>file</key><integer>0</integer>
+// CHECK:    </dict>
+// CHECK:    </dict>
+// CHECK:    <dict>
+// CHECK:     <key>path</key>
+// CHECK:     <array>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
+// CHECK:        <array>
+// CHECK:         <dict>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>45</integer>
+// CHECK:             <key>col</key><integer>3</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>45</integer>
+// CHECK:             <key>col</key><integer>3</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>45</integer>
+// CHECK:             <key>col</key><integer>15</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>45</integer>
+// CHECK:             <key>col</key><integer>15</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:         </dict>
+// CHECK:        </array>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>event</string>
+// CHECK:       <key>location</key>
+// CHECK:       <dict>
+// CHECK:        <key>line</key><integer>45</integer>
+// CHECK:        <key>col</key><integer>15</integer>
+// CHECK:        <key>file</key><integer>0</integer>
+// CHECK:       </dict>
+// CHECK:       <key>ranges</key>
+// CHECK:       <array>
+// CHECK:         <array>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>45</integer>
+// CHECK:           <key>col</key><integer>15</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>45</integer>
+// CHECK:           <key>col</key><integer>23</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:         </array>
+// CHECK:       </array>
+// CHECK:       <key>depth</key><integer>0</integer>
+// CHECK:       <key>extended_message</key>
+// CHECK:       <string>Calling &apos;wrapper&apos;</string>
+// CHECK:       <key>message</key>
+// CHECK:  <string>Calling &apos;wrapper&apos;</string>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>event</string>
+// CHECK:       <key>location</key>
+// CHECK:       <dict>
+// CHECK:        <key>line</key><integer>36</integer>
+// CHECK:        <key>col</key><integer>1</integer>
+// CHECK:        <key>file</key><integer>0</integer>
+// CHECK:       </dict>
+// CHECK:       <key>depth</key><integer>1</integer>
+// CHECK:       <key>extended_message</key>
+// CHECK:       <string>Entered call from &apos;test_wrapper&apos;</string>
+// CHECK:       <key>message</key>
+// CHECK:  <string>Entered call from &apos;test_wrapper&apos;</string>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
+// CHECK:        <array>
+// CHECK:         <dict>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>36</integer>
+// CHECK:             <key>col</key><integer>1</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>36</integer>
+// CHECK:             <key>col</key><integer>1</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>37</integer>
+// CHECK:             <key>col</key><integer>3</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>37</integer>
+// CHECK:             <key>col</key><integer>3</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:         </dict>
+// CHECK:        </array>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
+// CHECK:        <array>
+// CHECK:         <dict>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>37</integer>
+// CHECK:             <key>col</key><integer>3</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>37</integer>
+// CHECK:             <key>col</key><integer>3</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>37</integer>
+// CHECK:             <key>col</key><integer>13</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>37</integer>
+// CHECK:             <key>col</key><integer>23</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:         </dict>
+// CHECK:        </array>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>event</string>
+// CHECK:       <key>location</key>
+// CHECK:       <dict>
+// CHECK:        <key>line</key><integer>37</integer>
+// CHECK:        <key>col</key><integer>13</integer>
+// CHECK:        <key>file</key><integer>0</integer>
+// CHECK:       </dict>
+// CHECK:       <key>ranges</key>
+// CHECK:       <array>
+// CHECK:         <array>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>37</integer>
+// CHECK:           <key>col</key><integer>13</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>37</integer>
+// CHECK:           <key>col</key><integer>23</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:         </array>
+// CHECK:       </array>
+// CHECK:       <key>depth</key><integer>1</integer>
+// CHECK:       <key>extended_message</key>
+// CHECK:       <string>Memory is allocated</string>
+// CHECK:       <key>message</key>
+// CHECK:  <string>Memory is allocated</string>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
+// CHECK:        <array>
+// CHECK:         <dict>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>37</integer>
+// CHECK:             <key>col</key><integer>13</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>37</integer>
+// CHECK:             <key>col</key><integer>23</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>39</integer>
+// CHECK:             <key>col</key><integer>3</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>39</integer>
+// CHECK:             <key>col</key><integer>3</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:         </dict>
+// CHECK:        </array>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
+// CHECK:        <array>
+// CHECK:         <dict>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>39</integer>
+// CHECK:             <key>col</key><integer>3</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>39</integer>
+// CHECK:             <key>col</key><integer>3</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>39</integer>
+// CHECK:             <key>col</key><integer>7</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>39</integer>
+// CHECK:             <key>col</key><integer>7</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:         </dict>
+// CHECK:        </array>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>event</string>
+// CHECK:       <key>location</key>
+// CHECK:       <dict>
+// CHECK:        <key>line</key><integer>39</integer>
+// CHECK:        <key>col</key><integer>7</integer>
+// CHECK:        <key>file</key><integer>0</integer>
+// CHECK:       </dict>
+// CHECK:       <key>ranges</key>
+// CHECK:       <array>
+// CHECK:         <array>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>39</integer>
+// CHECK:           <key>col</key><integer>7</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>39</integer>
+// CHECK:           <key>col</key><integer>7</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:         </array>
+// CHECK:       </array>
+// CHECK:       <key>depth</key><integer>1</integer>
+// CHECK:       <key>extended_message</key>
+// CHECK:       <string>Assuming &apos;x&apos; is non-null</string>
+// CHECK:       <key>message</key>
+// CHECK:  <string>Assuming &apos;x&apos; is non-null</string>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
+// CHECK:        <array>
+// CHECK:         <dict>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>39</integer>
+// CHECK:             <key>col</key><integer>7</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>39</integer>
+// CHECK:             <key>col</key><integer>7</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>40</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>40</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:         </dict>
+// CHECK:        </array>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>event</string>
+// CHECK:       <key>location</key>
+// CHECK:       <dict>
+// CHECK:        <key>line</key><integer>45</integer>
+// CHECK:        <key>col</key><integer>15</integer>
+// CHECK:        <key>file</key><integer>0</integer>
+// CHECK:       </dict>
+// CHECK:       <key>ranges</key>
+// CHECK:       <array>
+// CHECK:         <array>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>45</integer>
+// CHECK:           <key>col</key><integer>15</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>45</integer>
+// CHECK:           <key>col</key><integer>23</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:         </array>
+// CHECK:       </array>
+// CHECK:       <key>depth</key><integer>1</integer>
+// CHECK:       <key>extended_message</key>
+// CHECK:       <string>Returning from &apos;wrapper&apos;, which allocated memory</string>
+// CHECK:       <key>message</key>
+// CHECK:  <string>Returning from &apos;wrapper&apos;, which allocated memory</string>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
+// CHECK:        <array>
+// CHECK:         <dict>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>45</integer>
+// CHECK:             <key>col</key><integer>15</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>45</integer>
+// CHECK:             <key>col</key><integer>23</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>47</integer>
+// CHECK:             <key>col</key><integer>1</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>47</integer>
+// CHECK:             <key>col</key><integer>1</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:         </dict>
+// CHECK:        </array>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>event</string>
+// CHECK:       <key>location</key>
+// CHECK:       <dict>
+// CHECK:        <key>line</key><integer>47</integer>
+// CHECK:        <key>col</key><integer>1</integer>
+// CHECK:        <key>file</key><integer>0</integer>
+// CHECK:       </dict>
+// CHECK:       <key>depth</key><integer>0</integer>
+// CHECK:       <key>extended_message</key>
+// CHECK:       <string>Memory is never released; potential memory leak</string>
+// CHECK:       <key>message</key>
+// CHECK:  <string>Memory is never released; potential memory leak</string>
+// CHECK:      </dict>
+// CHECK:     </array>
+// CHECK:     <key>description</key><string>Memory is never released; potential memory leak</string>
+// CHECK:     <key>category</key><string>Memory Error</string>
+// CHECK:     <key>type</key><string>Memory leak</string>
+// CHECK:    <key>location</key>
+// CHECK:    <dict>
+// CHECK:     <key>line</key><integer>47</integer>
+// CHECK:     <key>col</key><integer>1</integer>
+// CHECK:     <key>file</key><integer>0</integer>
+// CHECK:    </dict>
+// CHECK:    </dict>
+// CHECK:    <dict>
+// CHECK:     <key>path</key>
+// CHECK:     <array>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
+// CHECK:        <array>
+// CHECK:         <dict>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>60</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>60</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>61</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>61</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:         </dict>
+// CHECK:        </array>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>event</string>
+// CHECK:       <key>location</key>
+// CHECK:       <dict>
+// CHECK:        <key>line</key><integer>61</integer>
+// CHECK:        <key>col</key><integer>5</integer>
+// CHECK:        <key>file</key><integer>0</integer>
+// CHECK:       </dict>
+// CHECK:       <key>ranges</key>
+// CHECK:       <array>
+// CHECK:         <array>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>61</integer>
+// CHECK:           <key>col</key><integer>5</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>61</integer>
+// CHECK:           <key>col</key><integer>28</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:         </array>
+// CHECK:       </array>
+// CHECK:       <key>depth</key><integer>0</integer>
+// CHECK:       <key>extended_message</key>
+// CHECK:       <string>Calling &apos;my_malloc_and_free&apos;</string>
+// CHECK:       <key>message</key>
+// CHECK:  <string>Calling &apos;my_malloc_and_free&apos;</string>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>event</string>
+// CHECK:       <key>location</key>
+// CHECK:       <dict>
+// CHECK:        <key>line</key><integer>53</integer>
+// CHECK:        <key>col</key><integer>1</integer>
+// CHECK:        <key>file</key><integer>0</integer>
+// CHECK:       </dict>
+// CHECK:       <key>depth</key><integer>1</integer>
+// CHECK:       <key>extended_message</key>
+// CHECK:       <string>Entered call from &apos;test_double_action_call&apos;</string>
+// CHECK:       <key>message</key>
+// CHECK:  <string>Entered call from &apos;test_double_action_call&apos;</string>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
+// CHECK:        <array>
+// CHECK:         <dict>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>53</integer>
+// CHECK:             <key>col</key><integer>1</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>53</integer>
+// CHECK:             <key>col</key><integer>1</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>54</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>54</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:         </dict>
+// CHECK:        </array>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
+// CHECK:        <array>
+// CHECK:         <dict>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>54</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>54</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>54</integer>
+// CHECK:             <key>col</key><integer>10</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>54</integer>
+// CHECK:             <key>col</key><integer>20</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:         </dict>
+// CHECK:        </array>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>event</string>
+// CHECK:       <key>location</key>
+// CHECK:       <dict>
+// CHECK:        <key>line</key><integer>54</integer>
+// CHECK:        <key>col</key><integer>10</integer>
+// CHECK:        <key>file</key><integer>0</integer>
+// CHECK:       </dict>
+// CHECK:       <key>ranges</key>
+// CHECK:       <array>
+// CHECK:         <array>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>54</integer>
+// CHECK:           <key>col</key><integer>10</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>54</integer>
+// CHECK:           <key>col</key><integer>20</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:         </array>
+// CHECK:       </array>
+// CHECK:       <key>depth</key><integer>1</integer>
+// CHECK:       <key>extended_message</key>
+// CHECK:       <string>Memory is allocated</string>
+// CHECK:       <key>message</key>
+// CHECK:  <string>Memory is allocated</string>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
+// CHECK:        <array>
+// CHECK:         <dict>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>54</integer>
+// CHECK:             <key>col</key><integer>10</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>54</integer>
+// CHECK:             <key>col</key><integer>20</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>55</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>55</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:         </dict>
+// CHECK:        </array>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
+// CHECK:        <array>
+// CHECK:         <dict>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>55</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>55</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>56</integer>
+// CHECK:             <key>col</key><integer>7</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>56</integer>
+// CHECK:             <key>col</key><integer>7</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:         </dict>
+// CHECK:        </array>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>event</string>
+// CHECK:       <key>location</key>
+// CHECK:       <dict>
+// CHECK:        <key>line</key><integer>56</integer>
+// CHECK:        <key>col</key><integer>7</integer>
+// CHECK:        <key>file</key><integer>0</integer>
+// CHECK:       </dict>
+// CHECK:       <key>ranges</key>
+// CHECK:       <array>
+// CHECK:         <array>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>56</integer>
+// CHECK:           <key>col</key><integer>7</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>56</integer>
+// CHECK:           <key>col</key><integer>17</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:         </array>
+// CHECK:       </array>
+// CHECK:       <key>depth</key><integer>1</integer>
+// CHECK:       <key>extended_message</key>
+// CHECK:       <string>Calling &apos;my_free&apos;</string>
+// CHECK:       <key>message</key>
+// CHECK:  <string>Calling &apos;my_free&apos;</string>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>event</string>
+// CHECK:       <key>location</key>
+// CHECK:       <dict>
+// CHECK:        <key>line</key><integer>50</integer>
+// CHECK:        <key>col</key><integer>1</integer>
+// CHECK:        <key>file</key><integer>0</integer>
+// CHECK:       </dict>
+// CHECK:       <key>depth</key><integer>2</integer>
+// CHECK:       <key>extended_message</key>
+// CHECK:       <string>Entered call from &apos;my_malloc_and_free&apos;</string>
+// CHECK:       <key>message</key>
+// CHECK:  <string>Entered call from &apos;my_malloc_and_free&apos;</string>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
+// CHECK:        <array>
+// CHECK:         <dict>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>50</integer>
+// CHECK:             <key>col</key><integer>1</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>50</integer>
+// CHECK:             <key>col</key><integer>1</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>51</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>51</integer>
+// CHECK:             <key>col</key><integer>11</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:         </dict>
+// CHECK:        </array>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>event</string>
+// CHECK:       <key>location</key>
+// CHECK:       <dict>
+// CHECK:        <key>line</key><integer>51</integer>
+// CHECK:        <key>col</key><integer>5</integer>
+// CHECK:        <key>file</key><integer>0</integer>
+// CHECK:       </dict>
+// CHECK:       <key>ranges</key>
+// CHECK:       <array>
+// CHECK:         <array>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>51</integer>
+// CHECK:           <key>col</key><integer>5</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>51</integer>
+// CHECK:           <key>col</key><integer>11</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:         </array>
+// CHECK:       </array>
+// CHECK:       <key>depth</key><integer>2</integer>
+// CHECK:       <key>extended_message</key>
+// CHECK:       <string>Memory is released</string>
+// CHECK:       <key>message</key>
+// CHECK:  <string>Memory is released</string>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>event</string>
+// CHECK:       <key>location</key>
+// CHECK:       <dict>
+// CHECK:        <key>line</key><integer>56</integer>
+// CHECK:        <key>col</key><integer>7</integer>
+// CHECK:        <key>file</key><integer>0</integer>
+// CHECK:       </dict>
+// CHECK:       <key>ranges</key>
+// CHECK:       <array>
+// CHECK:         <array>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>56</integer>
+// CHECK:           <key>col</key><integer>7</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>56</integer>
+// CHECK:           <key>col</key><integer>17</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:         </array>
+// CHECK:       </array>
+// CHECK:       <key>depth</key><integer>2</integer>
+// CHECK:       <key>extended_message</key>
+// CHECK:       <string>Returning from &apos;my_free&apos;, which released memory</string>
+// CHECK:       <key>message</key>
+// CHECK:  <string>Returning from &apos;my_free&apos;, which released memory</string>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
+// CHECK:        <array>
+// CHECK:         <dict>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>56</integer>
+// CHECK:             <key>col</key><integer>7</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>56</integer>
+// CHECK:             <key>col</key><integer>17</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>57</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>57</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:         </dict>
+// CHECK:        </array>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>event</string>
+// CHECK:       <key>location</key>
+// CHECK:       <dict>
+// CHECK:        <key>line</key><integer>61</integer>
+// CHECK:        <key>col</key><integer>5</integer>
+// CHECK:        <key>file</key><integer>0</integer>
+// CHECK:       </dict>
+// CHECK:       <key>ranges</key>
+// CHECK:       <array>
+// CHECK:         <array>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>61</integer>
+// CHECK:           <key>col</key><integer>5</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>61</integer>
+// CHECK:           <key>col</key><integer>28</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:         </array>
+// CHECK:       </array>
+// CHECK:       <key>depth</key><integer>1</integer>
+// CHECK:       <key>extended_message</key>
+// CHECK:       <string>Returning from &apos;my_malloc_and_free&apos;, which released memory</string>
+// CHECK:       <key>message</key>
+// CHECK:  <string>Returning from &apos;my_malloc_and_free&apos;, which released memory</string>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>control</string>
+// CHECK:       <key>edges</key>
+// CHECK:        <array>
+// CHECK:         <dict>
+// CHECK:          <key>start</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>61</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>61</integer>
+// CHECK:             <key>col</key><integer>28</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:          <key>end</key>
+// CHECK:           <array>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>62</integer>
+// CHECK:             <key>col</key><integer>5</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:            <dict>
+// CHECK:             <key>line</key><integer>62</integer>
+// CHECK:             <key>col</key><integer>14</integer>
+// CHECK:             <key>file</key><integer>0</integer>
+// CHECK:            </dict>
+// CHECK:           </array>
+// CHECK:         </dict>
+// CHECK:        </array>
+// CHECK:      </dict>
+// CHECK:      <dict>
+// CHECK:       <key>kind</key><string>event</string>
+// CHECK:       <key>location</key>
+// CHECK:       <dict>
+// CHECK:        <key>line</key><integer>62</integer>
+// CHECK:        <key>col</key><integer>5</integer>
+// CHECK:        <key>file</key><integer>0</integer>
+// CHECK:       </dict>
+// CHECK:       <key>ranges</key>
+// CHECK:       <array>
+// CHECK:         <array>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>62</integer>
+// CHECK:           <key>col</key><integer>12</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:          <dict>
+// CHECK:           <key>line</key><integer>62</integer>
+// CHECK:           <key>col</key><integer>14</integer>
+// CHECK:           <key>file</key><integer>0</integer>
+// CHECK:          </dict>
+// CHECK:         </array>
+// CHECK:       </array>
+// CHECK:       <key>depth</key><integer>0</integer>
+// CHECK:       <key>extended_message</key>
+// CHECK:       <string>Use of memory after it is freed</string>
+// CHECK:       <key>message</key>
+// CHECK:  <string>Use of memory after it is freed</string>
+// CHECK:      </dict>
+// CHECK:     </array>
+// CHECK:     <key>description</key><string>Use of memory after it is freed</string>
+// CHECK:     <key>category</key><string>Memory Error</string>
+// CHECK:     <key>type</key><string>Use-after-free</string>
+// CHECK:    <key>location</key>
+// CHECK:    <dict>
+// CHECK:     <key>line</key><integer>62</integer>
+// CHECK:     <key>col</key><integer>5</integer>
+// CHECK:     <key>file</key><integer>0</integer>
+// CHECK:    </dict>
+// CHECK:    </dict>
+// CHECK:   </array>
+// CHECK:  </dict>
+// CHECK:  </plist>