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