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