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