1 // RUN: %clang_cc1 -analyze -analyzer-checker=core -analyzer-output=text -analyzer-config graph-trim-interval=5 -verify %s 2 // RUN: %clang_cc1 -analyze -analyzer-checker=core -analyzer-output=plist-multi-file -analyzer-config graph-trim-interval=5 %s -o %t.plist 3 // RUN: FileCheck --input-file=%t.plist %s 4 5 void use(int *ptr, int val) { 6 *ptr = val; // expected-warning {{Dereference of null pointer (loaded from variable 'ptr')}} 7 // expected-note@-1 {{Dereference of null pointer (loaded from variable 'ptr')}} 8 } 9 10 int compute() { 11 // Do something that will take enough processing to trigger trimming. 12 // FIXME: This is actually really sensitive. If the interval timing is just 13 // wrong, the node for the actual dereference may also be collected, and all 14 // the path notes will disappear. <rdar://problem/12511814> 15 return 2 + 3 + 4 + 5 + 6; 16 } 17 18 void testSimple() { 19 int *p = 0; 20 // expected-note@-1 {{'p' initialized to a null pointer value}} 21 use(p, compute()); 22 // expected-note@-1 {{Passing null pointer value via 1st parameter 'ptr'}} 23 // expected-note@-2 {{Calling 'use'}} 24 } 25 26 27 void use2(int *ptr, int val) { 28 *ptr = val; // expected-warning {{Dereference of null pointer (loaded from variable 'ptr')}} 29 // expected-note@-1 {{Dereference of null pointer (loaded from variable 'ptr')}} 30 } 31 32 void passThrough(int *p) { 33 use2(p, compute()); 34 // expected-note@-1 {{Passing null pointer value via 1st parameter 'ptr'}} 35 // expected-note@-2 {{Calling 'use2'}} 36 } 37 38 void testChainedCalls() { 39 int *ptr = 0; 40 // expected-note@-1 {{'ptr' initialized to a null pointer value}} 41 passThrough(ptr); 42 // expected-note@-1 {{Passing null pointer value via 1st parameter 'p'}} 43 // expected-note@-2 {{Calling 'passThrough'}} 44 } 45 46 // CHECK: <key>diagnostics</key> 47 // CHECK-NEXT: <array> 48 // CHECK-NEXT: <dict> 49 // CHECK-NEXT: <key>path</key> 50 // CHECK-NEXT: <array> 51 // CHECK-NEXT: <dict> 52 // CHECK-NEXT: <key>kind</key><string>event</string> 53 // CHECK-NEXT: <key>location</key> 54 // CHECK-NEXT: <dict> 55 // CHECK-NEXT: <key>line</key><integer>19</integer> 56 // CHECK-NEXT: <key>col</key><integer>3</integer> 57 // CHECK-NEXT: <key>file</key><integer>0</integer> 58 // CHECK-NEXT: </dict> 59 // CHECK-NEXT: <key>ranges</key> 60 // CHECK-NEXT: <array> 61 // CHECK-NEXT: <array> 62 // CHECK-NEXT: <dict> 63 // CHECK-NEXT: <key>line</key><integer>19</integer> 64 // CHECK-NEXT: <key>col</key><integer>3</integer> 65 // CHECK-NEXT: <key>file</key><integer>0</integer> 66 // CHECK-NEXT: </dict> 67 // CHECK-NEXT: <dict> 68 // CHECK-NEXT: <key>line</key><integer>19</integer> 69 // CHECK-NEXT: <key>col</key><integer>8</integer> 70 // CHECK-NEXT: <key>file</key><integer>0</integer> 71 // CHECK-NEXT: </dict> 72 // CHECK-NEXT: </array> 73 // CHECK-NEXT: </array> 74 // CHECK-NEXT: <key>depth</key><integer>0</integer> 75 // CHECK-NEXT: <key>extended_message</key> 76 // CHECK-NEXT: <string>'p' initialized to a null pointer value</string> 77 // CHECK-NEXT: <key>message</key> 78 // CHECK-NEXT: <string>'p' initialized to a null pointer value</string> 79 // CHECK-NEXT: </dict> 80 // CHECK-NEXT: <dict> 81 // CHECK-NEXT: <key>kind</key><string>control</string> 82 // CHECK-NEXT: <key>edges</key> 83 // CHECK-NEXT: <array> 84 // CHECK-NEXT: <dict> 85 // CHECK-NEXT: <key>start</key> 86 // CHECK-NEXT: <array> 87 // CHECK-NEXT: <dict> 88 // CHECK-NEXT: <key>line</key><integer>19</integer> 89 // CHECK-NEXT: <key>col</key><integer>3</integer> 90 // CHECK-NEXT: <key>file</key><integer>0</integer> 91 // CHECK-NEXT: </dict> 92 // CHECK-NEXT: <dict> 93 // CHECK-NEXT: <key>line</key><integer>19</integer> 94 // CHECK-NEXT: <key>col</key><integer>5</integer> 95 // CHECK-NEXT: <key>file</key><integer>0</integer> 96 // CHECK-NEXT: </dict> 97 // CHECK-NEXT: </array> 98 // CHECK-NEXT: <key>end</key> 99 // CHECK-NEXT: <array> 100 // CHECK-NEXT: <dict> 101 // CHECK-NEXT: <key>line</key><integer>21</integer> 102 // CHECK-NEXT: <key>col</key><integer>10</integer> 103 // CHECK-NEXT: <key>file</key><integer>0</integer> 104 // CHECK-NEXT: </dict> 105 // CHECK-NEXT: <dict> 106 // CHECK-NEXT: <key>line</key><integer>21</integer> 107 // CHECK-NEXT: <key>col</key><integer>16</integer> 108 // CHECK-NEXT: <key>file</key><integer>0</integer> 109 // CHECK-NEXT: </dict> 110 // CHECK-NEXT: </array> 111 // CHECK-NEXT: </dict> 112 // CHECK-NEXT: </array> 113 // CHECK-NEXT: </dict> 114 // CHECK-NEXT: <dict> 115 // CHECK-NEXT: <key>kind</key><string>control</string> 116 // CHECK-NEXT: <key>edges</key> 117 // CHECK-NEXT: <array> 118 // CHECK-NEXT: <dict> 119 // CHECK-NEXT: <key>start</key> 120 // CHECK-NEXT: <array> 121 // CHECK-NEXT: <dict> 122 // CHECK-NEXT: <key>line</key><integer>21</integer> 123 // CHECK-NEXT: <key>col</key><integer>3</integer> 124 // CHECK-NEXT: <key>file</key><integer>0</integer> 125 // CHECK-NEXT: </dict> 126 // CHECK-NEXT: <dict> 127 // CHECK-NEXT: <key>line</key><integer>21</integer> 128 // CHECK-NEXT: <key>col</key><integer>5</integer> 129 // CHECK-NEXT: <key>file</key><integer>0</integer> 130 // CHECK-NEXT: </dict> 131 // CHECK-NEXT: </array> 132 // CHECK-NEXT: <key>end</key> 133 // CHECK-NEXT: <array> 134 // CHECK-NEXT: <dict> 135 // CHECK-NEXT: <key>line</key><integer>21</integer> 136 // CHECK-NEXT: <key>col</key><integer>10</integer> 137 // CHECK-NEXT: <key>file</key><integer>0</integer> 138 // CHECK-NEXT: </dict> 139 // CHECK-NEXT: <dict> 140 // CHECK-NEXT: <key>line</key><integer>21</integer> 141 // CHECK-NEXT: <key>col</key><integer>16</integer> 142 // CHECK-NEXT: <key>file</key><integer>0</integer> 143 // CHECK-NEXT: </dict> 144 // CHECK-NEXT: </array> 145 // CHECK-NEXT: </dict> 146 // CHECK-NEXT: </array> 147 // CHECK-NEXT: </dict> 148 // CHECK-NEXT: <dict> 149 // CHECK-NEXT: <key>kind</key><string>control</string> 150 // CHECK-NEXT: <key>edges</key> 151 // CHECK-NEXT: <array> 152 // CHECK-NEXT: <dict> 153 // CHECK-NEXT: <key>start</key> 154 // CHECK-NEXT: <array> 155 // CHECK-NEXT: <dict> 156 // CHECK-NEXT: <key>line</key><integer>21</integer> 157 // CHECK-NEXT: <key>col</key><integer>10</integer> 158 // CHECK-NEXT: <key>file</key><integer>0</integer> 159 // CHECK-NEXT: </dict> 160 // CHECK-NEXT: <dict> 161 // CHECK-NEXT: <key>line</key><integer>21</integer> 162 // CHECK-NEXT: <key>col</key><integer>16</integer> 163 // CHECK-NEXT: <key>file</key><integer>0</integer> 164 // CHECK-NEXT: </dict> 165 // CHECK-NEXT: </array> 166 // CHECK-NEXT: <key>end</key> 167 // CHECK-NEXT: <array> 168 // CHECK-NEXT: <dict> 169 // CHECK-NEXT: <key>line</key><integer>21</integer> 170 // CHECK-NEXT: <key>col</key><integer>7</integer> 171 // CHECK-NEXT: <key>file</key><integer>0</integer> 172 // CHECK-NEXT: </dict> 173 // CHECK-NEXT: <dict> 174 // CHECK-NEXT: <key>line</key><integer>21</integer> 175 // CHECK-NEXT: <key>col</key><integer>7</integer> 176 // CHECK-NEXT: <key>file</key><integer>0</integer> 177 // CHECK-NEXT: </dict> 178 // CHECK-NEXT: </array> 179 // CHECK-NEXT: </dict> 180 // CHECK-NEXT: </array> 181 // CHECK-NEXT: </dict> 182 // CHECK-NEXT: <dict> 183 // CHECK-NEXT: <key>kind</key><string>event</string> 184 // CHECK-NEXT: <key>location</key> 185 // CHECK-NEXT: <dict> 186 // CHECK-NEXT: <key>line</key><integer>21</integer> 187 // CHECK-NEXT: <key>col</key><integer>7</integer> 188 // CHECK-NEXT: <key>file</key><integer>0</integer> 189 // CHECK-NEXT: </dict> 190 // CHECK-NEXT: <key>ranges</key> 191 // CHECK-NEXT: <array> 192 // CHECK-NEXT: <array> 193 // CHECK-NEXT: <dict> 194 // CHECK-NEXT: <key>line</key><integer>21</integer> 195 // CHECK-NEXT: <key>col</key><integer>7</integer> 196 // CHECK-NEXT: <key>file</key><integer>0</integer> 197 // CHECK-NEXT: </dict> 198 // CHECK-NEXT: <dict> 199 // CHECK-NEXT: <key>line</key><integer>21</integer> 200 // CHECK-NEXT: <key>col</key><integer>7</integer> 201 // CHECK-NEXT: <key>file</key><integer>0</integer> 202 // CHECK-NEXT: </dict> 203 // CHECK-NEXT: </array> 204 // CHECK-NEXT: </array> 205 // CHECK-NEXT: <key>depth</key><integer>0</integer> 206 // CHECK-NEXT: <key>extended_message</key> 207 // CHECK-NEXT: <string>Passing null pointer value via 1st parameter 'ptr'</string> 208 // CHECK-NEXT: <key>message</key> 209 // CHECK-NEXT: <string>Passing null pointer value via 1st parameter 'ptr'</string> 210 // CHECK-NEXT: </dict> 211 // CHECK-NEXT: <dict> 212 // CHECK-NEXT: <key>kind</key><string>event</string> 213 // CHECK-NEXT: <key>location</key> 214 // CHECK-NEXT: <dict> 215 // CHECK-NEXT: <key>line</key><integer>21</integer> 216 // CHECK-NEXT: <key>col</key><integer>3</integer> 217 // CHECK-NEXT: <key>file</key><integer>0</integer> 218 // CHECK-NEXT: </dict> 219 // CHECK-NEXT: <key>ranges</key> 220 // CHECK-NEXT: <array> 221 // CHECK-NEXT: <array> 222 // CHECK-NEXT: <dict> 223 // CHECK-NEXT: <key>line</key><integer>21</integer> 224 // CHECK-NEXT: <key>col</key><integer>3</integer> 225 // CHECK-NEXT: <key>file</key><integer>0</integer> 226 // CHECK-NEXT: </dict> 227 // CHECK-NEXT: <dict> 228 // CHECK-NEXT: <key>line</key><integer>21</integer> 229 // CHECK-NEXT: <key>col</key><integer>19</integer> 230 // CHECK-NEXT: <key>file</key><integer>0</integer> 231 // CHECK-NEXT: </dict> 232 // CHECK-NEXT: </array> 233 // CHECK-NEXT: </array> 234 // CHECK-NEXT: <key>depth</key><integer>0</integer> 235 // CHECK-NEXT: <key>extended_message</key> 236 // CHECK-NEXT: <string>Calling 'use'</string> 237 // CHECK-NEXT: <key>message</key> 238 // CHECK-NEXT: <string>Calling 'use'</string> 239 // CHECK-NEXT: </dict> 240 // CHECK-NEXT: <dict> 241 // CHECK-NEXT: <key>kind</key><string>event</string> 242 // CHECK-NEXT: <key>location</key> 243 // CHECK-NEXT: <dict> 244 // CHECK-NEXT: <key>line</key><integer>5</integer> 245 // CHECK-NEXT: <key>col</key><integer>1</integer> 246 // CHECK-NEXT: <key>file</key><integer>0</integer> 247 // CHECK-NEXT: </dict> 248 // CHECK-NEXT: <key>depth</key><integer>1</integer> 249 // CHECK-NEXT: <key>extended_message</key> 250 // CHECK-NEXT: <string>Entered call from 'testSimple'</string> 251 // CHECK-NEXT: <key>message</key> 252 // CHECK-NEXT: <string>Entered call from 'testSimple'</string> 253 // CHECK-NEXT: </dict> 254 // CHECK-NEXT: <dict> 255 // CHECK-NEXT: <key>kind</key><string>control</string> 256 // CHECK-NEXT: <key>edges</key> 257 // CHECK-NEXT: <array> 258 // CHECK-NEXT: <dict> 259 // CHECK-NEXT: <key>start</key> 260 // CHECK-NEXT: <array> 261 // CHECK-NEXT: <dict> 262 // CHECK-NEXT: <key>line</key><integer>5</integer> 263 // CHECK-NEXT: <key>col</key><integer>1</integer> 264 // CHECK-NEXT: <key>file</key><integer>0</integer> 265 // CHECK-NEXT: </dict> 266 // CHECK-NEXT: <dict> 267 // CHECK-NEXT: <key>line</key><integer>5</integer> 268 // CHECK-NEXT: <key>col</key><integer>4</integer> 269 // CHECK-NEXT: <key>file</key><integer>0</integer> 270 // CHECK-NEXT: </dict> 271 // CHECK-NEXT: </array> 272 // CHECK-NEXT: <key>end</key> 273 // CHECK-NEXT: <array> 274 // CHECK-NEXT: <dict> 275 // CHECK-NEXT: <key>line</key><integer>6</integer> 276 // CHECK-NEXT: <key>col</key><integer>3</integer> 277 // CHECK-NEXT: <key>file</key><integer>0</integer> 278 // CHECK-NEXT: </dict> 279 // CHECK-NEXT: <dict> 280 // CHECK-NEXT: <key>line</key><integer>6</integer> 281 // CHECK-NEXT: <key>col</key><integer>3</integer> 282 // CHECK-NEXT: <key>file</key><integer>0</integer> 283 // CHECK-NEXT: </dict> 284 // CHECK-NEXT: </array> 285 // CHECK-NEXT: </dict> 286 // CHECK-NEXT: </array> 287 // CHECK-NEXT: </dict> 288 // CHECK-NEXT: <dict> 289 // CHECK-NEXT: <key>kind</key><string>event</string> 290 // CHECK-NEXT: <key>location</key> 291 // CHECK-NEXT: <dict> 292 // CHECK-NEXT: <key>line</key><integer>6</integer> 293 // CHECK-NEXT: <key>col</key><integer>3</integer> 294 // CHECK-NEXT: <key>file</key><integer>0</integer> 295 // CHECK-NEXT: </dict> 296 // CHECK-NEXT: <key>ranges</key> 297 // CHECK-NEXT: <array> 298 // CHECK-NEXT: <array> 299 // CHECK-NEXT: <dict> 300 // CHECK-NEXT: <key>line</key><integer>6</integer> 301 // CHECK-NEXT: <key>col</key><integer>4</integer> 302 // CHECK-NEXT: <key>file</key><integer>0</integer> 303 // CHECK-NEXT: </dict> 304 // CHECK-NEXT: <dict> 305 // CHECK-NEXT: <key>line</key><integer>6</integer> 306 // CHECK-NEXT: <key>col</key><integer>6</integer> 307 // CHECK-NEXT: <key>file</key><integer>0</integer> 308 // CHECK-NEXT: </dict> 309 // CHECK-NEXT: </array> 310 // CHECK-NEXT: </array> 311 // CHECK-NEXT: <key>depth</key><integer>1</integer> 312 // CHECK-NEXT: <key>extended_message</key> 313 // CHECK-NEXT: <string>Dereference of null pointer (loaded from variable 'ptr')</string> 314 // CHECK-NEXT: <key>message</key> 315 // CHECK-NEXT: <string>Dereference of null pointer (loaded from variable 'ptr')</string> 316 // CHECK-NEXT: </dict> 317 // CHECK-NEXT: </array> 318 // CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable 'ptr')</string> 319 // CHECK-NEXT: <key>category</key><string>Logic error</string> 320 // CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string> 321 // CHECK-NEXT: <key>issue_context_kind</key><string>function</string> 322 // CHECK-NEXT: <key>issue_context</key><string>use</string> 323 // CHECK-NEXT: <key>issue_hash</key><string>1</string> 324 // CHECK-NEXT: <key>location</key> 325 // CHECK-NEXT: <dict> 326 // CHECK-NEXT: <key>line</key><integer>6</integer> 327 // CHECK-NEXT: <key>col</key><integer>3</integer> 328 // CHECK-NEXT: <key>file</key><integer>0</integer> 329 // CHECK-NEXT: </dict> 330 // CHECK-NEXT: </dict> 331 // CHECK-NEXT: <dict> 332 // CHECK-NEXT: <key>path</key> 333 // CHECK-NEXT: <array> 334 // CHECK-NEXT: <dict> 335 // CHECK-NEXT: <key>kind</key><string>event</string> 336 // CHECK-NEXT: <key>location</key> 337 // CHECK-NEXT: <dict> 338 // CHECK-NEXT: <key>line</key><integer>39</integer> 339 // CHECK-NEXT: <key>col</key><integer>3</integer> 340 // CHECK-NEXT: <key>file</key><integer>0</integer> 341 // CHECK-NEXT: </dict> 342 // CHECK-NEXT: <key>ranges</key> 343 // CHECK-NEXT: <array> 344 // CHECK-NEXT: <array> 345 // CHECK-NEXT: <dict> 346 // CHECK-NEXT: <key>line</key><integer>39</integer> 347 // CHECK-NEXT: <key>col</key><integer>3</integer> 348 // CHECK-NEXT: <key>file</key><integer>0</integer> 349 // CHECK-NEXT: </dict> 350 // CHECK-NEXT: <dict> 351 // CHECK-NEXT: <key>line</key><integer>39</integer> 352 // CHECK-NEXT: <key>col</key><integer>10</integer> 353 // CHECK-NEXT: <key>file</key><integer>0</integer> 354 // CHECK-NEXT: </dict> 355 // CHECK-NEXT: </array> 356 // CHECK-NEXT: </array> 357 // CHECK-NEXT: <key>depth</key><integer>0</integer> 358 // CHECK-NEXT: <key>extended_message</key> 359 // CHECK-NEXT: <string>'ptr' initialized to a null pointer value</string> 360 // CHECK-NEXT: <key>message</key> 361 // CHECK-NEXT: <string>'ptr' initialized to a null pointer value</string> 362 // CHECK-NEXT: </dict> 363 // CHECK-NEXT: <dict> 364 // CHECK-NEXT: <key>kind</key><string>control</string> 365 // CHECK-NEXT: <key>edges</key> 366 // CHECK-NEXT: <array> 367 // CHECK-NEXT: <dict> 368 // CHECK-NEXT: <key>start</key> 369 // CHECK-NEXT: <array> 370 // CHECK-NEXT: <dict> 371 // CHECK-NEXT: <key>line</key><integer>39</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: <dict> 376 // CHECK-NEXT: <key>line</key><integer>39</integer> 377 // CHECK-NEXT: <key>col</key><integer>5</integer> 378 // CHECK-NEXT: <key>file</key><integer>0</integer> 379 // CHECK-NEXT: </dict> 380 // CHECK-NEXT: </array> 381 // CHECK-NEXT: <key>end</key> 382 // CHECK-NEXT: <array> 383 // CHECK-NEXT: <dict> 384 // CHECK-NEXT: <key>line</key><integer>41</integer> 385 // CHECK-NEXT: <key>col</key><integer>3</integer> 386 // CHECK-NEXT: <key>file</key><integer>0</integer> 387 // CHECK-NEXT: </dict> 388 // CHECK-NEXT: <dict> 389 // CHECK-NEXT: <key>line</key><integer>41</integer> 390 // CHECK-NEXT: <key>col</key><integer>13</integer> 391 // CHECK-NEXT: <key>file</key><integer>0</integer> 392 // CHECK-NEXT: </dict> 393 // CHECK-NEXT: </array> 394 // CHECK-NEXT: </dict> 395 // CHECK-NEXT: </array> 396 // CHECK-NEXT: </dict> 397 // CHECK-NEXT: <dict> 398 // CHECK-NEXT: <key>kind</key><string>control</string> 399 // CHECK-NEXT: <key>edges</key> 400 // CHECK-NEXT: <array> 401 // CHECK-NEXT: <dict> 402 // CHECK-NEXT: <key>start</key> 403 // CHECK-NEXT: <array> 404 // CHECK-NEXT: <dict> 405 // CHECK-NEXT: <key>line</key><integer>41</integer> 406 // CHECK-NEXT: <key>col</key><integer>3</integer> 407 // CHECK-NEXT: <key>file</key><integer>0</integer> 408 // CHECK-NEXT: </dict> 409 // CHECK-NEXT: <dict> 410 // CHECK-NEXT: <key>line</key><integer>41</integer> 411 // CHECK-NEXT: <key>col</key><integer>13</integer> 412 // CHECK-NEXT: <key>file</key><integer>0</integer> 413 // CHECK-NEXT: </dict> 414 // CHECK-NEXT: </array> 415 // CHECK-NEXT: <key>end</key> 416 // CHECK-NEXT: <array> 417 // CHECK-NEXT: <dict> 418 // CHECK-NEXT: <key>line</key><integer>41</integer> 419 // CHECK-NEXT: <key>col</key><integer>15</integer> 420 // CHECK-NEXT: <key>file</key><integer>0</integer> 421 // CHECK-NEXT: </dict> 422 // CHECK-NEXT: <dict> 423 // CHECK-NEXT: <key>line</key><integer>41</integer> 424 // CHECK-NEXT: <key>col</key><integer>17</integer> 425 // CHECK-NEXT: <key>file</key><integer>0</integer> 426 // CHECK-NEXT: </dict> 427 // CHECK-NEXT: </array> 428 // CHECK-NEXT: </dict> 429 // CHECK-NEXT: </array> 430 // CHECK-NEXT: </dict> 431 // CHECK-NEXT: <dict> 432 // CHECK-NEXT: <key>kind</key><string>event</string> 433 // CHECK-NEXT: <key>location</key> 434 // CHECK-NEXT: <dict> 435 // CHECK-NEXT: <key>line</key><integer>41</integer> 436 // CHECK-NEXT: <key>col</key><integer>15</integer> 437 // CHECK-NEXT: <key>file</key><integer>0</integer> 438 // CHECK-NEXT: </dict> 439 // CHECK-NEXT: <key>ranges</key> 440 // CHECK-NEXT: <array> 441 // CHECK-NEXT: <array> 442 // CHECK-NEXT: <dict> 443 // CHECK-NEXT: <key>line</key><integer>41</integer> 444 // CHECK-NEXT: <key>col</key><integer>15</integer> 445 // CHECK-NEXT: <key>file</key><integer>0</integer> 446 // CHECK-NEXT: </dict> 447 // CHECK-NEXT: <dict> 448 // CHECK-NEXT: <key>line</key><integer>41</integer> 449 // CHECK-NEXT: <key>col</key><integer>17</integer> 450 // CHECK-NEXT: <key>file</key><integer>0</integer> 451 // CHECK-NEXT: </dict> 452 // CHECK-NEXT: </array> 453 // CHECK-NEXT: </array> 454 // CHECK-NEXT: <key>depth</key><integer>0</integer> 455 // CHECK-NEXT: <key>extended_message</key> 456 // CHECK-NEXT: <string>Passing null pointer value via 1st parameter 'p'</string> 457 // CHECK-NEXT: <key>message</key> 458 // CHECK-NEXT: <string>Passing null pointer value via 1st parameter 'p'</string> 459 // CHECK-NEXT: </dict> 460 // CHECK-NEXT: <dict> 461 // CHECK-NEXT: <key>kind</key><string>event</string> 462 // CHECK-NEXT: <key>location</key> 463 // CHECK-NEXT: <dict> 464 // CHECK-NEXT: <key>line</key><integer>41</integer> 465 // CHECK-NEXT: <key>col</key><integer>3</integer> 466 // CHECK-NEXT: <key>file</key><integer>0</integer> 467 // CHECK-NEXT: </dict> 468 // CHECK-NEXT: <key>ranges</key> 469 // CHECK-NEXT: <array> 470 // CHECK-NEXT: <array> 471 // CHECK-NEXT: <dict> 472 // CHECK-NEXT: <key>line</key><integer>41</integer> 473 // CHECK-NEXT: <key>col</key><integer>3</integer> 474 // CHECK-NEXT: <key>file</key><integer>0</integer> 475 // CHECK-NEXT: </dict> 476 // CHECK-NEXT: <dict> 477 // CHECK-NEXT: <key>line</key><integer>41</integer> 478 // CHECK-NEXT: <key>col</key><integer>18</integer> 479 // CHECK-NEXT: <key>file</key><integer>0</integer> 480 // CHECK-NEXT: </dict> 481 // CHECK-NEXT: </array> 482 // CHECK-NEXT: </array> 483 // CHECK-NEXT: <key>depth</key><integer>0</integer> 484 // CHECK-NEXT: <key>extended_message</key> 485 // CHECK-NEXT: <string>Calling 'passThrough'</string> 486 // CHECK-NEXT: <key>message</key> 487 // CHECK-NEXT: <string>Calling 'passThrough'</string> 488 // CHECK-NEXT: </dict> 489 // CHECK-NEXT: <dict> 490 // CHECK-NEXT: <key>kind</key><string>event</string> 491 // CHECK-NEXT: <key>location</key> 492 // CHECK-NEXT: <dict> 493 // CHECK-NEXT: <key>line</key><integer>32</integer> 494 // CHECK-NEXT: <key>col</key><integer>1</integer> 495 // CHECK-NEXT: <key>file</key><integer>0</integer> 496 // CHECK-NEXT: </dict> 497 // CHECK-NEXT: <key>depth</key><integer>1</integer> 498 // CHECK-NEXT: <key>extended_message</key> 499 // CHECK-NEXT: <string>Entered call from 'testChainedCalls'</string> 500 // CHECK-NEXT: <key>message</key> 501 // CHECK-NEXT: <string>Entered call from 'testChainedCalls'</string> 502 // CHECK-NEXT: </dict> 503 // CHECK-NEXT: <dict> 504 // CHECK-NEXT: <key>kind</key><string>control</string> 505 // CHECK-NEXT: <key>edges</key> 506 // CHECK-NEXT: <array> 507 // CHECK-NEXT: <dict> 508 // CHECK-NEXT: <key>start</key> 509 // CHECK-NEXT: <array> 510 // CHECK-NEXT: <dict> 511 // CHECK-NEXT: <key>line</key><integer>32</integer> 512 // CHECK-NEXT: <key>col</key><integer>1</integer> 513 // CHECK-NEXT: <key>file</key><integer>0</integer> 514 // CHECK-NEXT: </dict> 515 // CHECK-NEXT: <dict> 516 // CHECK-NEXT: <key>line</key><integer>32</integer> 517 // CHECK-NEXT: <key>col</key><integer>4</integer> 518 // CHECK-NEXT: <key>file</key><integer>0</integer> 519 // CHECK-NEXT: </dict> 520 // CHECK-NEXT: </array> 521 // CHECK-NEXT: <key>end</key> 522 // CHECK-NEXT: <array> 523 // CHECK-NEXT: <dict> 524 // CHECK-NEXT: <key>line</key><integer>33</integer> 525 // CHECK-NEXT: <key>col</key><integer>3</integer> 526 // CHECK-NEXT: <key>file</key><integer>0</integer> 527 // CHECK-NEXT: </dict> 528 // CHECK-NEXT: <dict> 529 // CHECK-NEXT: <key>line</key><integer>33</integer> 530 // CHECK-NEXT: <key>col</key><integer>6</integer> 531 // CHECK-NEXT: <key>file</key><integer>0</integer> 532 // CHECK-NEXT: </dict> 533 // CHECK-NEXT: </array> 534 // CHECK-NEXT: </dict> 535 // CHECK-NEXT: </array> 536 // CHECK-NEXT: </dict> 537 // CHECK-NEXT: <dict> 538 // CHECK-NEXT: <key>kind</key><string>control</string> 539 // CHECK-NEXT: <key>edges</key> 540 // CHECK-NEXT: <array> 541 // CHECK-NEXT: <dict> 542 // CHECK-NEXT: <key>start</key> 543 // CHECK-NEXT: <array> 544 // CHECK-NEXT: <dict> 545 // CHECK-NEXT: <key>line</key><integer>33</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>33</integer> 551 // CHECK-NEXT: <key>col</key><integer>6</integer> 552 // CHECK-NEXT: <key>file</key><integer>0</integer> 553 // CHECK-NEXT: </dict> 554 // CHECK-NEXT: </array> 555 // CHECK-NEXT: <key>end</key> 556 // CHECK-NEXT: <array> 557 // CHECK-NEXT: <dict> 558 // CHECK-NEXT: <key>line</key><integer>33</integer> 559 // CHECK-NEXT: <key>col</key><integer>11</integer> 560 // CHECK-NEXT: <key>file</key><integer>0</integer> 561 // CHECK-NEXT: </dict> 562 // CHECK-NEXT: <dict> 563 // CHECK-NEXT: <key>line</key><integer>33</integer> 564 // CHECK-NEXT: <key>col</key><integer>17</integer> 565 // CHECK-NEXT: <key>file</key><integer>0</integer> 566 // CHECK-NEXT: </dict> 567 // CHECK-NEXT: </array> 568 // CHECK-NEXT: </dict> 569 // CHECK-NEXT: </array> 570 // CHECK-NEXT: </dict> 571 // CHECK-NEXT: <dict> 572 // CHECK-NEXT: <key>kind</key><string>control</string> 573 // CHECK-NEXT: <key>edges</key> 574 // CHECK-NEXT: <array> 575 // CHECK-NEXT: <dict> 576 // CHECK-NEXT: <key>start</key> 577 // CHECK-NEXT: <array> 578 // CHECK-NEXT: <dict> 579 // CHECK-NEXT: <key>line</key><integer>33</integer> 580 // CHECK-NEXT: <key>col</key><integer>3</integer> 581 // CHECK-NEXT: <key>file</key><integer>0</integer> 582 // CHECK-NEXT: </dict> 583 // CHECK-NEXT: <dict> 584 // CHECK-NEXT: <key>line</key><integer>33</integer> 585 // CHECK-NEXT: <key>col</key><integer>6</integer> 586 // CHECK-NEXT: <key>file</key><integer>0</integer> 587 // CHECK-NEXT: </dict> 588 // CHECK-NEXT: </array> 589 // CHECK-NEXT: <key>end</key> 590 // CHECK-NEXT: <array> 591 // CHECK-NEXT: <dict> 592 // CHECK-NEXT: <key>line</key><integer>33</integer> 593 // CHECK-NEXT: <key>col</key><integer>11</integer> 594 // CHECK-NEXT: <key>file</key><integer>0</integer> 595 // CHECK-NEXT: </dict> 596 // CHECK-NEXT: <dict> 597 // CHECK-NEXT: <key>line</key><integer>33</integer> 598 // CHECK-NEXT: <key>col</key><integer>17</integer> 599 // CHECK-NEXT: <key>file</key><integer>0</integer> 600 // CHECK-NEXT: </dict> 601 // CHECK-NEXT: </array> 602 // CHECK-NEXT: </dict> 603 // CHECK-NEXT: </array> 604 // CHECK-NEXT: </dict> 605 // CHECK-NEXT: <dict> 606 // CHECK-NEXT: <key>kind</key><string>control</string> 607 // CHECK-NEXT: <key>edges</key> 608 // CHECK-NEXT: <array> 609 // CHECK-NEXT: <dict> 610 // CHECK-NEXT: <key>start</key> 611 // CHECK-NEXT: <array> 612 // CHECK-NEXT: <dict> 613 // CHECK-NEXT: <key>line</key><integer>33</integer> 614 // CHECK-NEXT: <key>col</key><integer>11</integer> 615 // CHECK-NEXT: <key>file</key><integer>0</integer> 616 // CHECK-NEXT: </dict> 617 // CHECK-NEXT: <dict> 618 // CHECK-NEXT: <key>line</key><integer>33</integer> 619 // CHECK-NEXT: <key>col</key><integer>17</integer> 620 // CHECK-NEXT: <key>file</key><integer>0</integer> 621 // CHECK-NEXT: </dict> 622 // CHECK-NEXT: </array> 623 // CHECK-NEXT: <key>end</key> 624 // CHECK-NEXT: <array> 625 // CHECK-NEXT: <dict> 626 // CHECK-NEXT: <key>line</key><integer>33</integer> 627 // CHECK-NEXT: <key>col</key><integer>8</integer> 628 // CHECK-NEXT: <key>file</key><integer>0</integer> 629 // CHECK-NEXT: </dict> 630 // CHECK-NEXT: <dict> 631 // CHECK-NEXT: <key>line</key><integer>33</integer> 632 // CHECK-NEXT: <key>col</key><integer>8</integer> 633 // CHECK-NEXT: <key>file</key><integer>0</integer> 634 // CHECK-NEXT: </dict> 635 // CHECK-NEXT: </array> 636 // CHECK-NEXT: </dict> 637 // CHECK-NEXT: </array> 638 // CHECK-NEXT: </dict> 639 // CHECK-NEXT: <dict> 640 // CHECK-NEXT: <key>kind</key><string>event</string> 641 // CHECK-NEXT: <key>location</key> 642 // CHECK-NEXT: <dict> 643 // CHECK-NEXT: <key>line</key><integer>33</integer> 644 // CHECK-NEXT: <key>col</key><integer>8</integer> 645 // CHECK-NEXT: <key>file</key><integer>0</integer> 646 // CHECK-NEXT: </dict> 647 // CHECK-NEXT: <key>ranges</key> 648 // CHECK-NEXT: <array> 649 // CHECK-NEXT: <array> 650 // CHECK-NEXT: <dict> 651 // CHECK-NEXT: <key>line</key><integer>33</integer> 652 // CHECK-NEXT: <key>col</key><integer>8</integer> 653 // CHECK-NEXT: <key>file</key><integer>0</integer> 654 // CHECK-NEXT: </dict> 655 // CHECK-NEXT: <dict> 656 // CHECK-NEXT: <key>line</key><integer>33</integer> 657 // CHECK-NEXT: <key>col</key><integer>8</integer> 658 // CHECK-NEXT: <key>file</key><integer>0</integer> 659 // CHECK-NEXT: </dict> 660 // CHECK-NEXT: </array> 661 // CHECK-NEXT: </array> 662 // CHECK-NEXT: <key>depth</key><integer>1</integer> 663 // CHECK-NEXT: <key>extended_message</key> 664 // CHECK-NEXT: <string>Passing null pointer value via 1st parameter 'ptr'</string> 665 // CHECK-NEXT: <key>message</key> 666 // CHECK-NEXT: <string>Passing null pointer value via 1st parameter 'ptr'</string> 667 // CHECK-NEXT: </dict> 668 // CHECK-NEXT: <dict> 669 // CHECK-NEXT: <key>kind</key><string>event</string> 670 // CHECK-NEXT: <key>location</key> 671 // CHECK-NEXT: <dict> 672 // CHECK-NEXT: <key>line</key><integer>33</integer> 673 // CHECK-NEXT: <key>col</key><integer>3</integer> 674 // CHECK-NEXT: <key>file</key><integer>0</integer> 675 // CHECK-NEXT: </dict> 676 // CHECK-NEXT: <key>ranges</key> 677 // CHECK-NEXT: <array> 678 // CHECK-NEXT: <array> 679 // CHECK-NEXT: <dict> 680 // CHECK-NEXT: <key>line</key><integer>33</integer> 681 // CHECK-NEXT: <key>col</key><integer>3</integer> 682 // CHECK-NEXT: <key>file</key><integer>0</integer> 683 // CHECK-NEXT: </dict> 684 // CHECK-NEXT: <dict> 685 // CHECK-NEXT: <key>line</key><integer>33</integer> 686 // CHECK-NEXT: <key>col</key><integer>20</integer> 687 // CHECK-NEXT: <key>file</key><integer>0</integer> 688 // CHECK-NEXT: </dict> 689 // CHECK-NEXT: </array> 690 // CHECK-NEXT: </array> 691 // CHECK-NEXT: <key>depth</key><integer>1</integer> 692 // CHECK-NEXT: <key>extended_message</key> 693 // CHECK-NEXT: <string>Calling 'use2'</string> 694 // CHECK-NEXT: <key>message</key> 695 // CHECK-NEXT: <string>Calling 'use2'</string> 696 // CHECK-NEXT: </dict> 697 // CHECK-NEXT: <dict> 698 // CHECK-NEXT: <key>kind</key><string>event</string> 699 // CHECK-NEXT: <key>location</key> 700 // CHECK-NEXT: <dict> 701 // CHECK-NEXT: <key>line</key><integer>27</integer> 702 // CHECK-NEXT: <key>col</key><integer>1</integer> 703 // CHECK-NEXT: <key>file</key><integer>0</integer> 704 // CHECK-NEXT: </dict> 705 // CHECK-NEXT: <key>depth</key><integer>2</integer> 706 // CHECK-NEXT: <key>extended_message</key> 707 // CHECK-NEXT: <string>Entered call from 'passThrough'</string> 708 // CHECK-NEXT: <key>message</key> 709 // CHECK-NEXT: <string>Entered call from 'passThrough'</string> 710 // CHECK-NEXT: </dict> 711 // CHECK-NEXT: <dict> 712 // CHECK-NEXT: <key>kind</key><string>control</string> 713 // CHECK-NEXT: <key>edges</key> 714 // CHECK-NEXT: <array> 715 // CHECK-NEXT: <dict> 716 // CHECK-NEXT: <key>start</key> 717 // CHECK-NEXT: <array> 718 // CHECK-NEXT: <dict> 719 // CHECK-NEXT: <key>line</key><integer>27</integer> 720 // CHECK-NEXT: <key>col</key><integer>1</integer> 721 // CHECK-NEXT: <key>file</key><integer>0</integer> 722 // CHECK-NEXT: </dict> 723 // CHECK-NEXT: <dict> 724 // CHECK-NEXT: <key>line</key><integer>27</integer> 725 // CHECK-NEXT: <key>col</key><integer>4</integer> 726 // CHECK-NEXT: <key>file</key><integer>0</integer> 727 // CHECK-NEXT: </dict> 728 // CHECK-NEXT: </array> 729 // CHECK-NEXT: <key>end</key> 730 // CHECK-NEXT: <array> 731 // CHECK-NEXT: <dict> 732 // CHECK-NEXT: <key>line</key><integer>28</integer> 733 // CHECK-NEXT: <key>col</key><integer>3</integer> 734 // CHECK-NEXT: <key>file</key><integer>0</integer> 735 // CHECK-NEXT: </dict> 736 // CHECK-NEXT: <dict> 737 // CHECK-NEXT: <key>line</key><integer>28</integer> 738 // CHECK-NEXT: <key>col</key><integer>3</integer> 739 // CHECK-NEXT: <key>file</key><integer>0</integer> 740 // CHECK-NEXT: </dict> 741 // CHECK-NEXT: </array> 742 // CHECK-NEXT: </dict> 743 // CHECK-NEXT: </array> 744 // CHECK-NEXT: </dict> 745 // CHECK-NEXT: <dict> 746 // CHECK-NEXT: <key>kind</key><string>event</string> 747 // CHECK-NEXT: <key>location</key> 748 // CHECK-NEXT: <dict> 749 // CHECK-NEXT: <key>line</key><integer>28</integer> 750 // CHECK-NEXT: <key>col</key><integer>3</integer> 751 // CHECK-NEXT: <key>file</key><integer>0</integer> 752 // CHECK-NEXT: </dict> 753 // CHECK-NEXT: <key>ranges</key> 754 // CHECK-NEXT: <array> 755 // CHECK-NEXT: <array> 756 // CHECK-NEXT: <dict> 757 // CHECK-NEXT: <key>line</key><integer>28</integer> 758 // CHECK-NEXT: <key>col</key><integer>4</integer> 759 // CHECK-NEXT: <key>file</key><integer>0</integer> 760 // CHECK-NEXT: </dict> 761 // CHECK-NEXT: <dict> 762 // CHECK-NEXT: <key>line</key><integer>28</integer> 763 // CHECK-NEXT: <key>col</key><integer>6</integer> 764 // CHECK-NEXT: <key>file</key><integer>0</integer> 765 // CHECK-NEXT: </dict> 766 // CHECK-NEXT: </array> 767 // CHECK-NEXT: </array> 768 // CHECK-NEXT: <key>depth</key><integer>2</integer> 769 // CHECK-NEXT: <key>extended_message</key> 770 // CHECK-NEXT: <string>Dereference of null pointer (loaded from variable 'ptr')</string> 771 // CHECK-NEXT: <key>message</key> 772 // CHECK-NEXT: <string>Dereference of null pointer (loaded from variable 'ptr')</string> 773 // CHECK-NEXT: </dict> 774 // CHECK-NEXT: </array> 775 // CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable 'ptr')</string> 776 // CHECK-NEXT: <key>category</key><string>Logic error</string> 777 // CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string> 778 // CHECK-NEXT: <key>issue_context_kind</key><string>function</string> 779 // CHECK-NEXT: <key>issue_context</key><string>use2</string> 780 // CHECK-NEXT: <key>issue_hash</key><string>1</string> 781 // CHECK-NEXT: <key>location</key> 782 // CHECK-NEXT: <dict> 783 // CHECK-NEXT: <key>line</key><integer>28</integer> 784 // CHECK-NEXT: <key>col</key><integer>3</integer> 785 // CHECK-NEXT: <key>file</key><integer>0</integer> 786 // CHECK-NEXT: </dict> 787 // CHECK-NEXT: </dict> 788 // CHECK-NEXT: </array> 789