1// RUN: %clang_cc1 -analyze -analyzer-checker=core,osx.cocoa.RetainCount -fblocks -verify %s 2// RUN: %clang_cc1 -analyze -analyzer-checker=core,osx.cocoa.RetainCount -fblocks -analyzer-output=plist-multi-file -analyzer-config path-diagnostics-alternate=false %s -o %t 3// RUN: FileCheck --input-file=%t %s 4@class NSString; 5typedef long NSInteger; 6typedef unsigned char BOOL; 7@interface NSObject {} 8+(id)alloc; 9-(id)init; 10-(id)autorelease; 11-(id)copy; 12-(id)retain; 13@end 14@interface NSNumber : NSObject 15+ (NSNumber *)numberWithInteger:(NSInteger)value __attribute__((availability(ios,introduced=2.0))); 16@end 17NSInteger *inoutIntegerValueGlobal; 18NSInteger *inoutIntegerValueGlobal2; 19NSString *traitNameGlobal; 20static BOOL cond; 21 22static inline void reallyPerformAction(void (^integerHandler)(NSInteger *inoutIntegerValue, NSString *traitName)) { 23 integerHandler(inoutIntegerValueGlobal, traitNameGlobal); // expected-warning {{Potential leak of an object}} 24 integerHandler(inoutIntegerValueGlobal2,traitNameGlobal); 25} 26 27static inline BOOL performAction(NSNumber *(^action)(NSNumber *traitValue)) { 28 __attribute__((__blocks__(byref))) BOOL didFindTrait = 0; 29 reallyPerformAction(^(NSInteger *inoutIntegerValue,NSString *traitName) { 30 31 if (cond) { 32 33 NSNumber *traitValue = @(*inoutIntegerValue); 34 35 NSNumber *newTraitValue = action(traitValue); 36 37 if (traitValue != newTraitValue) { 38 *inoutIntegerValue = newTraitValue ? *inoutIntegerValue : *inoutIntegerValue; 39 } 40 didFindTrait = 1; 41 } 42 43 }); 44 return didFindTrait; 45} 46 47void runTest() { 48 __attribute__((__blocks__(byref))) NSNumber *builtinResult = ((NSNumber *)0); 49 BOOL wasBuiltinTrait = performAction(^(NSNumber *traitValue) { 50 builtinResult = [traitValue retain]; 51 52 return traitValue; 53 }); 54 if (wasBuiltinTrait) { 55 [builtinResult autorelease]; 56 return; 57 } else { 58 return; 59 } 60} 61 62// CHECK: <key>diagnostics</key> 63// CHECK: <array> 64// CHECK: <dict> 65// CHECK: <key>path</key> 66// CHECK: <array> 67// CHECK: <dict> 68// CHECK: <key>kind</key><string>control</string> 69// CHECK: <key>edges</key> 70// CHECK: <array> 71// CHECK: <dict> 72// CHECK: <key>start</key> 73// CHECK: <array> 74// CHECK: <dict> 75// CHECK: <key>line</key><integer>48</integer> 76// CHECK: <key>col</key><integer>3</integer> 77// CHECK: <key>file</key><integer>0</integer> 78// CHECK: </dict> 79// CHECK: <dict> 80// CHECK: <key>line</key><integer>48</integer> 81// CHECK: <key>col</key><integer>15</integer> 82// CHECK: <key>file</key><integer>0</integer> 83// CHECK: </dict> 84// CHECK: </array> 85// CHECK: <key>end</key> 86// CHECK: <array> 87// CHECK: <dict> 88// CHECK: <key>line</key><integer>49</integer> 89// CHECK: <key>col</key><integer>26</integer> 90// CHECK: <key>file</key><integer>0</integer> 91// CHECK: </dict> 92// CHECK: <dict> 93// CHECK: <key>line</key><integer>49</integer> 94// CHECK: <key>col</key><integer>38</integer> 95// CHECK: <key>file</key><integer>0</integer> 96// CHECK: </dict> 97// CHECK: </array> 98// CHECK: </dict> 99// CHECK: </array> 100// CHECK: </dict> 101// CHECK: <dict> 102// CHECK: <key>kind</key><string>event</string> 103// CHECK: <key>location</key> 104// CHECK: <dict> 105// CHECK: <key>line</key><integer>49</integer> 106// CHECK: <key>col</key><integer>26</integer> 107// CHECK: <key>file</key><integer>0</integer> 108// CHECK: </dict> 109// CHECK: <key>ranges</key> 110// CHECK: <array> 111// CHECK: <array> 112// CHECK: <dict> 113// CHECK: <key>line</key><integer>49</integer> 114// CHECK: <key>col</key><integer>26</integer> 115// CHECK: <key>file</key><integer>0</integer> 116// CHECK: </dict> 117// CHECK: <dict> 118// CHECK: <key>line</key><integer>53</integer> 119// CHECK: <key>col</key><integer>4</integer> 120// CHECK: <key>file</key><integer>0</integer> 121// CHECK: </dict> 122// CHECK: </array> 123// CHECK: </array> 124// CHECK: <key>depth</key><integer>0</integer> 125// CHECK: <key>extended_message</key> 126// CHECK: <string>Calling 'performAction'</string> 127// CHECK: <key>message</key> 128// CHECK: <string>Calling 'performAction'</string> 129// CHECK: </dict> 130// CHECK: <dict> 131// CHECK: <key>kind</key><string>event</string> 132// CHECK: <key>location</key> 133// CHECK: <dict> 134// CHECK: <key>line</key><integer>27</integer> 135// CHECK: <key>col</key><integer>1</integer> 136// CHECK: <key>file</key><integer>0</integer> 137// CHECK: </dict> 138// CHECK: <key>depth</key><integer>1</integer> 139// CHECK: <key>extended_message</key> 140// CHECK: <string>Entered call from 'runTest'</string> 141// CHECK: <key>message</key> 142// CHECK: <string>Entered call from 'runTest'</string> 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>27</integer> 153// CHECK: <key>col</key><integer>1</integer> 154// CHECK: <key>file</key><integer>0</integer> 155// CHECK: </dict> 156// CHECK: <dict> 157// CHECK: <key>line</key><integer>27</integer> 158// CHECK: <key>col</key><integer>6</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>28</integer> 166// CHECK: <key>col</key><integer>3</integer> 167// CHECK: <key>file</key><integer>0</integer> 168// CHECK: </dict> 169// CHECK: <dict> 170// CHECK: <key>line</key><integer>28</integer> 171// CHECK: <key>col</key><integer>15</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>control</string> 180// CHECK: <key>edges</key> 181// CHECK: <array> 182// CHECK: <dict> 183// CHECK: <key>start</key> 184// CHECK: <array> 185// CHECK: <dict> 186// CHECK: <key>line</key><integer>28</integer> 187// CHECK: <key>col</key><integer>3</integer> 188// CHECK: <key>file</key><integer>0</integer> 189// CHECK: </dict> 190// CHECK: <dict> 191// CHECK: <key>line</key><integer>28</integer> 192// CHECK: <key>col</key><integer>15</integer> 193// CHECK: <key>file</key><integer>0</integer> 194// CHECK: </dict> 195// CHECK: </array> 196// CHECK: <key>end</key> 197// CHECK: <array> 198// CHECK: <dict> 199// CHECK: <key>line</key><integer>29</integer> 200// CHECK: <key>col</key><integer>3</integer> 201// CHECK: <key>file</key><integer>0</integer> 202// CHECK: </dict> 203// CHECK: <dict> 204// CHECK: <key>line</key><integer>29</integer> 205// CHECK: <key>col</key><integer>21</integer> 206// CHECK: <key>file</key><integer>0</integer> 207// CHECK: </dict> 208// CHECK: </array> 209// CHECK: </dict> 210// CHECK: </array> 211// CHECK: </dict> 212// CHECK: <dict> 213// CHECK: <key>kind</key><string>event</string> 214// CHECK: <key>location</key> 215// CHECK: <dict> 216// CHECK: <key>line</key><integer>29</integer> 217// CHECK: <key>col</key><integer>3</integer> 218// CHECK: <key>file</key><integer>0</integer> 219// CHECK: </dict> 220// CHECK: <key>ranges</key> 221// CHECK: <array> 222// CHECK: <array> 223// CHECK: <dict> 224// CHECK: <key>line</key><integer>29</integer> 225// CHECK: <key>col</key><integer>3</integer> 226// CHECK: <key>file</key><integer>0</integer> 227// CHECK: </dict> 228// CHECK: <dict> 229// CHECK: <key>line</key><integer>43</integer> 230// CHECK: <key>col</key><integer>4</integer> 231// CHECK: <key>file</key><integer>0</integer> 232// CHECK: </dict> 233// CHECK: </array> 234// CHECK: </array> 235// CHECK: <key>depth</key><integer>1</integer> 236// CHECK: <key>extended_message</key> 237// CHECK: <string>Calling 'reallyPerformAction'</string> 238// CHECK: <key>message</key> 239// CHECK: <string>Calling 'reallyPerformAction'</string> 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>22</integer> 246// CHECK: <key>col</key><integer>1</integer> 247// CHECK: <key>file</key><integer>0</integer> 248// CHECK: </dict> 249// CHECK: <key>depth</key><integer>2</integer> 250// CHECK: <key>extended_message</key> 251// CHECK: <string>Entered call from 'performAction'</string> 252// CHECK: <key>message</key> 253// CHECK: <string>Entered call from 'performAction'</string> 254// CHECK: </dict> 255// CHECK: <dict> 256// CHECK: <key>kind</key><string>control</string> 257// CHECK: <key>edges</key> 258// CHECK: <array> 259// CHECK: <dict> 260// CHECK: <key>start</key> 261// CHECK: <array> 262// CHECK: <dict> 263// CHECK: <key>line</key><integer>22</integer> 264// CHECK: <key>col</key><integer>1</integer> 265// CHECK: <key>file</key><integer>0</integer> 266// CHECK: </dict> 267// CHECK: <dict> 268// CHECK: <key>line</key><integer>22</integer> 269// CHECK: <key>col</key><integer>6</integer> 270// CHECK: <key>file</key><integer>0</integer> 271// CHECK: </dict> 272// CHECK: </array> 273// CHECK: <key>end</key> 274// CHECK: <array> 275// CHECK: <dict> 276// CHECK: <key>line</key><integer>23</integer> 277// CHECK: <key>col</key><integer>3</integer> 278// CHECK: <key>file</key><integer>0</integer> 279// CHECK: </dict> 280// CHECK: <dict> 281// CHECK: <key>line</key><integer>23</integer> 282// CHECK: <key>col</key><integer>16</integer> 283// CHECK: <key>file</key><integer>0</integer> 284// CHECK: </dict> 285// CHECK: </array> 286// CHECK: </dict> 287// CHECK: </array> 288// CHECK: </dict> 289// CHECK: <dict> 290// CHECK: <key>kind</key><string>event</string> 291// CHECK: <key>location</key> 292// CHECK: <dict> 293// CHECK: <key>line</key><integer>23</integer> 294// CHECK: <key>col</key><integer>3</integer> 295// CHECK: <key>file</key><integer>0</integer> 296// CHECK: </dict> 297// CHECK: <key>ranges</key> 298// CHECK: <array> 299// CHECK: <array> 300// CHECK: <dict> 301// CHECK: <key>line</key><integer>23</integer> 302// CHECK: <key>col</key><integer>3</integer> 303// CHECK: <key>file</key><integer>0</integer> 304// CHECK: </dict> 305// CHECK: <dict> 306// CHECK: <key>line</key><integer>23</integer> 307// CHECK: <key>col</key><integer>58</integer> 308// CHECK: <key>file</key><integer>0</integer> 309// CHECK: </dict> 310// CHECK: </array> 311// CHECK: </array> 312// CHECK: <key>depth</key><integer>2</integer> 313// CHECK: <key>extended_message</key> 314// CHECK: <string>Calling anonymous block</string> 315// CHECK: <key>message</key> 316// CHECK: <string>Calling anonymous block</string> 317// CHECK: </dict> 318// CHECK: <dict> 319// CHECK: <key>kind</key><string>event</string> 320// CHECK: <key>location</key> 321// CHECK: <dict> 322// CHECK: <key>line</key><integer>29</integer> 323// CHECK: <key>col</key><integer>23</integer> 324// CHECK: <key>file</key><integer>0</integer> 325// CHECK: </dict> 326// CHECK: <key>depth</key><integer>3</integer> 327// CHECK: <key>extended_message</key> 328// CHECK: <string>Entered call from 'reallyPerformAction'</string> 329// CHECK: <key>message</key> 330// CHECK: <string>Entered call from 'reallyPerformAction'</string> 331// CHECK: </dict> 332// CHECK: <dict> 333// CHECK: <key>kind</key><string>control</string> 334// CHECK: <key>edges</key> 335// CHECK: <array> 336// CHECK: <dict> 337// CHECK: <key>start</key> 338// CHECK: <array> 339// CHECK: <dict> 340// CHECK: <key>line</key><integer>29</integer> 341// CHECK: <key>col</key><integer>23</integer> 342// CHECK: <key>file</key><integer>0</integer> 343// CHECK: </dict> 344// CHECK: <dict> 345// CHECK: <key>line</key><integer>29</integer> 346// CHECK: <key>col</key><integer>23</integer> 347// CHECK: <key>file</key><integer>0</integer> 348// CHECK: </dict> 349// CHECK: </array> 350// CHECK: <key>end</key> 351// CHECK: <array> 352// CHECK: <dict> 353// CHECK: <key>line</key><integer>31</integer> 354// CHECK: <key>col</key><integer>5</integer> 355// CHECK: <key>file</key><integer>0</integer> 356// CHECK: </dict> 357// CHECK: <dict> 358// CHECK: <key>line</key><integer>31</integer> 359// CHECK: <key>col</key><integer>6</integer> 360// CHECK: <key>file</key><integer>0</integer> 361// CHECK: </dict> 362// CHECK: </array> 363// CHECK: </dict> 364// CHECK: </array> 365// CHECK: </dict> 366// CHECK: <dict> 367// CHECK: <key>kind</key><string>control</string> 368// CHECK: <key>edges</key> 369// CHECK: <array> 370// CHECK: <dict> 371// CHECK: <key>start</key> 372// CHECK: <array> 373// CHECK: <dict> 374// CHECK: <key>line</key><integer>31</integer> 375// CHECK: <key>col</key><integer>5</integer> 376// CHECK: <key>file</key><integer>0</integer> 377// CHECK: </dict> 378// CHECK: <dict> 379// CHECK: <key>line</key><integer>31</integer> 380// CHECK: <key>col</key><integer>6</integer> 381// CHECK: <key>file</key><integer>0</integer> 382// CHECK: </dict> 383// CHECK: </array> 384// CHECK: <key>end</key> 385// CHECK: <array> 386// CHECK: <dict> 387// CHECK: <key>line</key><integer>31</integer> 388// CHECK: <key>col</key><integer>9</integer> 389// CHECK: <key>file</key><integer>0</integer> 390// CHECK: </dict> 391// CHECK: <dict> 392// CHECK: <key>line</key><integer>31</integer> 393// CHECK: <key>col</key><integer>12</integer> 394// CHECK: <key>file</key><integer>0</integer> 395// CHECK: </dict> 396// CHECK: </array> 397// CHECK: </dict> 398// CHECK: </array> 399// CHECK: </dict> 400// CHECK: <dict> 401// CHECK: <key>kind</key><string>event</string> 402// CHECK: <key>location</key> 403// CHECK: <dict> 404// CHECK: <key>line</key><integer>31</integer> 405// CHECK: <key>col</key><integer>9</integer> 406// CHECK: <key>file</key><integer>0</integer> 407// CHECK: </dict> 408// CHECK: <key>ranges</key> 409// CHECK: <array> 410// CHECK: <array> 411// CHECK: <dict> 412// CHECK: <key>line</key><integer>31</integer> 413// CHECK: <key>col</key><integer>9</integer> 414// CHECK: <key>file</key><integer>0</integer> 415// CHECK: </dict> 416// CHECK: <dict> 417// CHECK: <key>line</key><integer>31</integer> 418// CHECK: <key>col</key><integer>12</integer> 419// CHECK: <key>file</key><integer>0</integer> 420// CHECK: </dict> 421// CHECK: </array> 422// CHECK: </array> 423// CHECK: <key>depth</key><integer>3</integer> 424// CHECK: <key>extended_message</key> 425// CHECK: <string>Assuming 'cond' is not equal to 0</string> 426// CHECK: <key>message</key> 427// CHECK: <string>Assuming 'cond' is not equal to 0</string> 428// CHECK: </dict> 429// CHECK: <dict> 430// CHECK: <key>kind</key><string>control</string> 431// CHECK: <key>edges</key> 432// CHECK: <array> 433// CHECK: <dict> 434// CHECK: <key>start</key> 435// CHECK: <array> 436// CHECK: <dict> 437// CHECK: <key>line</key><integer>31</integer> 438// CHECK: <key>col</key><integer>9</integer> 439// CHECK: <key>file</key><integer>0</integer> 440// CHECK: </dict> 441// CHECK: <dict> 442// CHECK: <key>line</key><integer>31</integer> 443// CHECK: <key>col</key><integer>12</integer> 444// CHECK: <key>file</key><integer>0</integer> 445// CHECK: </dict> 446// CHECK: </array> 447// CHECK: <key>end</key> 448// CHECK: <array> 449// CHECK: <dict> 450// CHECK: <key>line</key><integer>33</integer> 451// CHECK: <key>col</key><integer>7</integer> 452// CHECK: <key>file</key><integer>0</integer> 453// CHECK: </dict> 454// CHECK: <dict> 455// CHECK: <key>line</key><integer>33</integer> 456// CHECK: <key>col</key><integer>14</integer> 457// CHECK: <key>file</key><integer>0</integer> 458// CHECK: </dict> 459// CHECK: </array> 460// CHECK: </dict> 461// CHECK: </array> 462// CHECK: </dict> 463// CHECK: <dict> 464// CHECK: <key>kind</key><string>control</string> 465// CHECK: <key>edges</key> 466// CHECK: <array> 467// CHECK: <dict> 468// CHECK: <key>start</key> 469// CHECK: <array> 470// CHECK: <dict> 471// CHECK: <key>line</key><integer>33</integer> 472// CHECK: <key>col</key><integer>7</integer> 473// CHECK: <key>file</key><integer>0</integer> 474// CHECK: </dict> 475// CHECK: <dict> 476// CHECK: <key>line</key><integer>33</integer> 477// CHECK: <key>col</key><integer>14</integer> 478// CHECK: <key>file</key><integer>0</integer> 479// CHECK: </dict> 480// CHECK: </array> 481// CHECK: <key>end</key> 482// CHECK: <array> 483// CHECK: <dict> 484// CHECK: <key>line</key><integer>33</integer> 485// CHECK: <key>col</key><integer>30</integer> 486// CHECK: <key>file</key><integer>0</integer> 487// CHECK: </dict> 488// CHECK: <dict> 489// CHECK: <key>line</key><integer>33</integer> 490// CHECK: <key>col</key><integer>30</integer> 491// CHECK: <key>file</key><integer>0</integer> 492// CHECK: </dict> 493// CHECK: </array> 494// CHECK: </dict> 495// CHECK: </array> 496// CHECK: </dict> 497// CHECK: <dict> 498// CHECK: <key>kind</key><string>event</string> 499// CHECK: <key>location</key> 500// CHECK: <dict> 501// CHECK: <key>line</key><integer>33</integer> 502// CHECK: <key>col</key><integer>30</integer> 503// CHECK: <key>file</key><integer>0</integer> 504// CHECK: </dict> 505// CHECK: <key>ranges</key> 506// CHECK: <array> 507// CHECK: <array> 508// CHECK: <dict> 509// CHECK: <key>line</key><integer>33</integer> 510// CHECK: <key>col</key><integer>30</integer> 511// CHECK: <key>file</key><integer>0</integer> 512// CHECK: </dict> 513// CHECK: <dict> 514// CHECK: <key>line</key><integer>33</integer> 515// CHECK: <key>col</key><integer>50</integer> 516// CHECK: <key>file</key><integer>0</integer> 517// CHECK: </dict> 518// CHECK: </array> 519// CHECK: </array> 520// CHECK: <key>depth</key><integer>3</integer> 521// CHECK: <key>extended_message</key> 522// CHECK: <string>NSNumber boxed expression produces an object with a +0 retain count</string> 523// CHECK: <key>message</key> 524// CHECK: <string>NSNumber boxed expression produces an object with a +0 retain count</string> 525// CHECK: </dict> 526// CHECK: <dict> 527// CHECK: <key>kind</key><string>control</string> 528// CHECK: <key>edges</key> 529// CHECK: <array> 530// CHECK: <dict> 531// CHECK: <key>start</key> 532// CHECK: <array> 533// CHECK: <dict> 534// CHECK: <key>line</key><integer>33</integer> 535// CHECK: <key>col</key><integer>30</integer> 536// CHECK: <key>file</key><integer>0</integer> 537// CHECK: </dict> 538// CHECK: <dict> 539// CHECK: <key>line</key><integer>33</integer> 540// CHECK: <key>col</key><integer>30</integer> 541// CHECK: <key>file</key><integer>0</integer> 542// CHECK: </dict> 543// CHECK: </array> 544// CHECK: <key>end</key> 545// CHECK: <array> 546// CHECK: <dict> 547// CHECK: <key>line</key><integer>35</integer> 548// CHECK: <key>col</key><integer>33</integer> 549// CHECK: <key>file</key><integer>0</integer> 550// CHECK: </dict> 551// CHECK: <dict> 552// CHECK: <key>line</key><integer>35</integer> 553// CHECK: <key>col</key><integer>38</integer> 554// CHECK: <key>file</key><integer>0</integer> 555// CHECK: </dict> 556// CHECK: </array> 557// CHECK: </dict> 558// CHECK: </array> 559// CHECK: </dict> 560// CHECK: <dict> 561// CHECK: <key>kind</key><string>event</string> 562// CHECK: <key>location</key> 563// CHECK: <dict> 564// CHECK: <key>line</key><integer>35</integer> 565// CHECK: <key>col</key><integer>33</integer> 566// CHECK: <key>file</key><integer>0</integer> 567// CHECK: </dict> 568// CHECK: <key>ranges</key> 569// CHECK: <array> 570// CHECK: <array> 571// CHECK: <dict> 572// CHECK: <key>line</key><integer>35</integer> 573// CHECK: <key>col</key><integer>33</integer> 574// CHECK: <key>file</key><integer>0</integer> 575// CHECK: </dict> 576// CHECK: <dict> 577// CHECK: <key>line</key><integer>35</integer> 578// CHECK: <key>col</key><integer>50</integer> 579// CHECK: <key>file</key><integer>0</integer> 580// CHECK: </dict> 581// CHECK: </array> 582// CHECK: </array> 583// CHECK: <key>depth</key><integer>3</integer> 584// CHECK: <key>extended_message</key> 585// CHECK: <string>Calling anonymous block</string> 586// CHECK: <key>message</key> 587// CHECK: <string>Calling anonymous block</string> 588// CHECK: </dict> 589// CHECK: <dict> 590// CHECK: <key>kind</key><string>event</string> 591// CHECK: <key>location</key> 592// CHECK: <dict> 593// CHECK: <key>line</key><integer>49</integer> 594// CHECK: <key>col</key><integer>40</integer> 595// CHECK: <key>file</key><integer>0</integer> 596// CHECK: </dict> 597// CHECK: <key>depth</key><integer>4</integer> 598// CHECK: <key>extended_message</key> 599// CHECK: <string>Entered call</string> 600// CHECK: <key>message</key> 601// CHECK: <string>Entered call</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>49</integer> 612// CHECK: <key>col</key><integer>40</integer> 613// CHECK: <key>file</key><integer>0</integer> 614// CHECK: </dict> 615// CHECK: <dict> 616// CHECK: <key>line</key><integer>49</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>50</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>50</integer> 630// CHECK: <key>col</key><integer>17</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>control</string> 639// CHECK: <key>edges</key> 640// CHECK: <array> 641// CHECK: <dict> 642// CHECK: <key>start</key> 643// CHECK: <array> 644// CHECK: <dict> 645// CHECK: <key>line</key><integer>50</integer> 646// CHECK: <key>col</key><integer>5</integer> 647// CHECK: <key>file</key><integer>0</integer> 648// CHECK: </dict> 649// CHECK: <dict> 650// CHECK: <key>line</key><integer>50</integer> 651// CHECK: <key>col</key><integer>17</integer> 652// CHECK: <key>file</key><integer>0</integer> 653// CHECK: </dict> 654// CHECK: </array> 655// CHECK: <key>end</key> 656// CHECK: <array> 657// CHECK: <dict> 658// CHECK: <key>line</key><integer>50</integer> 659// CHECK: <key>col</key><integer>21</integer> 660// CHECK: <key>file</key><integer>0</integer> 661// CHECK: </dict> 662// CHECK: <dict> 663// CHECK: <key>line</key><integer>50</integer> 664// CHECK: <key>col</key><integer>21</integer> 665// CHECK: <key>file</key><integer>0</integer> 666// CHECK: </dict> 667// CHECK: </array> 668// CHECK: </dict> 669// CHECK: </array> 670// CHECK: </dict> 671// CHECK: <dict> 672// CHECK: <key>kind</key><string>event</string> 673// CHECK: <key>location</key> 674// CHECK: <dict> 675// CHECK: <key>line</key><integer>50</integer> 676// CHECK: <key>col</key><integer>21</integer> 677// CHECK: <key>file</key><integer>0</integer> 678// CHECK: </dict> 679// CHECK: <key>ranges</key> 680// CHECK: <array> 681// CHECK: <array> 682// CHECK: <dict> 683// CHECK: <key>line</key><integer>50</integer> 684// CHECK: <key>col</key><integer>21</integer> 685// CHECK: <key>file</key><integer>0</integer> 686// CHECK: </dict> 687// CHECK: <dict> 688// CHECK: <key>line</key><integer>50</integer> 689// CHECK: <key>col</key><integer>39</integer> 690// CHECK: <key>file</key><integer>0</integer> 691// CHECK: </dict> 692// CHECK: </array> 693// CHECK: <array> 694// CHECK: <dict> 695// CHECK: <key>line</key><integer>50</integer> 696// CHECK: <key>col</key><integer>22</integer> 697// CHECK: <key>file</key><integer>0</integer> 698// CHECK: </dict> 699// CHECK: <dict> 700// CHECK: <key>line</key><integer>50</integer> 701// CHECK: <key>col</key><integer>31</integer> 702// CHECK: <key>file</key><integer>0</integer> 703// CHECK: </dict> 704// CHECK: </array> 705// CHECK: </array> 706// CHECK: <key>depth</key><integer>4</integer> 707// CHECK: <key>extended_message</key> 708// CHECK: <string>Reference count incremented. The object now has a +1 retain count</string> 709// CHECK: <key>message</key> 710// CHECK: <string>Reference count incremented. The object now has a +1 retain count</string> 711// CHECK: </dict> 712// CHECK: <dict> 713// CHECK: <key>kind</key><string>event</string> 714// CHECK: <key>location</key> 715// CHECK: <dict> 716// CHECK: <key>line</key><integer>35</integer> 717// CHECK: <key>col</key><integer>33</integer> 718// CHECK: <key>file</key><integer>0</integer> 719// CHECK: </dict> 720// CHECK: <key>ranges</key> 721// CHECK: <array> 722// CHECK: <array> 723// CHECK: <dict> 724// CHECK: <key>line</key><integer>35</integer> 725// CHECK: <key>col</key><integer>33</integer> 726// CHECK: <key>file</key><integer>0</integer> 727// CHECK: </dict> 728// CHECK: <dict> 729// CHECK: <key>line</key><integer>35</integer> 730// CHECK: <key>col</key><integer>50</integer> 731// CHECK: <key>file</key><integer>0</integer> 732// CHECK: </dict> 733// CHECK: </array> 734// CHECK: </array> 735// CHECK: <key>depth</key><integer>3</integer> 736// CHECK: <key>extended_message</key> 737// CHECK: <string>Returning to caller</string> 738// CHECK: <key>message</key> 739// CHECK: <string>Returning to caller</string> 740// CHECK: </dict> 741// CHECK: <dict> 742// CHECK: <key>kind</key><string>control</string> 743// CHECK: <key>edges</key> 744// CHECK: <array> 745// CHECK: <dict> 746// CHECK: <key>start</key> 747// CHECK: <array> 748// CHECK: <dict> 749// CHECK: <key>line</key><integer>35</integer> 750// CHECK: <key>col</key><integer>33</integer> 751// CHECK: <key>file</key><integer>0</integer> 752// CHECK: </dict> 753// CHECK: <dict> 754// CHECK: <key>line</key><integer>35</integer> 755// CHECK: <key>col</key><integer>38</integer> 756// CHECK: <key>file</key><integer>0</integer> 757// CHECK: </dict> 758// CHECK: </array> 759// CHECK: <key>end</key> 760// CHECK: <array> 761// CHECK: <dict> 762// CHECK: <key>line</key><integer>37</integer> 763// CHECK: <key>col</key><integer>7</integer> 764// CHECK: <key>file</key><integer>0</integer> 765// CHECK: </dict> 766// CHECK: <dict> 767// CHECK: <key>line</key><integer>37</integer> 768// CHECK: <key>col</key><integer>8</integer> 769// CHECK: <key>file</key><integer>0</integer> 770// CHECK: </dict> 771// CHECK: </array> 772// CHECK: </dict> 773// CHECK: </array> 774// CHECK: </dict> 775// CHECK: <dict> 776// CHECK: <key>kind</key><string>control</string> 777// CHECK: <key>edges</key> 778// CHECK: <array> 779// CHECK: <dict> 780// CHECK: <key>start</key> 781// CHECK: <array> 782// CHECK: <dict> 783// CHECK: <key>line</key><integer>37</integer> 784// CHECK: <key>col</key><integer>7</integer> 785// CHECK: <key>file</key><integer>0</integer> 786// CHECK: </dict> 787// CHECK: <dict> 788// CHECK: <key>line</key><integer>37</integer> 789// CHECK: <key>col</key><integer>8</integer> 790// CHECK: <key>file</key><integer>0</integer> 791// CHECK: </dict> 792// CHECK: </array> 793// CHECK: <key>end</key> 794// CHECK: <array> 795// CHECK: <dict> 796// CHECK: <key>line</key><integer>40</integer> 797// CHECK: <key>col</key><integer>7</integer> 798// CHECK: <key>file</key><integer>0</integer> 799// CHECK: </dict> 800// CHECK: <dict> 801// CHECK: <key>line</key><integer>40</integer> 802// CHECK: <key>col</key><integer>18</integer> 803// CHECK: <key>file</key><integer>0</integer> 804// CHECK: </dict> 805// CHECK: </array> 806// CHECK: </dict> 807// CHECK: </array> 808// CHECK: </dict> 809// CHECK: <dict> 810// CHECK: <key>kind</key><string>event</string> 811// CHECK: <key>location</key> 812// CHECK: <dict> 813// CHECK: <key>line</key><integer>23</integer> 814// CHECK: <key>col</key><integer>3</integer> 815// CHECK: <key>file</key><integer>0</integer> 816// CHECK: </dict> 817// CHECK: <key>ranges</key> 818// CHECK: <array> 819// CHECK: <array> 820// CHECK: <dict> 821// CHECK: <key>line</key><integer>23</integer> 822// CHECK: <key>col</key><integer>3</integer> 823// CHECK: <key>file</key><integer>0</integer> 824// CHECK: </dict> 825// CHECK: <dict> 826// CHECK: <key>line</key><integer>23</integer> 827// CHECK: <key>col</key><integer>58</integer> 828// CHECK: <key>file</key><integer>0</integer> 829// CHECK: </dict> 830// CHECK: </array> 831// CHECK: </array> 832// CHECK: <key>depth</key><integer>2</integer> 833// CHECK: <key>extended_message</key> 834// CHECK: <string>Returning to caller</string> 835// CHECK: <key>message</key> 836// CHECK: <string>Returning to caller</string> 837// CHECK: </dict> 838// CHECK: <dict> 839// CHECK: <key>kind</key><string>control</string> 840// CHECK: <key>edges</key> 841// CHECK: <array> 842// CHECK: <dict> 843// CHECK: <key>start</key> 844// CHECK: <array> 845// CHECK: <dict> 846// CHECK: <key>line</key><integer>23</integer> 847// CHECK: <key>col</key><integer>3</integer> 848// CHECK: <key>file</key><integer>0</integer> 849// CHECK: </dict> 850// CHECK: <dict> 851// CHECK: <key>line</key><integer>23</integer> 852// CHECK: <key>col</key><integer>16</integer> 853// CHECK: <key>file</key><integer>0</integer> 854// CHECK: </dict> 855// CHECK: </array> 856// CHECK: <key>end</key> 857// CHECK: <array> 858// CHECK: <dict> 859// CHECK: <key>line</key><integer>24</integer> 860// CHECK: <key>col</key><integer>3</integer> 861// CHECK: <key>file</key><integer>0</integer> 862// CHECK: </dict> 863// CHECK: <dict> 864// CHECK: <key>line</key><integer>24</integer> 865// CHECK: <key>col</key><integer>16</integer> 866// CHECK: <key>file</key><integer>0</integer> 867// CHECK: </dict> 868// CHECK: </array> 869// CHECK: </dict> 870// CHECK: </array> 871// CHECK: </dict> 872// CHECK: <dict> 873// CHECK: <key>kind</key><string>event</string> 874// CHECK: <key>location</key> 875// CHECK: <dict> 876// CHECK: <key>line</key><integer>24</integer> 877// CHECK: <key>col</key><integer>3</integer> 878// CHECK: <key>file</key><integer>0</integer> 879// CHECK: </dict> 880// CHECK: <key>ranges</key> 881// CHECK: <array> 882// CHECK: <array> 883// CHECK: <dict> 884// CHECK: <key>line</key><integer>24</integer> 885// CHECK: <key>col</key><integer>3</integer> 886// CHECK: <key>file</key><integer>0</integer> 887// CHECK: </dict> 888// CHECK: <dict> 889// CHECK: <key>line</key><integer>24</integer> 890// CHECK: <key>col</key><integer>58</integer> 891// CHECK: <key>file</key><integer>0</integer> 892// CHECK: </dict> 893// CHECK: </array> 894// CHECK: </array> 895// CHECK: <key>depth</key><integer>2</integer> 896// CHECK: <key>extended_message</key> 897// CHECK: <string>Calling anonymous block</string> 898// CHECK: <key>message</key> 899// CHECK: <string>Calling anonymous block</string> 900// CHECK: </dict> 901// CHECK: <dict> 902// CHECK: <key>kind</key><string>event</string> 903// CHECK: <key>location</key> 904// CHECK: <dict> 905// CHECK: <key>line</key><integer>29</integer> 906// CHECK: <key>col</key><integer>23</integer> 907// CHECK: <key>file</key><integer>0</integer> 908// CHECK: </dict> 909// CHECK: <key>depth</key><integer>3</integer> 910// CHECK: <key>extended_message</key> 911// CHECK: <string>Entered call from 'reallyPerformAction'</string> 912// CHECK: <key>message</key> 913// CHECK: <string>Entered call from 'reallyPerformAction'</string> 914// CHECK: </dict> 915// CHECK: <dict> 916// CHECK: <key>kind</key><string>control</string> 917// CHECK: <key>edges</key> 918// CHECK: <array> 919// CHECK: <dict> 920// CHECK: <key>start</key> 921// CHECK: <array> 922// CHECK: <dict> 923// CHECK: <key>line</key><integer>29</integer> 924// CHECK: <key>col</key><integer>23</integer> 925// CHECK: <key>file</key><integer>0</integer> 926// CHECK: </dict> 927// CHECK: <dict> 928// CHECK: <key>line</key><integer>29</integer> 929// CHECK: <key>col</key><integer>23</integer> 930// CHECK: <key>file</key><integer>0</integer> 931// CHECK: </dict> 932// CHECK: </array> 933// CHECK: <key>end</key> 934// CHECK: <array> 935// CHECK: <dict> 936// CHECK: <key>line</key><integer>31</integer> 937// CHECK: <key>col</key><integer>5</integer> 938// CHECK: <key>file</key><integer>0</integer> 939// CHECK: </dict> 940// CHECK: <dict> 941// CHECK: <key>line</key><integer>31</integer> 942// CHECK: <key>col</key><integer>6</integer> 943// CHECK: <key>file</key><integer>0</integer> 944// CHECK: </dict> 945// CHECK: </array> 946// CHECK: </dict> 947// CHECK: </array> 948// CHECK: </dict> 949// CHECK: <dict> 950// CHECK: <key>kind</key><string>control</string> 951// CHECK: <key>edges</key> 952// CHECK: <array> 953// CHECK: <dict> 954// CHECK: <key>start</key> 955// CHECK: <array> 956// CHECK: <dict> 957// CHECK: <key>line</key><integer>31</integer> 958// CHECK: <key>col</key><integer>5</integer> 959// CHECK: <key>file</key><integer>0</integer> 960// CHECK: </dict> 961// CHECK: <dict> 962// CHECK: <key>line</key><integer>31</integer> 963// CHECK: <key>col</key><integer>6</integer> 964// CHECK: <key>file</key><integer>0</integer> 965// CHECK: </dict> 966// CHECK: </array> 967// CHECK: <key>end</key> 968// CHECK: <array> 969// CHECK: <dict> 970// CHECK: <key>line</key><integer>31</integer> 971// CHECK: <key>col</key><integer>9</integer> 972// CHECK: <key>file</key><integer>0</integer> 973// CHECK: </dict> 974// CHECK: <dict> 975// CHECK: <key>line</key><integer>31</integer> 976// CHECK: <key>col</key><integer>12</integer> 977// CHECK: <key>file</key><integer>0</integer> 978// CHECK: </dict> 979// CHECK: </array> 980// CHECK: </dict> 981// CHECK: </array> 982// CHECK: </dict> 983// CHECK: <dict> 984// CHECK: <key>kind</key><string>event</string> 985// CHECK: <key>location</key> 986// CHECK: <dict> 987// CHECK: <key>line</key><integer>31</integer> 988// CHECK: <key>col</key><integer>9</integer> 989// CHECK: <key>file</key><integer>0</integer> 990// CHECK: </dict> 991// CHECK: <key>ranges</key> 992// CHECK: <array> 993// CHECK: <array> 994// CHECK: <dict> 995// CHECK: <key>line</key><integer>31</integer> 996// CHECK: <key>col</key><integer>9</integer> 997// CHECK: <key>file</key><integer>0</integer> 998// CHECK: </dict> 999// CHECK: <dict> 1000// CHECK: <key>line</key><integer>31</integer> 1001// CHECK: <key>col</key><integer>12</integer> 1002// CHECK: <key>file</key><integer>0</integer> 1003// CHECK: </dict> 1004// CHECK: </array> 1005// CHECK: </array> 1006// CHECK: <key>depth</key><integer>3</integer> 1007// CHECK: <key>extended_message</key> 1008// CHECK: <string>Assuming 'cond' is not equal to 0</string> 1009// CHECK: <key>message</key> 1010// CHECK: <string>Assuming 'cond' is not equal to 0</string> 1011// CHECK: </dict> 1012// CHECK: <dict> 1013// CHECK: <key>kind</key><string>control</string> 1014// CHECK: <key>edges</key> 1015// CHECK: <array> 1016// CHECK: <dict> 1017// CHECK: <key>start</key> 1018// CHECK: <array> 1019// CHECK: <dict> 1020// CHECK: <key>line</key><integer>31</integer> 1021// CHECK: <key>col</key><integer>9</integer> 1022// CHECK: <key>file</key><integer>0</integer> 1023// CHECK: </dict> 1024// CHECK: <dict> 1025// CHECK: <key>line</key><integer>31</integer> 1026// CHECK: <key>col</key><integer>12</integer> 1027// CHECK: <key>file</key><integer>0</integer> 1028// CHECK: </dict> 1029// CHECK: </array> 1030// CHECK: <key>end</key> 1031// CHECK: <array> 1032// CHECK: <dict> 1033// CHECK: <key>line</key><integer>33</integer> 1034// CHECK: <key>col</key><integer>7</integer> 1035// CHECK: <key>file</key><integer>0</integer> 1036// CHECK: </dict> 1037// CHECK: <dict> 1038// CHECK: <key>line</key><integer>33</integer> 1039// CHECK: <key>col</key><integer>14</integer> 1040// CHECK: <key>file</key><integer>0</integer> 1041// CHECK: </dict> 1042// CHECK: </array> 1043// CHECK: </dict> 1044// CHECK: </array> 1045// CHECK: </dict> 1046// CHECK: <dict> 1047// CHECK: <key>kind</key><string>control</string> 1048// CHECK: <key>edges</key> 1049// CHECK: <array> 1050// CHECK: <dict> 1051// CHECK: <key>start</key> 1052// CHECK: <array> 1053// CHECK: <dict> 1054// CHECK: <key>line</key><integer>33</integer> 1055// CHECK: <key>col</key><integer>7</integer> 1056// CHECK: <key>file</key><integer>0</integer> 1057// CHECK: </dict> 1058// CHECK: <dict> 1059// CHECK: <key>line</key><integer>33</integer> 1060// CHECK: <key>col</key><integer>14</integer> 1061// CHECK: <key>file</key><integer>0</integer> 1062// CHECK: </dict> 1063// CHECK: </array> 1064// CHECK: <key>end</key> 1065// CHECK: <array> 1066// CHECK: <dict> 1067// CHECK: <key>line</key><integer>35</integer> 1068// CHECK: <key>col</key><integer>33</integer> 1069// CHECK: <key>file</key><integer>0</integer> 1070// CHECK: </dict> 1071// CHECK: <dict> 1072// CHECK: <key>line</key><integer>35</integer> 1073// CHECK: <key>col</key><integer>38</integer> 1074// CHECK: <key>file</key><integer>0</integer> 1075// CHECK: </dict> 1076// CHECK: </array> 1077// CHECK: </dict> 1078// CHECK: </array> 1079// CHECK: </dict> 1080// CHECK: <dict> 1081// CHECK: <key>kind</key><string>event</string> 1082// CHECK: <key>location</key> 1083// CHECK: <dict> 1084// CHECK: <key>line</key><integer>35</integer> 1085// CHECK: <key>col</key><integer>33</integer> 1086// CHECK: <key>file</key><integer>0</integer> 1087// CHECK: </dict> 1088// CHECK: <key>ranges</key> 1089// CHECK: <array> 1090// CHECK: <array> 1091// CHECK: <dict> 1092// CHECK: <key>line</key><integer>35</integer> 1093// CHECK: <key>col</key><integer>33</integer> 1094// CHECK: <key>file</key><integer>0</integer> 1095// CHECK: </dict> 1096// CHECK: <dict> 1097// CHECK: <key>line</key><integer>35</integer> 1098// CHECK: <key>col</key><integer>50</integer> 1099// CHECK: <key>file</key><integer>0</integer> 1100// CHECK: </dict> 1101// CHECK: </array> 1102// CHECK: </array> 1103// CHECK: <key>depth</key><integer>3</integer> 1104// CHECK: <key>extended_message</key> 1105// CHECK: <string>Calling anonymous block</string> 1106// CHECK: <key>message</key> 1107// CHECK: <string>Calling anonymous block</string> 1108// CHECK: </dict> 1109// CHECK: <dict> 1110// CHECK: <key>kind</key><string>event</string> 1111// CHECK: <key>location</key> 1112// CHECK: <dict> 1113// CHECK: <key>line</key><integer>49</integer> 1114// CHECK: <key>col</key><integer>40</integer> 1115// CHECK: <key>file</key><integer>0</integer> 1116// CHECK: </dict> 1117// CHECK: <key>depth</key><integer>4</integer> 1118// CHECK: <key>extended_message</key> 1119// CHECK: <string>Entered call</string> 1120// CHECK: <key>message</key> 1121// CHECK: <string>Entered call</string> 1122// CHECK: </dict> 1123// CHECK: <dict> 1124// CHECK: <key>kind</key><string>control</string> 1125// CHECK: <key>edges</key> 1126// CHECK: <array> 1127// CHECK: <dict> 1128// CHECK: <key>start</key> 1129// CHECK: <array> 1130// CHECK: <dict> 1131// CHECK: <key>line</key><integer>49</integer> 1132// CHECK: <key>col</key><integer>40</integer> 1133// CHECK: <key>file</key><integer>0</integer> 1134// CHECK: </dict> 1135// CHECK: <dict> 1136// CHECK: <key>line</key><integer>49</integer> 1137// CHECK: <key>col</key><integer>40</integer> 1138// CHECK: <key>file</key><integer>0</integer> 1139// CHECK: </dict> 1140// CHECK: </array> 1141// CHECK: <key>end</key> 1142// CHECK: <array> 1143// CHECK: <dict> 1144// CHECK: <key>line</key><integer>50</integer> 1145// CHECK: <key>col</key><integer>5</integer> 1146// CHECK: <key>file</key><integer>0</integer> 1147// CHECK: </dict> 1148// CHECK: <dict> 1149// CHECK: <key>line</key><integer>50</integer> 1150// CHECK: <key>col</key><integer>17</integer> 1151// CHECK: <key>file</key><integer>0</integer> 1152// CHECK: </dict> 1153// CHECK: </array> 1154// CHECK: </dict> 1155// CHECK: </array> 1156// CHECK: </dict> 1157// CHECK: <dict> 1158// CHECK: <key>kind</key><string>control</string> 1159// CHECK: <key>edges</key> 1160// CHECK: <array> 1161// CHECK: <dict> 1162// CHECK: <key>start</key> 1163// CHECK: <array> 1164// CHECK: <dict> 1165// CHECK: <key>line</key><integer>50</integer> 1166// CHECK: <key>col</key><integer>5</integer> 1167// CHECK: <key>file</key><integer>0</integer> 1168// CHECK: </dict> 1169// CHECK: <dict> 1170// CHECK: <key>line</key><integer>50</integer> 1171// CHECK: <key>col</key><integer>17</integer> 1172// CHECK: <key>file</key><integer>0</integer> 1173// CHECK: </dict> 1174// CHECK: </array> 1175// CHECK: <key>end</key> 1176// CHECK: <array> 1177// CHECK: <dict> 1178// CHECK: <key>line</key><integer>52</integer> 1179// CHECK: <key>col</key><integer>5</integer> 1180// CHECK: <key>file</key><integer>0</integer> 1181// CHECK: </dict> 1182// CHECK: <dict> 1183// CHECK: <key>line</key><integer>52</integer> 1184// CHECK: <key>col</key><integer>10</integer> 1185// CHECK: <key>file</key><integer>0</integer> 1186// CHECK: </dict> 1187// CHECK: </array> 1188// CHECK: </dict> 1189// CHECK: </array> 1190// CHECK: </dict> 1191// CHECK: <dict> 1192// CHECK: <key>kind</key><string>event</string> 1193// CHECK: <key>location</key> 1194// CHECK: <dict> 1195// CHECK: <key>line</key><integer>52</integer> 1196// CHECK: <key>col</key><integer>5</integer> 1197// CHECK: <key>file</key><integer>0</integer> 1198// CHECK: </dict> 1199// CHECK: <key>ranges</key> 1200// CHECK: <array> 1201// CHECK: <array> 1202// CHECK: <dict> 1203// CHECK: <key>line</key><integer>52</integer> 1204// CHECK: <key>col</key><integer>5</integer> 1205// CHECK: <key>file</key><integer>0</integer> 1206// CHECK: </dict> 1207// CHECK: <dict> 1208// CHECK: <key>line</key><integer>52</integer> 1209// CHECK: <key>col</key><integer>21</integer> 1210// CHECK: <key>file</key><integer>0</integer> 1211// CHECK: </dict> 1212// CHECK: </array> 1213// CHECK: </array> 1214// CHECK: <key>depth</key><integer>4</integer> 1215// CHECK: <key>extended_message</key> 1216// CHECK: <string>Object leaked: allocated object is not referenced later in this execution path and has a retain count of +1</string> 1217// CHECK: <key>message</key> 1218// CHECK: <string>Object leaked: allocated object is not referenced later in this execution path and has a retain count of +1</string> 1219// CHECK: </dict> 1220// CHECK: </array> 1221// CHECK: <key>description</key><string>Potential leak of an object</string> 1222// CHECK: <key>category</key><string>Memory (Core Foundation/Objective-C)</string> 1223// CHECK: <key>type</key><string>Leak</string> 1224// CHECK: <key>location</key> 1225// CHECK: <dict> 1226// CHECK: <key>line</key><integer>52</integer> 1227// CHECK: <key>col</key><integer>5</integer> 1228// CHECK: <key>file</key><integer>0</integer> 1229// CHECK: </dict> 1230// CHECK: </dict> 1231// CHECK: </array> 1232// CHECK:</dict> 1233// CHECK:</plist> 1234