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 25 void 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