unix-fns.c revision cc85d217d329aa3c78aa3f57a238e5b7931ee2c5
1// RUN: %clang_cc1 -triple x86_64-apple-darwin10 -analyze -analyzer-checker=core,unix.API,osx.API %s -analyzer-store=region -analyzer-output=plist -analyzer-ipa=inlining -analyzer-eagerly-assume -analyzer-config faux-bodies=true -fblocks -verify -o %t.plist 2// RUN: FileCheck --input-file=%t.plist %s 3 4struct _opaque_pthread_once_t { 5 long __sig; 6 char __opaque[8]; 7}; 8typedef struct _opaque_pthread_once_t __darwin_pthread_once_t; 9typedef __darwin_pthread_once_t pthread_once_t; 10int pthread_once(pthread_once_t *, void (*)(void)); 11typedef long unsigned int __darwin_size_t; 12typedef __darwin_size_t size_t; 13void *calloc(size_t, size_t); 14void *malloc(size_t); 15void *realloc(void *, size_t); 16void *alloca(size_t); 17void *valloc(size_t); 18 19typedef union { 20 struct _os_object_s *_os_obj; 21 struct dispatch_object_s *_do; 22 struct dispatch_continuation_s *_dc; 23 struct dispatch_queue_s *_dq; 24 struct dispatch_queue_attr_s *_dqa; 25 struct dispatch_group_s *_dg; 26 struct dispatch_source_s *_ds; 27 struct dispatch_source_attr_s *_dsa; 28 struct dispatch_semaphore_s *_dsema; 29 struct dispatch_data_s *_ddata; 30 struct dispatch_io_s *_dchannel; 31 struct dispatch_operation_s *_doperation; 32 struct dispatch_disk_s *_ddisk; 33} dispatch_object_t __attribute__((__transparent_union__)); 34 35typedef void (^dispatch_block_t)(void); 36typedef long dispatch_once_t; 37typedef struct dispatch_queue_s *dispatch_queue_t; 38void dispatch_once(dispatch_once_t *predicate, dispatch_block_t block); 39void dispatch_sync(dispatch_queue_t queue, dispatch_block_t block); 40 41#ifndef O_CREAT 42#define O_CREAT 0x0200 43#define O_RDONLY 0x0000 44#endif 45int open(const char *, int, ...); 46int close(int fildes); 47 48void test_open(const char *path) { 49 int fd; 50 fd = open(path, O_RDONLY); // no-warning 51 if (!fd) 52 close(fd); 53 54 fd = open(path, O_CREAT); // expected-warning{{Call to 'open' requires a third argument when the 'O_CREAT' flag is set}} 55 if (!fd) 56 close(fd); 57} 58 59void test_dispatch_once() { 60 dispatch_once_t pred = 0; 61 do { if (__builtin_expect(*(&pred), ~0l) != ~0l) dispatch_once((&pred), (^() {})); } while (0); // expected-warning{{Call to 'dispatch_once' uses the local variable 'pred' for the predicate value}} 62} 63void test_dispatch_once_neg() { 64 static dispatch_once_t pred = 0; 65 do { if (__builtin_expect(*(&pred), ~0l) != ~0l) dispatch_once((&pred), (^() {})); } while (0); // no-warning 66} 67 68void test_pthread_once_aux(); 69 70void test_pthread_once() { 71 pthread_once_t pred = {0x30B1BCBA, {0}}; 72 pthread_once(&pred, test_pthread_once_aux); // expected-warning{{Call to 'pthread_once' uses the local variable 'pred' for the "control" value}} 73} 74void test_pthread_once_neg() { 75 static pthread_once_t pred = {0x30B1BCBA, {0}}; 76 pthread_once(&pred, test_pthread_once_aux); // no-warning 77} 78 79// PR 2899 - warn of zero-sized allocations to malloc(). 80void pr2899() { 81 char* foo = malloc(0); // expected-warning{{Call to 'malloc' has an allocation size of 0 bytes}} 82 for (unsigned i = 0; i < 100; i++) { 83 foo[i] = 0; 84 } 85} 86void pr2899_nowarn(size_t size) { 87 char* foo = malloc(size); // no-warning 88 for (unsigned i = 0; i < 100; i++) { 89 foo[i] = 0; 90 } 91} 92void test_calloc(void) { 93 char *foo = calloc(0, 42); // expected-warning{{Call to 'calloc' has an allocation size of 0 bytes}} 94 for (unsigned i = 0; i < 100; i++) { 95 foo[i] = 0; 96 } 97} 98void test_calloc2(void) { 99 char *foo = calloc(42, 0); // expected-warning{{Call to 'calloc' has an allocation size of 0 bytes}} 100 for (unsigned i = 0; i < 100; i++) { 101 foo[i] = 0; 102 } 103} 104void test_calloc_nowarn(size_t nmemb, size_t size) { 105 char *foo = calloc(nmemb, size); // no-warning 106 for (unsigned i = 0; i < 100; i++) { 107 foo[i] = 0; 108 } 109} 110void test_realloc(char *ptr) { 111 char *foo = realloc(ptr, 0); // expected-warning{{Call to 'realloc' has an allocation size of 0 bytes}} 112 for (unsigned i = 0; i < 100; i++) { 113 foo[i] = 0; 114 } 115} 116void test_realloc_nowarn(char *ptr, size_t size) { 117 char *foo = realloc(ptr, size); // no-warning 118 for (unsigned i = 0; i < 100; i++) { 119 foo[i] = 0; 120 } 121} 122void test_alloca() { 123 char *foo = alloca(0); // expected-warning{{Call to 'alloca' has an allocation size of 0 bytes}} 124 for(unsigned i = 0; i < 100; i++) { 125 foo[i] = 0; 126 } 127} 128void test_alloca_nowarn(size_t sz) { 129 char *foo = alloca(sz); // no-warning 130 for(unsigned i = 0; i < 100; i++) { 131 foo[i] = 0; 132 } 133} 134void test_builtin_alloca() { 135 char *foo2 = __builtin_alloca(0); // expected-warning{{Call to 'alloca' has an allocation size of 0 bytes}} 136 for(unsigned i = 0; i < 100; i++) { 137 foo2[i] = 0; 138 } 139} 140void test_builtin_alloca_nowarn(size_t sz) { 141 char *foo2 = __builtin_alloca(sz); // no-warning 142 for(unsigned i = 0; i < 100; i++) { 143 foo2[i] = 0; 144 } 145} 146void test_valloc() { 147 char *foo = valloc(0); // expected-warning{{Call to 'valloc' has an allocation size of 0 bytes}} 148 for(unsigned i = 0; i < 100; i++) { 149 foo[i] = 0; 150 } 151} 152void test_valloc_nowarn(size_t sz) { 153 char *foo = valloc(sz); // no-warning 154 for(unsigned i = 0; i < 100; i++) { 155 foo[i] = 0; 156 } 157} 158 159// Test dispatch_once being a macro that wraps a call to _dispatch_once, which in turn 160// calls the real dispatch_once. 161 162static inline void _dispatch_once(dispatch_once_t *predicate, dispatch_block_t block) 163{ 164 dispatch_once(predicate, block); 165} 166 167#define dispatch_once _dispatch_once 168 169void test_dispatch_once_in_macro() { 170 dispatch_once_t pred = 0; 171 dispatch_once(&pred, ^(){}); // expected-warning {{Call to 'dispatch_once' uses the local variable 'pred' for the predicate value}} 172} 173 174// Test inlining of dispatch_sync. 175void test_dispatch_sync(dispatch_queue_t queue, int *q) { 176 int *p = 0; 177 dispatch_sync(queue, ^(void){ 178 if (q) { 179 *p = 1; // expected-warning {{null pointer}} 180 } 181 }); 182} 183 184// Test inlining if dispatch_once. 185void test_inline_dispatch_once() { 186 static dispatch_once_t pred; 187 int *p = 0; 188 dispatch_once(&pred, ^(void) { 189 *p = 1; // expected-warning {{null}} 190 }); 191} 192 193// CHECK: <key>diagnostics</key> 194// CHECK-NEXT: <array> 195// CHECK-NEXT: <dict> 196// CHECK-NEXT: <key>path</key> 197// CHECK-NEXT: <array> 198// CHECK-NEXT: <dict> 199// CHECK-NEXT: <key>kind</key><string>control</string> 200// CHECK-NEXT: <key>edges</key> 201// CHECK-NEXT: <array> 202// CHECK-NEXT: <dict> 203// CHECK-NEXT: <key>start</key> 204// CHECK-NEXT: <array> 205// CHECK-NEXT: <dict> 206// CHECK-NEXT: <key>line</key><integer>49</integer> 207// CHECK-NEXT: <key>col</key><integer>3</integer> 208// CHECK-NEXT: <key>file</key><integer>0</integer> 209// CHECK-NEXT: </dict> 210// CHECK-NEXT: <dict> 211// CHECK-NEXT: <key>line</key><integer>49</integer> 212// CHECK-NEXT: <key>col</key><integer>5</integer> 213// CHECK-NEXT: <key>file</key><integer>0</integer> 214// CHECK-NEXT: </dict> 215// CHECK-NEXT: </array> 216// CHECK-NEXT: <key>end</key> 217// CHECK-NEXT: <array> 218// CHECK-NEXT: <dict> 219// CHECK-NEXT: <key>line</key><integer>51</integer> 220// CHECK-NEXT: <key>col</key><integer>3</integer> 221// CHECK-NEXT: <key>file</key><integer>0</integer> 222// CHECK-NEXT: </dict> 223// CHECK-NEXT: <dict> 224// CHECK-NEXT: <key>line</key><integer>51</integer> 225// CHECK-NEXT: <key>col</key><integer>4</integer> 226// CHECK-NEXT: <key>file</key><integer>0</integer> 227// CHECK-NEXT: </dict> 228// CHECK-NEXT: </array> 229// CHECK-NEXT: </dict> 230// CHECK-NEXT: </array> 231// CHECK-NEXT: </dict> 232// CHECK-NEXT: <dict> 233// CHECK-NEXT: <key>kind</key><string>control</string> 234// CHECK-NEXT: <key>edges</key> 235// CHECK-NEXT: <array> 236// CHECK-NEXT: <dict> 237// CHECK-NEXT: <key>start</key> 238// CHECK-NEXT: <array> 239// CHECK-NEXT: <dict> 240// CHECK-NEXT: <key>line</key><integer>51</integer> 241// CHECK-NEXT: <key>col</key><integer>3</integer> 242// CHECK-NEXT: <key>file</key><integer>0</integer> 243// CHECK-NEXT: </dict> 244// CHECK-NEXT: <dict> 245// CHECK-NEXT: <key>line</key><integer>51</integer> 246// CHECK-NEXT: <key>col</key><integer>4</integer> 247// CHECK-NEXT: <key>file</key><integer>0</integer> 248// CHECK-NEXT: </dict> 249// CHECK-NEXT: </array> 250// CHECK-NEXT: <key>end</key> 251// CHECK-NEXT: <array> 252// CHECK-NEXT: <dict> 253// CHECK-NEXT: <key>line</key><integer>51</integer> 254// CHECK-NEXT: <key>col</key><integer>7</integer> 255// CHECK-NEXT: <key>file</key><integer>0</integer> 256// CHECK-NEXT: </dict> 257// CHECK-NEXT: <dict> 258// CHECK-NEXT: <key>line</key><integer>51</integer> 259// CHECK-NEXT: <key>col</key><integer>7</integer> 260// CHECK-NEXT: <key>file</key><integer>0</integer> 261// CHECK-NEXT: </dict> 262// CHECK-NEXT: </array> 263// CHECK-NEXT: </dict> 264// CHECK-NEXT: </array> 265// CHECK-NEXT: </dict> 266// CHECK-NEXT: <dict> 267// CHECK-NEXT: <key>kind</key><string>event</string> 268// CHECK-NEXT: <key>location</key> 269// CHECK-NEXT: <dict> 270// CHECK-NEXT: <key>line</key><integer>51</integer> 271// CHECK-NEXT: <key>col</key><integer>7</integer> 272// CHECK-NEXT: <key>file</key><integer>0</integer> 273// CHECK-NEXT: </dict> 274// CHECK-NEXT: <key>ranges</key> 275// CHECK-NEXT: <array> 276// CHECK-NEXT: <array> 277// CHECK-NEXT: <dict> 278// CHECK-NEXT: <key>line</key><integer>51</integer> 279// CHECK-NEXT: <key>col</key><integer>7</integer> 280// CHECK-NEXT: <key>file</key><integer>0</integer> 281// CHECK-NEXT: </dict> 282// CHECK-NEXT: <dict> 283// CHECK-NEXT: <key>line</key><integer>51</integer> 284// CHECK-NEXT: <key>col</key><integer>9</integer> 285// CHECK-NEXT: <key>file</key><integer>0</integer> 286// CHECK-NEXT: </dict> 287// CHECK-NEXT: </array> 288// CHECK-NEXT: </array> 289// CHECK-NEXT: <key>depth</key><integer>0</integer> 290// CHECK-NEXT: <key>extended_message</key> 291// CHECK-NEXT: <string>Assuming 'fd' is not equal to 0</string> 292// CHECK-NEXT: <key>message</key> 293// CHECK-NEXT: <string>Assuming 'fd' is not equal to 0</string> 294// CHECK-NEXT: </dict> 295// CHECK-NEXT: <dict> 296// CHECK-NEXT: <key>kind</key><string>control</string> 297// CHECK-NEXT: <key>edges</key> 298// CHECK-NEXT: <array> 299// CHECK-NEXT: <dict> 300// CHECK-NEXT: <key>start</key> 301// CHECK-NEXT: <array> 302// CHECK-NEXT: <dict> 303// CHECK-NEXT: <key>line</key><integer>51</integer> 304// CHECK-NEXT: <key>col</key><integer>7</integer> 305// CHECK-NEXT: <key>file</key><integer>0</integer> 306// CHECK-NEXT: </dict> 307// CHECK-NEXT: <dict> 308// CHECK-NEXT: <key>line</key><integer>51</integer> 309// CHECK-NEXT: <key>col</key><integer>7</integer> 310// CHECK-NEXT: <key>file</key><integer>0</integer> 311// CHECK-NEXT: </dict> 312// CHECK-NEXT: </array> 313// CHECK-NEXT: <key>end</key> 314// CHECK-NEXT: <array> 315// CHECK-NEXT: <dict> 316// CHECK-NEXT: <key>line</key><integer>54</integer> 317// CHECK-NEXT: <key>col</key><integer>3</integer> 318// CHECK-NEXT: <key>file</key><integer>0</integer> 319// CHECK-NEXT: </dict> 320// CHECK-NEXT: <dict> 321// CHECK-NEXT: <key>line</key><integer>54</integer> 322// CHECK-NEXT: <key>col</key><integer>4</integer> 323// CHECK-NEXT: <key>file</key><integer>0</integer> 324// CHECK-NEXT: </dict> 325// CHECK-NEXT: </array> 326// CHECK-NEXT: </dict> 327// CHECK-NEXT: </array> 328// CHECK-NEXT: </dict> 329// CHECK-NEXT: <dict> 330// CHECK-NEXT: <key>kind</key><string>control</string> 331// CHECK-NEXT: <key>edges</key> 332// CHECK-NEXT: <array> 333// CHECK-NEXT: <dict> 334// CHECK-NEXT: <key>start</key> 335// CHECK-NEXT: <array> 336// CHECK-NEXT: <dict> 337// CHECK-NEXT: <key>line</key><integer>54</integer> 338// CHECK-NEXT: <key>col</key><integer>3</integer> 339// CHECK-NEXT: <key>file</key><integer>0</integer> 340// CHECK-NEXT: </dict> 341// CHECK-NEXT: <dict> 342// CHECK-NEXT: <key>line</key><integer>54</integer> 343// CHECK-NEXT: <key>col</key><integer>4</integer> 344// CHECK-NEXT: <key>file</key><integer>0</integer> 345// CHECK-NEXT: </dict> 346// CHECK-NEXT: </array> 347// CHECK-NEXT: <key>end</key> 348// CHECK-NEXT: <array> 349// CHECK-NEXT: <dict> 350// CHECK-NEXT: <key>line</key><integer>54</integer> 351// CHECK-NEXT: <key>col</key><integer>8</integer> 352// CHECK-NEXT: <key>file</key><integer>0</integer> 353// CHECK-NEXT: </dict> 354// CHECK-NEXT: <dict> 355// CHECK-NEXT: <key>line</key><integer>54</integer> 356// CHECK-NEXT: <key>col</key><integer>11</integer> 357// CHECK-NEXT: <key>file</key><integer>0</integer> 358// CHECK-NEXT: </dict> 359// CHECK-NEXT: </array> 360// CHECK-NEXT: </dict> 361// CHECK-NEXT: </array> 362// CHECK-NEXT: </dict> 363// CHECK-NEXT: <dict> 364// CHECK-NEXT: <key>kind</key><string>event</string> 365// CHECK-NEXT: <key>location</key> 366// CHECK-NEXT: <dict> 367// CHECK-NEXT: <key>line</key><integer>54</integer> 368// CHECK-NEXT: <key>col</key><integer>8</integer> 369// CHECK-NEXT: <key>file</key><integer>0</integer> 370// CHECK-NEXT: </dict> 371// CHECK-NEXT: <key>ranges</key> 372// CHECK-NEXT: <array> 373// CHECK-NEXT: <array> 374// CHECK-NEXT: <dict> 375// CHECK-NEXT: <key>line</key><integer>54</integer> 376// CHECK-NEXT: <key>col</key><integer>19</integer> 377// CHECK-NEXT: <key>file</key><integer>0</integer> 378// CHECK-NEXT: </dict> 379// CHECK-NEXT: <dict> 380// CHECK-NEXT: <key>line</key><integer>54</integer> 381// CHECK-NEXT: <key>col</key><integer>25</integer> 382// CHECK-NEXT: <key>file</key><integer>0</integer> 383// CHECK-NEXT: </dict> 384// CHECK-NEXT: </array> 385// CHECK-NEXT: </array> 386// CHECK-NEXT: <key>depth</key><integer>0</integer> 387// CHECK-NEXT: <key>extended_message</key> 388// CHECK-NEXT: <string>Call to 'open' requires a third argument when the 'O_CREAT' flag is set</string> 389// CHECK-NEXT: <key>message</key> 390// CHECK-NEXT: <string>Call to 'open' requires a third argument when the 'O_CREAT' flag is set</string> 391// CHECK-NEXT: </dict> 392// CHECK-NEXT: </array> 393// CHECK-NEXT: <key>description</key><string>Call to 'open' requires a third argument when the 'O_CREAT' flag is set</string> 394// CHECK-NEXT: <key>category</key><string>Unix API</string> 395// CHECK-NEXT: <key>type</key><string>Improper use of 'open'</string> 396// CHECK-NEXT: <key>issue_context_kind</key><string>function</string> 397// CHECK-NEXT: <key>issue_context</key><string>test_open</string> 398// CHECK-NEXT: <key>issue_hash</key><integer>6</integer> 399// CHECK-NEXT: <key>location</key> 400// CHECK-NEXT: <dict> 401// CHECK-NEXT: <key>line</key><integer>54</integer> 402// CHECK-NEXT: <key>col</key><integer>8</integer> 403// CHECK-NEXT: <key>file</key><integer>0</integer> 404// CHECK-NEXT: </dict> 405// CHECK-NEXT: </dict> 406// CHECK-NEXT: <dict> 407// CHECK-NEXT: <key>path</key> 408// CHECK-NEXT: <array> 409// CHECK-NEXT: <dict> 410// CHECK-NEXT: <key>kind</key><string>control</string> 411// CHECK-NEXT: <key>edges</key> 412// CHECK-NEXT: <array> 413// CHECK-NEXT: <dict> 414// CHECK-NEXT: <key>start</key> 415// CHECK-NEXT: <array> 416// CHECK-NEXT: <dict> 417// CHECK-NEXT: <key>line</key><integer>60</integer> 418// CHECK-NEXT: <key>col</key><integer>3</integer> 419// CHECK-NEXT: <key>file</key><integer>0</integer> 420// CHECK-NEXT: </dict> 421// CHECK-NEXT: <dict> 422// CHECK-NEXT: <key>line</key><integer>60</integer> 423// CHECK-NEXT: <key>col</key><integer>17</integer> 424// CHECK-NEXT: <key>file</key><integer>0</integer> 425// CHECK-NEXT: </dict> 426// CHECK-NEXT: </array> 427// CHECK-NEXT: <key>end</key> 428// CHECK-NEXT: <array> 429// CHECK-NEXT: <dict> 430// CHECK-NEXT: <key>line</key><integer>61</integer> 431// CHECK-NEXT: <key>col</key><integer>3</integer> 432// CHECK-NEXT: <key>file</key><integer>0</integer> 433// CHECK-NEXT: </dict> 434// CHECK-NEXT: <dict> 435// CHECK-NEXT: <key>line</key><integer>61</integer> 436// CHECK-NEXT: <key>col</key><integer>4</integer> 437// CHECK-NEXT: <key>file</key><integer>0</integer> 438// CHECK-NEXT: </dict> 439// CHECK-NEXT: </array> 440// CHECK-NEXT: </dict> 441// CHECK-NEXT: </array> 442// CHECK-NEXT: </dict> 443// CHECK-NEXT: <dict> 444// CHECK-NEXT: <key>kind</key><string>control</string> 445// CHECK-NEXT: <key>edges</key> 446// CHECK-NEXT: <array> 447// CHECK-NEXT: <dict> 448// CHECK-NEXT: <key>start</key> 449// CHECK-NEXT: <array> 450// CHECK-NEXT: <dict> 451// CHECK-NEXT: <key>line</key><integer>61</integer> 452// CHECK-NEXT: <key>col</key><integer>3</integer> 453// CHECK-NEXT: <key>file</key><integer>0</integer> 454// CHECK-NEXT: </dict> 455// CHECK-NEXT: <dict> 456// CHECK-NEXT: <key>line</key><integer>61</integer> 457// CHECK-NEXT: <key>col</key><integer>4</integer> 458// CHECK-NEXT: <key>file</key><integer>0</integer> 459// CHECK-NEXT: </dict> 460// CHECK-NEXT: </array> 461// CHECK-NEXT: <key>end</key> 462// CHECK-NEXT: <array> 463// CHECK-NEXT: <dict> 464// CHECK-NEXT: <key>line</key><integer>61</integer> 465// CHECK-NEXT: <key>col</key><integer>8</integer> 466// CHECK-NEXT: <key>file</key><integer>0</integer> 467// CHECK-NEXT: </dict> 468// CHECK-NEXT: <dict> 469// CHECK-NEXT: <key>line</key><integer>61</integer> 470// CHECK-NEXT: <key>col</key><integer>9</integer> 471// CHECK-NEXT: <key>file</key><integer>0</integer> 472// CHECK-NEXT: </dict> 473// CHECK-NEXT: </array> 474// CHECK-NEXT: </dict> 475// CHECK-NEXT: </array> 476// CHECK-NEXT: </dict> 477// CHECK-NEXT: <dict> 478// CHECK-NEXT: <key>kind</key><string>control</string> 479// CHECK-NEXT: <key>edges</key> 480// CHECK-NEXT: <array> 481// CHECK-NEXT: <dict> 482// CHECK-NEXT: <key>start</key> 483// CHECK-NEXT: <array> 484// CHECK-NEXT: <dict> 485// CHECK-NEXT: <key>line</key><integer>61</integer> 486// CHECK-NEXT: <key>col</key><integer>8</integer> 487// CHECK-NEXT: <key>file</key><integer>0</integer> 488// CHECK-NEXT: </dict> 489// CHECK-NEXT: <dict> 490// CHECK-NEXT: <key>line</key><integer>61</integer> 491// CHECK-NEXT: <key>col</key><integer>9</integer> 492// CHECK-NEXT: <key>file</key><integer>0</integer> 493// CHECK-NEXT: </dict> 494// CHECK-NEXT: </array> 495// CHECK-NEXT: <key>end</key> 496// CHECK-NEXT: <array> 497// CHECK-NEXT: <dict> 498// CHECK-NEXT: <key>line</key><integer>61</integer> 499// CHECK-NEXT: <key>col</key><integer>52</integer> 500// CHECK-NEXT: <key>file</key><integer>0</integer> 501// CHECK-NEXT: </dict> 502// CHECK-NEXT: <dict> 503// CHECK-NEXT: <key>line</key><integer>61</integer> 504// CHECK-NEXT: <key>col</key><integer>64</integer> 505// CHECK-NEXT: <key>file</key><integer>0</integer> 506// CHECK-NEXT: </dict> 507// CHECK-NEXT: </array> 508// CHECK-NEXT: </dict> 509// CHECK-NEXT: </array> 510// CHECK-NEXT: </dict> 511// CHECK-NEXT: <dict> 512// CHECK-NEXT: <key>kind</key><string>event</string> 513// CHECK-NEXT: <key>location</key> 514// CHECK-NEXT: <dict> 515// CHECK-NEXT: <key>line</key><integer>61</integer> 516// CHECK-NEXT: <key>col</key><integer>52</integer> 517// CHECK-NEXT: <key>file</key><integer>0</integer> 518// CHECK-NEXT: </dict> 519// CHECK-NEXT: <key>ranges</key> 520// CHECK-NEXT: <array> 521// CHECK-NEXT: <array> 522// CHECK-NEXT: <dict> 523// CHECK-NEXT: <key>line</key><integer>61</integer> 524// CHECK-NEXT: <key>col</key><integer>66</integer> 525// CHECK-NEXT: <key>file</key><integer>0</integer> 526// CHECK-NEXT: </dict> 527// CHECK-NEXT: <dict> 528// CHECK-NEXT: <key>line</key><integer>61</integer> 529// CHECK-NEXT: <key>col</key><integer>72</integer> 530// CHECK-NEXT: <key>file</key><integer>0</integer> 531// CHECK-NEXT: </dict> 532// CHECK-NEXT: </array> 533// CHECK-NEXT: </array> 534// CHECK-NEXT: <key>depth</key><integer>0</integer> 535// CHECK-NEXT: <key>extended_message</key> 536// CHECK-NEXT: <string>Call to 'dispatch_once' uses the local variable 'pred' for the predicate value. Using such transient memory for the predicate is potentially dangerous. Perhaps you intended to declare the variable as 'static'?</string> 537// CHECK-NEXT: <key>message</key> 538// CHECK-NEXT: <string>Call to 'dispatch_once' uses the local variable 'pred' for the predicate value. Using such transient memory for the predicate is potentially dangerous. Perhaps you intended to declare the variable as 'static'?</string> 539// CHECK-NEXT: </dict> 540// CHECK-NEXT: </array> 541// CHECK-NEXT: <key>description</key><string>Call to 'dispatch_once' uses the local variable 'pred' for the predicate value. Using such transient memory for the predicate is potentially dangerous. Perhaps you intended to declare the variable as 'static'?</string> 542// CHECK-NEXT: <key>category</key><string>Mac OS X API</string> 543// CHECK-NEXT: <key>type</key><string>Improper use of 'dispatch_once'</string> 544// CHECK-NEXT: <key>issue_context_kind</key><string>function</string> 545// CHECK-NEXT: <key>issue_context</key><string>test_dispatch_once</string> 546// CHECK-NEXT: <key>issue_hash</key><integer>2</integer> 547// CHECK-NEXT: <key>location</key> 548// CHECK-NEXT: <dict> 549// CHECK-NEXT: <key>line</key><integer>61</integer> 550// CHECK-NEXT: <key>col</key><integer>52</integer> 551// CHECK-NEXT: <key>file</key><integer>0</integer> 552// CHECK-NEXT: </dict> 553// CHECK-NEXT: </dict> 554// CHECK-NEXT: <dict> 555// CHECK-NEXT: <key>path</key> 556// CHECK-NEXT: <array> 557// CHECK-NEXT: <dict> 558// CHECK-NEXT: <key>kind</key><string>control</string> 559// CHECK-NEXT: <key>edges</key> 560// CHECK-NEXT: <array> 561// CHECK-NEXT: <dict> 562// CHECK-NEXT: <key>start</key> 563// CHECK-NEXT: <array> 564// CHECK-NEXT: <dict> 565// CHECK-NEXT: <key>line</key><integer>71</integer> 566// CHECK-NEXT: <key>col</key><integer>3</integer> 567// CHECK-NEXT: <key>file</key><integer>0</integer> 568// CHECK-NEXT: </dict> 569// CHECK-NEXT: <dict> 570// CHECK-NEXT: <key>line</key><integer>71</integer> 571// CHECK-NEXT: <key>col</key><integer>16</integer> 572// CHECK-NEXT: <key>file</key><integer>0</integer> 573// CHECK-NEXT: </dict> 574// CHECK-NEXT: </array> 575// CHECK-NEXT: <key>end</key> 576// CHECK-NEXT: <array> 577// CHECK-NEXT: <dict> 578// CHECK-NEXT: <key>line</key><integer>72</integer> 579// CHECK-NEXT: <key>col</key><integer>3</integer> 580// CHECK-NEXT: <key>file</key><integer>0</integer> 581// CHECK-NEXT: </dict> 582// CHECK-NEXT: <dict> 583// CHECK-NEXT: <key>line</key><integer>72</integer> 584// CHECK-NEXT: <key>col</key><integer>14</integer> 585// CHECK-NEXT: <key>file</key><integer>0</integer> 586// CHECK-NEXT: </dict> 587// CHECK-NEXT: </array> 588// CHECK-NEXT: </dict> 589// CHECK-NEXT: </array> 590// CHECK-NEXT: </dict> 591// CHECK-NEXT: <dict> 592// CHECK-NEXT: <key>kind</key><string>event</string> 593// CHECK-NEXT: <key>location</key> 594// CHECK-NEXT: <dict> 595// CHECK-NEXT: <key>line</key><integer>72</integer> 596// CHECK-NEXT: <key>col</key><integer>3</integer> 597// CHECK-NEXT: <key>file</key><integer>0</integer> 598// CHECK-NEXT: </dict> 599// CHECK-NEXT: <key>ranges</key> 600// CHECK-NEXT: <array> 601// CHECK-NEXT: <array> 602// CHECK-NEXT: <dict> 603// CHECK-NEXT: <key>line</key><integer>72</integer> 604// CHECK-NEXT: <key>col</key><integer>16</integer> 605// CHECK-NEXT: <key>file</key><integer>0</integer> 606// CHECK-NEXT: </dict> 607// CHECK-NEXT: <dict> 608// CHECK-NEXT: <key>line</key><integer>72</integer> 609// CHECK-NEXT: <key>col</key><integer>20</integer> 610// CHECK-NEXT: <key>file</key><integer>0</integer> 611// CHECK-NEXT: </dict> 612// CHECK-NEXT: </array> 613// CHECK-NEXT: </array> 614// CHECK-NEXT: <key>depth</key><integer>0</integer> 615// CHECK-NEXT: <key>extended_message</key> 616// CHECK-NEXT: <string>Call to 'pthread_once' uses the local variable 'pred' for the "control" value. Using such transient memory for the control value is potentially dangerous. Perhaps you intended to declare the variable as 'static'?</string> 617// CHECK-NEXT: <key>message</key> 618// CHECK-NEXT: <string>Call to 'pthread_once' uses the local variable 'pred' for the "control" value. Using such transient memory for the control value is potentially dangerous. Perhaps you intended to declare the variable as 'static'?</string> 619// CHECK-NEXT: </dict> 620// CHECK-NEXT: </array> 621// CHECK-NEXT: <key>description</key><string>Call to 'pthread_once' uses the local variable 'pred' for the "control" value. Using such transient memory for the control value is potentially dangerous. Perhaps you intended to declare the variable as 'static'?</string> 622// CHECK-NEXT: <key>category</key><string>Unix API</string> 623// CHECK-NEXT: <key>type</key><string>Improper use of 'pthread_once'</string> 624// CHECK-NEXT: <key>issue_context_kind</key><string>function</string> 625// CHECK-NEXT: <key>issue_context</key><string>test_pthread_once</string> 626// CHECK-NEXT: <key>issue_hash</key><integer>2</integer> 627// CHECK-NEXT: <key>location</key> 628// CHECK-NEXT: <dict> 629// CHECK-NEXT: <key>line</key><integer>72</integer> 630// CHECK-NEXT: <key>col</key><integer>3</integer> 631// CHECK-NEXT: <key>file</key><integer>0</integer> 632// CHECK-NEXT: </dict> 633// CHECK-NEXT: </dict> 634// CHECK-NEXT: <dict> 635// CHECK-NEXT: <key>path</key> 636// CHECK-NEXT: <array> 637// CHECK-NEXT: <dict> 638// CHECK-NEXT: <key>kind</key><string>control</string> 639// CHECK-NEXT: <key>edges</key> 640// CHECK-NEXT: <array> 641// CHECK-NEXT: <dict> 642// CHECK-NEXT: <key>start</key> 643// CHECK-NEXT: <array> 644// CHECK-NEXT: <dict> 645// CHECK-NEXT: <key>line</key><integer>81</integer> 646// CHECK-NEXT: <key>col</key><integer>3</integer> 647// CHECK-NEXT: <key>file</key><integer>0</integer> 648// CHECK-NEXT: </dict> 649// CHECK-NEXT: <dict> 650// CHECK-NEXT: <key>line</key><integer>81</integer> 651// CHECK-NEXT: <key>col</key><integer>6</integer> 652// CHECK-NEXT: <key>file</key><integer>0</integer> 653// CHECK-NEXT: </dict> 654// CHECK-NEXT: </array> 655// CHECK-NEXT: <key>end</key> 656// CHECK-NEXT: <array> 657// CHECK-NEXT: <dict> 658// CHECK-NEXT: <key>line</key><integer>81</integer> 659// CHECK-NEXT: <key>col</key><integer>15</integer> 660// CHECK-NEXT: <key>file</key><integer>0</integer> 661// CHECK-NEXT: </dict> 662// CHECK-NEXT: <dict> 663// CHECK-NEXT: <key>line</key><integer>81</integer> 664// CHECK-NEXT: <key>col</key><integer>20</integer> 665// CHECK-NEXT: <key>file</key><integer>0</integer> 666// CHECK-NEXT: </dict> 667// CHECK-NEXT: </array> 668// CHECK-NEXT: </dict> 669// CHECK-NEXT: </array> 670// CHECK-NEXT: </dict> 671// CHECK-NEXT: <dict> 672// CHECK-NEXT: <key>kind</key><string>event</string> 673// CHECK-NEXT: <key>location</key> 674// CHECK-NEXT: <dict> 675// CHECK-NEXT: <key>line</key><integer>81</integer> 676// CHECK-NEXT: <key>col</key><integer>15</integer> 677// CHECK-NEXT: <key>file</key><integer>0</integer> 678// CHECK-NEXT: </dict> 679// CHECK-NEXT: <key>ranges</key> 680// CHECK-NEXT: <array> 681// CHECK-NEXT: <array> 682// CHECK-NEXT: <dict> 683// CHECK-NEXT: <key>line</key><integer>81</integer> 684// CHECK-NEXT: <key>col</key><integer>22</integer> 685// CHECK-NEXT: <key>file</key><integer>0</integer> 686// CHECK-NEXT: </dict> 687// CHECK-NEXT: <dict> 688// CHECK-NEXT: <key>line</key><integer>81</integer> 689// CHECK-NEXT: <key>col</key><integer>22</integer> 690// CHECK-NEXT: <key>file</key><integer>0</integer> 691// CHECK-NEXT: </dict> 692// CHECK-NEXT: </array> 693// CHECK-NEXT: </array> 694// CHECK-NEXT: <key>depth</key><integer>0</integer> 695// CHECK-NEXT: <key>extended_message</key> 696// CHECK-NEXT: <string>Call to 'malloc' has an allocation size of 0 bytes</string> 697// CHECK-NEXT: <key>message</key> 698// CHECK-NEXT: <string>Call to 'malloc' has an allocation size of 0 bytes</string> 699// CHECK-NEXT: </dict> 700// CHECK-NEXT: </array> 701// CHECK-NEXT: <key>description</key><string>Call to 'malloc' has an allocation size of 0 bytes</string> 702// CHECK-NEXT: <key>category</key><string>Unix API</string> 703// CHECK-NEXT: <key>type</key><string>Undefined allocation of 0 bytes (CERT MEM04-C; CWE-131)</string> 704// CHECK-NEXT: <key>issue_context_kind</key><string>function</string> 705// CHECK-NEXT: <key>issue_context</key><string>pr2899</string> 706// CHECK-NEXT: <key>issue_hash</key><integer>1</integer> 707// CHECK-NEXT: <key>location</key> 708// CHECK-NEXT: <dict> 709// CHECK-NEXT: <key>line</key><integer>81</integer> 710// CHECK-NEXT: <key>col</key><integer>15</integer> 711// CHECK-NEXT: <key>file</key><integer>0</integer> 712// CHECK-NEXT: </dict> 713// CHECK-NEXT: </dict> 714// CHECK-NEXT: <dict> 715// CHECK-NEXT: <key>path</key> 716// CHECK-NEXT: <array> 717// CHECK-NEXT: <dict> 718// CHECK-NEXT: <key>kind</key><string>control</string> 719// CHECK-NEXT: <key>edges</key> 720// CHECK-NEXT: <array> 721// CHECK-NEXT: <dict> 722// CHECK-NEXT: <key>start</key> 723// CHECK-NEXT: <array> 724// CHECK-NEXT: <dict> 725// CHECK-NEXT: <key>line</key><integer>93</integer> 726// CHECK-NEXT: <key>col</key><integer>3</integer> 727// CHECK-NEXT: <key>file</key><integer>0</integer> 728// CHECK-NEXT: </dict> 729// CHECK-NEXT: <dict> 730// CHECK-NEXT: <key>line</key><integer>93</integer> 731// CHECK-NEXT: <key>col</key><integer>6</integer> 732// CHECK-NEXT: <key>file</key><integer>0</integer> 733// CHECK-NEXT: </dict> 734// CHECK-NEXT: </array> 735// CHECK-NEXT: <key>end</key> 736// CHECK-NEXT: <array> 737// CHECK-NEXT: <dict> 738// CHECK-NEXT: <key>line</key><integer>93</integer> 739// CHECK-NEXT: <key>col</key><integer>15</integer> 740// CHECK-NEXT: <key>file</key><integer>0</integer> 741// CHECK-NEXT: </dict> 742// CHECK-NEXT: <dict> 743// CHECK-NEXT: <key>line</key><integer>93</integer> 744// CHECK-NEXT: <key>col</key><integer>20</integer> 745// CHECK-NEXT: <key>file</key><integer>0</integer> 746// CHECK-NEXT: </dict> 747// CHECK-NEXT: </array> 748// CHECK-NEXT: </dict> 749// CHECK-NEXT: </array> 750// CHECK-NEXT: </dict> 751// CHECK-NEXT: <dict> 752// CHECK-NEXT: <key>kind</key><string>event</string> 753// CHECK-NEXT: <key>location</key> 754// CHECK-NEXT: <dict> 755// CHECK-NEXT: <key>line</key><integer>93</integer> 756// CHECK-NEXT: <key>col</key><integer>15</integer> 757// CHECK-NEXT: <key>file</key><integer>0</integer> 758// CHECK-NEXT: </dict> 759// CHECK-NEXT: <key>ranges</key> 760// CHECK-NEXT: <array> 761// CHECK-NEXT: <array> 762// CHECK-NEXT: <dict> 763// CHECK-NEXT: <key>line</key><integer>93</integer> 764// CHECK-NEXT: <key>col</key><integer>22</integer> 765// CHECK-NEXT: <key>file</key><integer>0</integer> 766// CHECK-NEXT: </dict> 767// CHECK-NEXT: <dict> 768// CHECK-NEXT: <key>line</key><integer>93</integer> 769// CHECK-NEXT: <key>col</key><integer>22</integer> 770// CHECK-NEXT: <key>file</key><integer>0</integer> 771// CHECK-NEXT: </dict> 772// CHECK-NEXT: </array> 773// CHECK-NEXT: </array> 774// CHECK-NEXT: <key>depth</key><integer>0</integer> 775// CHECK-NEXT: <key>extended_message</key> 776// CHECK-NEXT: <string>Call to 'calloc' has an allocation size of 0 bytes</string> 777// CHECK-NEXT: <key>message</key> 778// CHECK-NEXT: <string>Call to 'calloc' has an allocation size of 0 bytes</string> 779// CHECK-NEXT: </dict> 780// CHECK-NEXT: </array> 781// CHECK-NEXT: <key>description</key><string>Call to 'calloc' has an allocation size of 0 bytes</string> 782// CHECK-NEXT: <key>category</key><string>Unix API</string> 783// CHECK-NEXT: <key>type</key><string>Undefined allocation of 0 bytes (CERT MEM04-C; CWE-131)</string> 784// CHECK-NEXT: <key>issue_context_kind</key><string>function</string> 785// CHECK-NEXT: <key>issue_context</key><string>test_calloc</string> 786// CHECK-NEXT: <key>issue_hash</key><integer>1</integer> 787// CHECK-NEXT: <key>location</key> 788// CHECK-NEXT: <dict> 789// CHECK-NEXT: <key>line</key><integer>93</integer> 790// CHECK-NEXT: <key>col</key><integer>15</integer> 791// CHECK-NEXT: <key>file</key><integer>0</integer> 792// CHECK-NEXT: </dict> 793// CHECK-NEXT: </dict> 794// CHECK-NEXT: <dict> 795// CHECK-NEXT: <key>path</key> 796// CHECK-NEXT: <array> 797// CHECK-NEXT: <dict> 798// CHECK-NEXT: <key>kind</key><string>control</string> 799// CHECK-NEXT: <key>edges</key> 800// CHECK-NEXT: <array> 801// CHECK-NEXT: <dict> 802// CHECK-NEXT: <key>start</key> 803// CHECK-NEXT: <array> 804// CHECK-NEXT: <dict> 805// CHECK-NEXT: <key>line</key><integer>99</integer> 806// CHECK-NEXT: <key>col</key><integer>3</integer> 807// CHECK-NEXT: <key>file</key><integer>0</integer> 808// CHECK-NEXT: </dict> 809// CHECK-NEXT: <dict> 810// CHECK-NEXT: <key>line</key><integer>99</integer> 811// CHECK-NEXT: <key>col</key><integer>6</integer> 812// CHECK-NEXT: <key>file</key><integer>0</integer> 813// CHECK-NEXT: </dict> 814// CHECK-NEXT: </array> 815// CHECK-NEXT: <key>end</key> 816// CHECK-NEXT: <array> 817// CHECK-NEXT: <dict> 818// CHECK-NEXT: <key>line</key><integer>99</integer> 819// CHECK-NEXT: <key>col</key><integer>15</integer> 820// CHECK-NEXT: <key>file</key><integer>0</integer> 821// CHECK-NEXT: </dict> 822// CHECK-NEXT: <dict> 823// CHECK-NEXT: <key>line</key><integer>99</integer> 824// CHECK-NEXT: <key>col</key><integer>20</integer> 825// CHECK-NEXT: <key>file</key><integer>0</integer> 826// CHECK-NEXT: </dict> 827// CHECK-NEXT: </array> 828// CHECK-NEXT: </dict> 829// CHECK-NEXT: </array> 830// CHECK-NEXT: </dict> 831// CHECK-NEXT: <dict> 832// CHECK-NEXT: <key>kind</key><string>event</string> 833// CHECK-NEXT: <key>location</key> 834// CHECK-NEXT: <dict> 835// CHECK-NEXT: <key>line</key><integer>99</integer> 836// CHECK-NEXT: <key>col</key><integer>15</integer> 837// CHECK-NEXT: <key>file</key><integer>0</integer> 838// CHECK-NEXT: </dict> 839// CHECK-NEXT: <key>ranges</key> 840// CHECK-NEXT: <array> 841// CHECK-NEXT: <array> 842// CHECK-NEXT: <dict> 843// CHECK-NEXT: <key>line</key><integer>99</integer> 844// CHECK-NEXT: <key>col</key><integer>26</integer> 845// CHECK-NEXT: <key>file</key><integer>0</integer> 846// CHECK-NEXT: </dict> 847// CHECK-NEXT: <dict> 848// CHECK-NEXT: <key>line</key><integer>99</integer> 849// CHECK-NEXT: <key>col</key><integer>26</integer> 850// CHECK-NEXT: <key>file</key><integer>0</integer> 851// CHECK-NEXT: </dict> 852// CHECK-NEXT: </array> 853// CHECK-NEXT: </array> 854// CHECK-NEXT: <key>depth</key><integer>0</integer> 855// CHECK-NEXT: <key>extended_message</key> 856// CHECK-NEXT: <string>Call to 'calloc' has an allocation size of 0 bytes</string> 857// CHECK-NEXT: <key>message</key> 858// CHECK-NEXT: <string>Call to 'calloc' has an allocation size of 0 bytes</string> 859// CHECK-NEXT: </dict> 860// CHECK-NEXT: </array> 861// CHECK-NEXT: <key>description</key><string>Call to 'calloc' has an allocation size of 0 bytes</string> 862// CHECK-NEXT: <key>category</key><string>Unix API</string> 863// CHECK-NEXT: <key>type</key><string>Undefined allocation of 0 bytes (CERT MEM04-C; CWE-131)</string> 864// CHECK-NEXT: <key>issue_context_kind</key><string>function</string> 865// CHECK-NEXT: <key>issue_context</key><string>test_calloc2</string> 866// CHECK-NEXT: <key>issue_hash</key><integer>1</integer> 867// CHECK-NEXT: <key>location</key> 868// CHECK-NEXT: <dict> 869// CHECK-NEXT: <key>line</key><integer>99</integer> 870// CHECK-NEXT: <key>col</key><integer>15</integer> 871// CHECK-NEXT: <key>file</key><integer>0</integer> 872// CHECK-NEXT: </dict> 873// CHECK-NEXT: </dict> 874// CHECK-NEXT: <dict> 875// CHECK-NEXT: <key>path</key> 876// CHECK-NEXT: <array> 877// CHECK-NEXT: <dict> 878// CHECK-NEXT: <key>kind</key><string>control</string> 879// CHECK-NEXT: <key>edges</key> 880// CHECK-NEXT: <array> 881// CHECK-NEXT: <dict> 882// CHECK-NEXT: <key>start</key> 883// CHECK-NEXT: <array> 884// CHECK-NEXT: <dict> 885// CHECK-NEXT: <key>line</key><integer>111</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: <dict> 890// CHECK-NEXT: <key>line</key><integer>111</integer> 891// CHECK-NEXT: <key>col</key><integer>6</integer> 892// CHECK-NEXT: <key>file</key><integer>0</integer> 893// CHECK-NEXT: </dict> 894// CHECK-NEXT: </array> 895// CHECK-NEXT: <key>end</key> 896// CHECK-NEXT: <array> 897// CHECK-NEXT: <dict> 898// CHECK-NEXT: <key>line</key><integer>111</integer> 899// CHECK-NEXT: <key>col</key><integer>15</integer> 900// CHECK-NEXT: <key>file</key><integer>0</integer> 901// CHECK-NEXT: </dict> 902// CHECK-NEXT: <dict> 903// CHECK-NEXT: <key>line</key><integer>111</integer> 904// CHECK-NEXT: <key>col</key><integer>21</integer> 905// CHECK-NEXT: <key>file</key><integer>0</integer> 906// CHECK-NEXT: </dict> 907// CHECK-NEXT: </array> 908// CHECK-NEXT: </dict> 909// CHECK-NEXT: </array> 910// CHECK-NEXT: </dict> 911// CHECK-NEXT: <dict> 912// CHECK-NEXT: <key>kind</key><string>event</string> 913// CHECK-NEXT: <key>location</key> 914// CHECK-NEXT: <dict> 915// CHECK-NEXT: <key>line</key><integer>111</integer> 916// CHECK-NEXT: <key>col</key><integer>15</integer> 917// CHECK-NEXT: <key>file</key><integer>0</integer> 918// CHECK-NEXT: </dict> 919// CHECK-NEXT: <key>ranges</key> 920// CHECK-NEXT: <array> 921// CHECK-NEXT: <array> 922// CHECK-NEXT: <dict> 923// CHECK-NEXT: <key>line</key><integer>111</integer> 924// CHECK-NEXT: <key>col</key><integer>28</integer> 925// CHECK-NEXT: <key>file</key><integer>0</integer> 926// CHECK-NEXT: </dict> 927// CHECK-NEXT: <dict> 928// CHECK-NEXT: <key>line</key><integer>111</integer> 929// CHECK-NEXT: <key>col</key><integer>28</integer> 930// CHECK-NEXT: <key>file</key><integer>0</integer> 931// CHECK-NEXT: </dict> 932// CHECK-NEXT: </array> 933// CHECK-NEXT: </array> 934// CHECK-NEXT: <key>depth</key><integer>0</integer> 935// CHECK-NEXT: <key>extended_message</key> 936// CHECK-NEXT: <string>Call to 'realloc' has an allocation size of 0 bytes</string> 937// CHECK-NEXT: <key>message</key> 938// CHECK-NEXT: <string>Call to 'realloc' has an allocation size of 0 bytes</string> 939// CHECK-NEXT: </dict> 940// CHECK-NEXT: </array> 941// CHECK-NEXT: <key>description</key><string>Call to 'realloc' has an allocation size of 0 bytes</string> 942// CHECK-NEXT: <key>category</key><string>Unix API</string> 943// CHECK-NEXT: <key>type</key><string>Undefined allocation of 0 bytes (CERT MEM04-C; CWE-131)</string> 944// CHECK-NEXT: <key>issue_context_kind</key><string>function</string> 945// CHECK-NEXT: <key>issue_context</key><string>test_realloc</string> 946// CHECK-NEXT: <key>issue_hash</key><integer>1</integer> 947// CHECK-NEXT: <key>location</key> 948// CHECK-NEXT: <dict> 949// CHECK-NEXT: <key>line</key><integer>111</integer> 950// CHECK-NEXT: <key>col</key><integer>15</integer> 951// CHECK-NEXT: <key>file</key><integer>0</integer> 952// CHECK-NEXT: </dict> 953// CHECK-NEXT: </dict> 954// CHECK-NEXT: <dict> 955// CHECK-NEXT: <key>path</key> 956// CHECK-NEXT: <array> 957// CHECK-NEXT: <dict> 958// CHECK-NEXT: <key>kind</key><string>control</string> 959// CHECK-NEXT: <key>edges</key> 960// CHECK-NEXT: <array> 961// CHECK-NEXT: <dict> 962// CHECK-NEXT: <key>start</key> 963// CHECK-NEXT: <array> 964// CHECK-NEXT: <dict> 965// CHECK-NEXT: <key>line</key><integer>123</integer> 966// CHECK-NEXT: <key>col</key><integer>3</integer> 967// CHECK-NEXT: <key>file</key><integer>0</integer> 968// CHECK-NEXT: </dict> 969// CHECK-NEXT: <dict> 970// CHECK-NEXT: <key>line</key><integer>123</integer> 971// CHECK-NEXT: <key>col</key><integer>6</integer> 972// CHECK-NEXT: <key>file</key><integer>0</integer> 973// CHECK-NEXT: </dict> 974// CHECK-NEXT: </array> 975// CHECK-NEXT: <key>end</key> 976// CHECK-NEXT: <array> 977// CHECK-NEXT: <dict> 978// CHECK-NEXT: <key>line</key><integer>123</integer> 979// CHECK-NEXT: <key>col</key><integer>15</integer> 980// CHECK-NEXT: <key>file</key><integer>0</integer> 981// CHECK-NEXT: </dict> 982// CHECK-NEXT: <dict> 983// CHECK-NEXT: <key>line</key><integer>123</integer> 984// CHECK-NEXT: <key>col</key><integer>20</integer> 985// CHECK-NEXT: <key>file</key><integer>0</integer> 986// CHECK-NEXT: </dict> 987// CHECK-NEXT: </array> 988// CHECK-NEXT: </dict> 989// CHECK-NEXT: </array> 990// CHECK-NEXT: </dict> 991// CHECK-NEXT: <dict> 992// CHECK-NEXT: <key>kind</key><string>event</string> 993// CHECK-NEXT: <key>location</key> 994// CHECK-NEXT: <dict> 995// CHECK-NEXT: <key>line</key><integer>123</integer> 996// CHECK-NEXT: <key>col</key><integer>15</integer> 997// CHECK-NEXT: <key>file</key><integer>0</integer> 998// CHECK-NEXT: </dict> 999// CHECK-NEXT: <key>ranges</key> 1000// CHECK-NEXT: <array> 1001// CHECK-NEXT: <array> 1002// CHECK-NEXT: <dict> 1003// CHECK-NEXT: <key>line</key><integer>123</integer> 1004// CHECK-NEXT: <key>col</key><integer>22</integer> 1005// CHECK-NEXT: <key>file</key><integer>0</integer> 1006// CHECK-NEXT: </dict> 1007// CHECK-NEXT: <dict> 1008// CHECK-NEXT: <key>line</key><integer>123</integer> 1009// CHECK-NEXT: <key>col</key><integer>22</integer> 1010// CHECK-NEXT: <key>file</key><integer>0</integer> 1011// CHECK-NEXT: </dict> 1012// CHECK-NEXT: </array> 1013// CHECK-NEXT: </array> 1014// CHECK-NEXT: <key>depth</key><integer>0</integer> 1015// CHECK-NEXT: <key>extended_message</key> 1016// CHECK-NEXT: <string>Call to 'alloca' has an allocation size of 0 bytes</string> 1017// CHECK-NEXT: <key>message</key> 1018// CHECK-NEXT: <string>Call to 'alloca' has an allocation size of 0 bytes</string> 1019// CHECK-NEXT: </dict> 1020// CHECK-NEXT: </array> 1021// CHECK-NEXT: <key>description</key><string>Call to 'alloca' has an allocation size of 0 bytes</string> 1022// CHECK-NEXT: <key>category</key><string>Unix API</string> 1023// CHECK-NEXT: <key>type</key><string>Undefined allocation of 0 bytes (CERT MEM04-C; CWE-131)</string> 1024// CHECK-NEXT: <key>issue_context_kind</key><string>function</string> 1025// CHECK-NEXT: <key>issue_context</key><string>test_alloca</string> 1026// CHECK-NEXT: <key>issue_hash</key><integer>1</integer> 1027// CHECK-NEXT: <key>location</key> 1028// CHECK-NEXT: <dict> 1029// CHECK-NEXT: <key>line</key><integer>123</integer> 1030// CHECK-NEXT: <key>col</key><integer>15</integer> 1031// CHECK-NEXT: <key>file</key><integer>0</integer> 1032// CHECK-NEXT: </dict> 1033// CHECK-NEXT: </dict> 1034// CHECK-NEXT: <dict> 1035// CHECK-NEXT: <key>path</key> 1036// CHECK-NEXT: <array> 1037// CHECK-NEXT: <dict> 1038// CHECK-NEXT: <key>kind</key><string>control</string> 1039// CHECK-NEXT: <key>edges</key> 1040// CHECK-NEXT: <array> 1041// CHECK-NEXT: <dict> 1042// CHECK-NEXT: <key>start</key> 1043// CHECK-NEXT: <array> 1044// CHECK-NEXT: <dict> 1045// CHECK-NEXT: <key>line</key><integer>135</integer> 1046// CHECK-NEXT: <key>col</key><integer>3</integer> 1047// CHECK-NEXT: <key>file</key><integer>0</integer> 1048// CHECK-NEXT: </dict> 1049// CHECK-NEXT: <dict> 1050// CHECK-NEXT: <key>line</key><integer>135</integer> 1051// CHECK-NEXT: <key>col</key><integer>6</integer> 1052// CHECK-NEXT: <key>file</key><integer>0</integer> 1053// CHECK-NEXT: </dict> 1054// CHECK-NEXT: </array> 1055// CHECK-NEXT: <key>end</key> 1056// CHECK-NEXT: <array> 1057// CHECK-NEXT: <dict> 1058// CHECK-NEXT: <key>line</key><integer>135</integer> 1059// CHECK-NEXT: <key>col</key><integer>16</integer> 1060// CHECK-NEXT: <key>file</key><integer>0</integer> 1061// CHECK-NEXT: </dict> 1062// CHECK-NEXT: <dict> 1063// CHECK-NEXT: <key>line</key><integer>135</integer> 1064// CHECK-NEXT: <key>col</key><integer>31</integer> 1065// CHECK-NEXT: <key>file</key><integer>0</integer> 1066// CHECK-NEXT: </dict> 1067// CHECK-NEXT: </array> 1068// CHECK-NEXT: </dict> 1069// CHECK-NEXT: </array> 1070// CHECK-NEXT: </dict> 1071// CHECK-NEXT: <dict> 1072// CHECK-NEXT: <key>kind</key><string>event</string> 1073// CHECK-NEXT: <key>location</key> 1074// CHECK-NEXT: <dict> 1075// CHECK-NEXT: <key>line</key><integer>135</integer> 1076// CHECK-NEXT: <key>col</key><integer>16</integer> 1077// CHECK-NEXT: <key>file</key><integer>0</integer> 1078// CHECK-NEXT: </dict> 1079// CHECK-NEXT: <key>ranges</key> 1080// CHECK-NEXT: <array> 1081// CHECK-NEXT: <array> 1082// CHECK-NEXT: <dict> 1083// CHECK-NEXT: <key>line</key><integer>135</integer> 1084// CHECK-NEXT: <key>col</key><integer>33</integer> 1085// CHECK-NEXT: <key>file</key><integer>0</integer> 1086// CHECK-NEXT: </dict> 1087// CHECK-NEXT: <dict> 1088// CHECK-NEXT: <key>line</key><integer>135</integer> 1089// CHECK-NEXT: <key>col</key><integer>33</integer> 1090// CHECK-NEXT: <key>file</key><integer>0</integer> 1091// CHECK-NEXT: </dict> 1092// CHECK-NEXT: </array> 1093// CHECK-NEXT: </array> 1094// CHECK-NEXT: <key>depth</key><integer>0</integer> 1095// CHECK-NEXT: <key>extended_message</key> 1096// CHECK-NEXT: <string>Call to 'alloca' has an allocation size of 0 bytes</string> 1097// CHECK-NEXT: <key>message</key> 1098// CHECK-NEXT: <string>Call to 'alloca' has an allocation size of 0 bytes</string> 1099// CHECK-NEXT: </dict> 1100// CHECK-NEXT: </array> 1101// CHECK-NEXT: <key>description</key><string>Call to 'alloca' has an allocation size of 0 bytes</string> 1102// CHECK-NEXT: <key>category</key><string>Unix API</string> 1103// CHECK-NEXT: <key>type</key><string>Undefined allocation of 0 bytes (CERT MEM04-C; CWE-131)</string> 1104// CHECK-NEXT: <key>issue_context_kind</key><string>function</string> 1105// CHECK-NEXT: <key>issue_context</key><string>test_builtin_alloca</string> 1106// CHECK-NEXT: <key>issue_hash</key><integer>1</integer> 1107// CHECK-NEXT: <key>location</key> 1108// CHECK-NEXT: <dict> 1109// CHECK-NEXT: <key>line</key><integer>135</integer> 1110// CHECK-NEXT: <key>col</key><integer>16</integer> 1111// CHECK-NEXT: <key>file</key><integer>0</integer> 1112// CHECK-NEXT: </dict> 1113// CHECK-NEXT: </dict> 1114// CHECK-NEXT: <dict> 1115// CHECK-NEXT: <key>path</key> 1116// CHECK-NEXT: <array> 1117// CHECK-NEXT: <dict> 1118// CHECK-NEXT: <key>kind</key><string>control</string> 1119// CHECK-NEXT: <key>edges</key> 1120// CHECK-NEXT: <array> 1121// CHECK-NEXT: <dict> 1122// CHECK-NEXT: <key>start</key> 1123// CHECK-NEXT: <array> 1124// CHECK-NEXT: <dict> 1125// CHECK-NEXT: <key>line</key><integer>147</integer> 1126// CHECK-NEXT: <key>col</key><integer>3</integer> 1127// CHECK-NEXT: <key>file</key><integer>0</integer> 1128// CHECK-NEXT: </dict> 1129// CHECK-NEXT: <dict> 1130// CHECK-NEXT: <key>line</key><integer>147</integer> 1131// CHECK-NEXT: <key>col</key><integer>6</integer> 1132// CHECK-NEXT: <key>file</key><integer>0</integer> 1133// CHECK-NEXT: </dict> 1134// CHECK-NEXT: </array> 1135// CHECK-NEXT: <key>end</key> 1136// CHECK-NEXT: <array> 1137// CHECK-NEXT: <dict> 1138// CHECK-NEXT: <key>line</key><integer>147</integer> 1139// CHECK-NEXT: <key>col</key><integer>15</integer> 1140// CHECK-NEXT: <key>file</key><integer>0</integer> 1141// CHECK-NEXT: </dict> 1142// CHECK-NEXT: <dict> 1143// CHECK-NEXT: <key>line</key><integer>147</integer> 1144// CHECK-NEXT: <key>col</key><integer>20</integer> 1145// CHECK-NEXT: <key>file</key><integer>0</integer> 1146// CHECK-NEXT: </dict> 1147// CHECK-NEXT: </array> 1148// CHECK-NEXT: </dict> 1149// CHECK-NEXT: </array> 1150// CHECK-NEXT: </dict> 1151// CHECK-NEXT: <dict> 1152// CHECK-NEXT: <key>kind</key><string>event</string> 1153// CHECK-NEXT: <key>location</key> 1154// CHECK-NEXT: <dict> 1155// CHECK-NEXT: <key>line</key><integer>147</integer> 1156// CHECK-NEXT: <key>col</key><integer>15</integer> 1157// CHECK-NEXT: <key>file</key><integer>0</integer> 1158// CHECK-NEXT: </dict> 1159// CHECK-NEXT: <key>ranges</key> 1160// CHECK-NEXT: <array> 1161// CHECK-NEXT: <array> 1162// CHECK-NEXT: <dict> 1163// CHECK-NEXT: <key>line</key><integer>147</integer> 1164// CHECK-NEXT: <key>col</key><integer>22</integer> 1165// CHECK-NEXT: <key>file</key><integer>0</integer> 1166// CHECK-NEXT: </dict> 1167// CHECK-NEXT: <dict> 1168// CHECK-NEXT: <key>line</key><integer>147</integer> 1169// CHECK-NEXT: <key>col</key><integer>22</integer> 1170// CHECK-NEXT: <key>file</key><integer>0</integer> 1171// CHECK-NEXT: </dict> 1172// CHECK-NEXT: </array> 1173// CHECK-NEXT: </array> 1174// CHECK-NEXT: <key>depth</key><integer>0</integer> 1175// CHECK-NEXT: <key>extended_message</key> 1176// CHECK-NEXT: <string>Call to 'valloc' has an allocation size of 0 bytes</string> 1177// CHECK-NEXT: <key>message</key> 1178// CHECK-NEXT: <string>Call to 'valloc' has an allocation size of 0 bytes</string> 1179// CHECK-NEXT: </dict> 1180// CHECK-NEXT: </array> 1181// CHECK-NEXT: <key>description</key><string>Call to 'valloc' has an allocation size of 0 bytes</string> 1182// CHECK-NEXT: <key>category</key><string>Unix API</string> 1183// CHECK-NEXT: <key>type</key><string>Undefined allocation of 0 bytes (CERT MEM04-C; CWE-131)</string> 1184// CHECK-NEXT: <key>issue_context_kind</key><string>function</string> 1185// CHECK-NEXT: <key>issue_context</key><string>test_valloc</string> 1186// CHECK-NEXT: <key>issue_hash</key><integer>1</integer> 1187// CHECK-NEXT: <key>location</key> 1188// CHECK-NEXT: <dict> 1189// CHECK-NEXT: <key>line</key><integer>147</integer> 1190// CHECK-NEXT: <key>col</key><integer>15</integer> 1191// CHECK-NEXT: <key>file</key><integer>0</integer> 1192// CHECK-NEXT: </dict> 1193// CHECK-NEXT: </dict> 1194// CHECK-NEXT: <dict> 1195// CHECK-NEXT: <key>path</key> 1196// CHECK-NEXT: <array> 1197// CHECK-NEXT: <dict> 1198// CHECK-NEXT: <key>kind</key><string>control</string> 1199// CHECK-NEXT: <key>edges</key> 1200// CHECK-NEXT: <array> 1201// CHECK-NEXT: <dict> 1202// CHECK-NEXT: <key>start</key> 1203// CHECK-NEXT: <array> 1204// CHECK-NEXT: <dict> 1205// CHECK-NEXT: <key>line</key><integer>170</integer> 1206// CHECK-NEXT: <key>col</key><integer>3</integer> 1207// CHECK-NEXT: <key>file</key><integer>0</integer> 1208// CHECK-NEXT: </dict> 1209// CHECK-NEXT: <dict> 1210// CHECK-NEXT: <key>line</key><integer>170</integer> 1211// CHECK-NEXT: <key>col</key><integer>17</integer> 1212// CHECK-NEXT: <key>file</key><integer>0</integer> 1213// CHECK-NEXT: </dict> 1214// CHECK-NEXT: </array> 1215// CHECK-NEXT: <key>end</key> 1216// CHECK-NEXT: <array> 1217// CHECK-NEXT: <dict> 1218// CHECK-NEXT: <key>line</key><integer>171</integer> 1219// CHECK-NEXT: <key>col</key><integer>3</integer> 1220// CHECK-NEXT: <key>file</key><integer>0</integer> 1221// CHECK-NEXT: </dict> 1222// CHECK-NEXT: <dict> 1223// CHECK-NEXT: <key>line</key><integer>171</integer> 1224// CHECK-NEXT: <key>col</key><integer>15</integer> 1225// CHECK-NEXT: <key>file</key><integer>0</integer> 1226// CHECK-NEXT: </dict> 1227// CHECK-NEXT: </array> 1228// CHECK-NEXT: </dict> 1229// CHECK-NEXT: </array> 1230// CHECK-NEXT: </dict> 1231// CHECK-NEXT: <dict> 1232// CHECK-NEXT: <key>kind</key><string>event</string> 1233// CHECK-NEXT: <key>location</key> 1234// CHECK-NEXT: <dict> 1235// CHECK-NEXT: <key>line</key><integer>171</integer> 1236// CHECK-NEXT: <key>col</key><integer>3</integer> 1237// CHECK-NEXT: <key>file</key><integer>0</integer> 1238// CHECK-NEXT: </dict> 1239// CHECK-NEXT: <key>ranges</key> 1240// CHECK-NEXT: <array> 1241// CHECK-NEXT: <array> 1242// CHECK-NEXT: <dict> 1243// CHECK-NEXT: <key>line</key><integer>171</integer> 1244// CHECK-NEXT: <key>col</key><integer>17</integer> 1245// CHECK-NEXT: <key>file</key><integer>0</integer> 1246// CHECK-NEXT: </dict> 1247// CHECK-NEXT: <dict> 1248// CHECK-NEXT: <key>line</key><integer>171</integer> 1249// CHECK-NEXT: <key>col</key><integer>21</integer> 1250// CHECK-NEXT: <key>file</key><integer>0</integer> 1251// CHECK-NEXT: </dict> 1252// CHECK-NEXT: </array> 1253// CHECK-NEXT: </array> 1254// CHECK-NEXT: <key>depth</key><integer>0</integer> 1255// CHECK-NEXT: <key>extended_message</key> 1256// CHECK-NEXT: <string>Call to 'dispatch_once' uses the local variable 'pred' for the predicate value. Using such transient memory for the predicate is potentially dangerous. Perhaps you intended to declare the variable as 'static'?</string> 1257// CHECK-NEXT: <key>message</key> 1258// CHECK-NEXT: <string>Call to 'dispatch_once' uses the local variable 'pred' for the predicate value. Using such transient memory for the predicate is potentially dangerous. Perhaps you intended to declare the variable as 'static'?</string> 1259// CHECK-NEXT: </dict> 1260// CHECK-NEXT: </array> 1261// CHECK-NEXT: <key>description</key><string>Call to 'dispatch_once' uses the local variable 'pred' for the predicate value. Using such transient memory for the predicate is potentially dangerous. Perhaps you intended to declare the variable as 'static'?</string> 1262// CHECK-NEXT: <key>category</key><string>Mac OS X API</string> 1263// CHECK-NEXT: <key>type</key><string>Improper use of 'dispatch_once'</string> 1264// CHECK-NEXT: <key>issue_context_kind</key><string>function</string> 1265// CHECK-NEXT: <key>issue_context</key><string>test_dispatch_once_in_macro</string> 1266// CHECK-NEXT: <key>issue_hash</key><integer>2</integer> 1267// CHECK-NEXT: <key>location</key> 1268// CHECK-NEXT: <dict> 1269// CHECK-NEXT: <key>line</key><integer>171</integer> 1270// CHECK-NEXT: <key>col</key><integer>3</integer> 1271// CHECK-NEXT: <key>file</key><integer>0</integer> 1272// CHECK-NEXT: </dict> 1273// CHECK-NEXT: </dict> 1274// CHECK-NEXT: <dict> 1275// CHECK-NEXT: <key>path</key> 1276// CHECK-NEXT: <array> 1277// CHECK-NEXT: <dict> 1278// CHECK-NEXT: <key>kind</key><string>event</string> 1279// CHECK-NEXT: <key>location</key> 1280// CHECK-NEXT: <dict> 1281// CHECK-NEXT: <key>line</key><integer>176</integer> 1282// CHECK-NEXT: <key>col</key><integer>3</integer> 1283// CHECK-NEXT: <key>file</key><integer>0</integer> 1284// CHECK-NEXT: </dict> 1285// CHECK-NEXT: <key>ranges</key> 1286// CHECK-NEXT: <array> 1287// CHECK-NEXT: <array> 1288// CHECK-NEXT: <dict> 1289// CHECK-NEXT: <key>line</key><integer>176</integer> 1290// CHECK-NEXT: <key>col</key><integer>3</integer> 1291// CHECK-NEXT: <key>file</key><integer>0</integer> 1292// CHECK-NEXT: </dict> 1293// CHECK-NEXT: <dict> 1294// CHECK-NEXT: <key>line</key><integer>176</integer> 1295// CHECK-NEXT: <key>col</key><integer>8</integer> 1296// CHECK-NEXT: <key>file</key><integer>0</integer> 1297// CHECK-NEXT: </dict> 1298// CHECK-NEXT: </array> 1299// CHECK-NEXT: </array> 1300// CHECK-NEXT: <key>depth</key><integer>0</integer> 1301// CHECK-NEXT: <key>extended_message</key> 1302// CHECK-NEXT: <string>Variable 'p' initialized to a null pointer value</string> 1303// CHECK-NEXT: <key>message</key> 1304// CHECK-NEXT: <string>Variable 'p' initialized to a null pointer value</string> 1305// CHECK-NEXT: </dict> 1306// CHECK-NEXT: <dict> 1307// CHECK-NEXT: <key>kind</key><string>control</string> 1308// CHECK-NEXT: <key>edges</key> 1309// CHECK-NEXT: <array> 1310// CHECK-NEXT: <dict> 1311// CHECK-NEXT: <key>start</key> 1312// CHECK-NEXT: <array> 1313// CHECK-NEXT: <dict> 1314// CHECK-NEXT: <key>line</key><integer>176</integer> 1315// CHECK-NEXT: <key>col</key><integer>3</integer> 1316// CHECK-NEXT: <key>file</key><integer>0</integer> 1317// CHECK-NEXT: </dict> 1318// CHECK-NEXT: <dict> 1319// CHECK-NEXT: <key>line</key><integer>176</integer> 1320// CHECK-NEXT: <key>col</key><integer>5</integer> 1321// CHECK-NEXT: <key>file</key><integer>0</integer> 1322// CHECK-NEXT: </dict> 1323// CHECK-NEXT: </array> 1324// CHECK-NEXT: <key>end</key> 1325// CHECK-NEXT: <array> 1326// CHECK-NEXT: <dict> 1327// CHECK-NEXT: <key>line</key><integer>177</integer> 1328// CHECK-NEXT: <key>col</key><integer>3</integer> 1329// CHECK-NEXT: <key>file</key><integer>0</integer> 1330// CHECK-NEXT: </dict> 1331// CHECK-NEXT: <dict> 1332// CHECK-NEXT: <key>line</key><integer>177</integer> 1333// CHECK-NEXT: <key>col</key><integer>15</integer> 1334// CHECK-NEXT: <key>file</key><integer>0</integer> 1335// CHECK-NEXT: </dict> 1336// CHECK-NEXT: </array> 1337// CHECK-NEXT: </dict> 1338// CHECK-NEXT: </array> 1339// CHECK-NEXT: </dict> 1340// CHECK-NEXT: <dict> 1341// CHECK-NEXT: <key>kind</key><string>event</string> 1342// CHECK-NEXT: <key>location</key> 1343// CHECK-NEXT: <dict> 1344// CHECK-NEXT: <key>line</key><integer>177</integer> 1345// CHECK-NEXT: <key>col</key><integer>3</integer> 1346// CHECK-NEXT: <key>file</key><integer>0</integer> 1347// CHECK-NEXT: </dict> 1348// CHECK-NEXT: <key>ranges</key> 1349// CHECK-NEXT: <array> 1350// CHECK-NEXT: <array> 1351// CHECK-NEXT: <dict> 1352// CHECK-NEXT: <key>line</key><integer>177</integer> 1353// CHECK-NEXT: <key>col</key><integer>3</integer> 1354// CHECK-NEXT: <key>file</key><integer>0</integer> 1355// CHECK-NEXT: </dict> 1356// CHECK-NEXT: <dict> 1357// CHECK-NEXT: <key>line</key><integer>181</integer> 1358// CHECK-NEXT: <key>col</key><integer>4</integer> 1359// CHECK-NEXT: <key>file</key><integer>0</integer> 1360// CHECK-NEXT: </dict> 1361// CHECK-NEXT: </array> 1362// CHECK-NEXT: </array> 1363// CHECK-NEXT: <key>depth</key><integer>0</integer> 1364// CHECK-NEXT: <key>extended_message</key> 1365// CHECK-NEXT: <string>Calling 'dispatch_sync'</string> 1366// CHECK-NEXT: <key>message</key> 1367// CHECK-NEXT: <string>Calling 'dispatch_sync'</string> 1368// CHECK-NEXT: </dict> 1369// CHECK-NEXT: <dict> 1370// CHECK-NEXT: <key>kind</key><string>event</string> 1371// CHECK-NEXT: <key>location</key> 1372// CHECK-NEXT: <dict> 1373// CHECK-NEXT: <key>line</key><integer>39</integer> 1374// CHECK-NEXT: <key>col</key><integer>1</integer> 1375// CHECK-NEXT: <key>file</key><integer>0</integer> 1376// CHECK-NEXT: </dict> 1377// CHECK-NEXT: <key>depth</key><integer>1</integer> 1378// CHECK-NEXT: <key>extended_message</key> 1379// CHECK-NEXT: <string>Entered call from 'test_dispatch_sync'</string> 1380// CHECK-NEXT: <key>message</key> 1381// CHECK-NEXT: <string>Entered call from 'test_dispatch_sync'</string> 1382// CHECK-NEXT: </dict> 1383// CHECK-NEXT: <dict> 1384// CHECK-NEXT: <key>kind</key><string>event</string> 1385// CHECK-NEXT: <key>location</key> 1386// CHECK-NEXT: <dict> 1387// CHECK-NEXT: <key>line</key><integer>177</integer> 1388// CHECK-NEXT: <key>col</key><integer>3</integer> 1389// CHECK-NEXT: <key>file</key><integer>0</integer> 1390// CHECK-NEXT: </dict> 1391// CHECK-NEXT: <key>ranges</key> 1392// CHECK-NEXT: <array> 1393// CHECK-NEXT: <array> 1394// CHECK-NEXT: <dict> 1395// CHECK-NEXT: <key>line</key><integer>177</integer> 1396// CHECK-NEXT: <key>col</key><integer>3</integer> 1397// CHECK-NEXT: <key>file</key><integer>0</integer> 1398// CHECK-NEXT: </dict> 1399// CHECK-NEXT: <dict> 1400// CHECK-NEXT: <key>line</key><integer>181</integer> 1401// CHECK-NEXT: <key>col</key><integer>4</integer> 1402// CHECK-NEXT: <key>file</key><integer>0</integer> 1403// CHECK-NEXT: </dict> 1404// CHECK-NEXT: </array> 1405// CHECK-NEXT: </array> 1406// CHECK-NEXT: <key>depth</key><integer>1</integer> 1407// CHECK-NEXT: <key>extended_message</key> 1408// CHECK-NEXT: <string>Calling anonymous block</string> 1409// CHECK-NEXT: <key>message</key> 1410// CHECK-NEXT: <string>Calling anonymous block</string> 1411// CHECK-NEXT: </dict> 1412// CHECK-NEXT: <dict> 1413// CHECK-NEXT: <key>kind</key><string>event</string> 1414// CHECK-NEXT: <key>location</key> 1415// CHECK-NEXT: <dict> 1416// CHECK-NEXT: <key>line</key><integer>177</integer> 1417// CHECK-NEXT: <key>col</key><integer>24</integer> 1418// CHECK-NEXT: <key>file</key><integer>0</integer> 1419// CHECK-NEXT: </dict> 1420// CHECK-NEXT: <key>depth</key><integer>2</integer> 1421// CHECK-NEXT: <key>extended_message</key> 1422// CHECK-NEXT: <string>Entered call from 'dispatch_sync'</string> 1423// CHECK-NEXT: <key>message</key> 1424// CHECK-NEXT: <string>Entered call from 'dispatch_sync'</string> 1425// CHECK-NEXT: </dict> 1426// CHECK-NEXT: <dict> 1427// CHECK-NEXT: <key>kind</key><string>control</string> 1428// CHECK-NEXT: <key>edges</key> 1429// CHECK-NEXT: <array> 1430// CHECK-NEXT: <dict> 1431// CHECK-NEXT: <key>start</key> 1432// CHECK-NEXT: <array> 1433// CHECK-NEXT: <dict> 1434// CHECK-NEXT: <key>line</key><integer>177</integer> 1435// CHECK-NEXT: <key>col</key><integer>24</integer> 1436// CHECK-NEXT: <key>file</key><integer>0</integer> 1437// CHECK-NEXT: </dict> 1438// CHECK-NEXT: <dict> 1439// CHECK-NEXT: <key>line</key><integer>177</integer> 1440// CHECK-NEXT: <key>col</key><integer>24</integer> 1441// CHECK-NEXT: <key>file</key><integer>0</integer> 1442// CHECK-NEXT: </dict> 1443// CHECK-NEXT: </array> 1444// CHECK-NEXT: <key>end</key> 1445// CHECK-NEXT: <array> 1446// CHECK-NEXT: <dict> 1447// CHECK-NEXT: <key>line</key><integer>178</integer> 1448// CHECK-NEXT: <key>col</key><integer>4</integer> 1449// CHECK-NEXT: <key>file</key><integer>0</integer> 1450// CHECK-NEXT: </dict> 1451// CHECK-NEXT: <dict> 1452// CHECK-NEXT: <key>line</key><integer>178</integer> 1453// CHECK-NEXT: <key>col</key><integer>5</integer> 1454// CHECK-NEXT: <key>file</key><integer>0</integer> 1455// CHECK-NEXT: </dict> 1456// CHECK-NEXT: </array> 1457// CHECK-NEXT: </dict> 1458// CHECK-NEXT: </array> 1459// CHECK-NEXT: </dict> 1460// CHECK-NEXT: <dict> 1461// CHECK-NEXT: <key>kind</key><string>control</string> 1462// CHECK-NEXT: <key>edges</key> 1463// CHECK-NEXT: <array> 1464// CHECK-NEXT: <dict> 1465// CHECK-NEXT: <key>start</key> 1466// CHECK-NEXT: <array> 1467// CHECK-NEXT: <dict> 1468// CHECK-NEXT: <key>line</key><integer>178</integer> 1469// CHECK-NEXT: <key>col</key><integer>4</integer> 1470// CHECK-NEXT: <key>file</key><integer>0</integer> 1471// CHECK-NEXT: </dict> 1472// CHECK-NEXT: <dict> 1473// CHECK-NEXT: <key>line</key><integer>178</integer> 1474// CHECK-NEXT: <key>col</key><integer>5</integer> 1475// CHECK-NEXT: <key>file</key><integer>0</integer> 1476// CHECK-NEXT: </dict> 1477// CHECK-NEXT: </array> 1478// CHECK-NEXT: <key>end</key> 1479// CHECK-NEXT: <array> 1480// CHECK-NEXT: <dict> 1481// CHECK-NEXT: <key>line</key><integer>178</integer> 1482// CHECK-NEXT: <key>col</key><integer>8</integer> 1483// CHECK-NEXT: <key>file</key><integer>0</integer> 1484// CHECK-NEXT: </dict> 1485// CHECK-NEXT: <dict> 1486// CHECK-NEXT: <key>line</key><integer>178</integer> 1487// CHECK-NEXT: <key>col</key><integer>8</integer> 1488// CHECK-NEXT: <key>file</key><integer>0</integer> 1489// CHECK-NEXT: </dict> 1490// CHECK-NEXT: </array> 1491// CHECK-NEXT: </dict> 1492// CHECK-NEXT: </array> 1493// CHECK-NEXT: </dict> 1494// CHECK-NEXT: <dict> 1495// CHECK-NEXT: <key>kind</key><string>event</string> 1496// CHECK-NEXT: <key>location</key> 1497// CHECK-NEXT: <dict> 1498// CHECK-NEXT: <key>line</key><integer>178</integer> 1499// CHECK-NEXT: <key>col</key><integer>8</integer> 1500// CHECK-NEXT: <key>file</key><integer>0</integer> 1501// CHECK-NEXT: </dict> 1502// CHECK-NEXT: <key>ranges</key> 1503// CHECK-NEXT: <array> 1504// CHECK-NEXT: <array> 1505// CHECK-NEXT: <dict> 1506// CHECK-NEXT: <key>line</key><integer>178</integer> 1507// CHECK-NEXT: <key>col</key><integer>8</integer> 1508// CHECK-NEXT: <key>file</key><integer>0</integer> 1509// CHECK-NEXT: </dict> 1510// CHECK-NEXT: <dict> 1511// CHECK-NEXT: <key>line</key><integer>178</integer> 1512// CHECK-NEXT: <key>col</key><integer>8</integer> 1513// CHECK-NEXT: <key>file</key><integer>0</integer> 1514// CHECK-NEXT: </dict> 1515// CHECK-NEXT: </array> 1516// CHECK-NEXT: </array> 1517// CHECK-NEXT: <key>depth</key><integer>2</integer> 1518// CHECK-NEXT: <key>extended_message</key> 1519// CHECK-NEXT: <string>Assuming 'q' is non-null</string> 1520// CHECK-NEXT: <key>message</key> 1521// CHECK-NEXT: <string>Assuming 'q' is non-null</string> 1522// CHECK-NEXT: </dict> 1523// CHECK-NEXT: <dict> 1524// CHECK-NEXT: <key>kind</key><string>control</string> 1525// CHECK-NEXT: <key>edges</key> 1526// CHECK-NEXT: <array> 1527// CHECK-NEXT: <dict> 1528// CHECK-NEXT: <key>start</key> 1529// CHECK-NEXT: <array> 1530// CHECK-NEXT: <dict> 1531// CHECK-NEXT: <key>line</key><integer>178</integer> 1532// CHECK-NEXT: <key>col</key><integer>8</integer> 1533// CHECK-NEXT: <key>file</key><integer>0</integer> 1534// CHECK-NEXT: </dict> 1535// CHECK-NEXT: <dict> 1536// CHECK-NEXT: <key>line</key><integer>178</integer> 1537// CHECK-NEXT: <key>col</key><integer>8</integer> 1538// CHECK-NEXT: <key>file</key><integer>0</integer> 1539// CHECK-NEXT: </dict> 1540// CHECK-NEXT: </array> 1541// CHECK-NEXT: <key>end</key> 1542// CHECK-NEXT: <array> 1543// CHECK-NEXT: <dict> 1544// CHECK-NEXT: <key>line</key><integer>179</integer> 1545// CHECK-NEXT: <key>col</key><integer>3</integer> 1546// CHECK-NEXT: <key>file</key><integer>0</integer> 1547// CHECK-NEXT: </dict> 1548// CHECK-NEXT: <dict> 1549// CHECK-NEXT: <key>line</key><integer>179</integer> 1550// CHECK-NEXT: <key>col</key><integer>3</integer> 1551// CHECK-NEXT: <key>file</key><integer>0</integer> 1552// CHECK-NEXT: </dict> 1553// CHECK-NEXT: </array> 1554// CHECK-NEXT: </dict> 1555// CHECK-NEXT: </array> 1556// CHECK-NEXT: </dict> 1557// CHECK-NEXT: <dict> 1558// CHECK-NEXT: <key>kind</key><string>event</string> 1559// CHECK-NEXT: <key>location</key> 1560// CHECK-NEXT: <dict> 1561// CHECK-NEXT: <key>line</key><integer>179</integer> 1562// CHECK-NEXT: <key>col</key><integer>3</integer> 1563// CHECK-NEXT: <key>file</key><integer>0</integer> 1564// CHECK-NEXT: </dict> 1565// CHECK-NEXT: <key>ranges</key> 1566// CHECK-NEXT: <array> 1567// CHECK-NEXT: <array> 1568// CHECK-NEXT: <dict> 1569// CHECK-NEXT: <key>line</key><integer>179</integer> 1570// CHECK-NEXT: <key>col</key><integer>4</integer> 1571// CHECK-NEXT: <key>file</key><integer>0</integer> 1572// CHECK-NEXT: </dict> 1573// CHECK-NEXT: <dict> 1574// CHECK-NEXT: <key>line</key><integer>179</integer> 1575// CHECK-NEXT: <key>col</key><integer>4</integer> 1576// CHECK-NEXT: <key>file</key><integer>0</integer> 1577// CHECK-NEXT: </dict> 1578// CHECK-NEXT: </array> 1579// CHECK-NEXT: </array> 1580// CHECK-NEXT: <key>depth</key><integer>2</integer> 1581// CHECK-NEXT: <key>extended_message</key> 1582// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable 'p')</string> 1583// CHECK-NEXT: <key>message</key> 1584// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable 'p')</string> 1585// CHECK-NEXT: </dict> 1586// CHECK-NEXT: </array> 1587// CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable 'p')</string> 1588// CHECK-NEXT: <key>category</key><string>Logic error</string> 1589// CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string> 1590// CHECK-NEXT: <key>location</key> 1591// CHECK-NEXT: <dict> 1592// CHECK-NEXT: <key>line</key><integer>179</integer> 1593// CHECK-NEXT: <key>col</key><integer>3</integer> 1594// CHECK-NEXT: <key>file</key><integer>0</integer> 1595// CHECK-NEXT: </dict> 1596// CHECK-NEXT: </dict> 1597// CHECK-NEXT: <dict> 1598// CHECK-NEXT: <key>path</key> 1599// CHECK-NEXT: <array> 1600// CHECK-NEXT: <dict> 1601// CHECK-NEXT: <key>kind</key><string>control</string> 1602// CHECK-NEXT: <key>edges</key> 1603// CHECK-NEXT: <array> 1604// CHECK-NEXT: <dict> 1605// CHECK-NEXT: <key>start</key> 1606// CHECK-NEXT: <array> 1607// CHECK-NEXT: <dict> 1608// CHECK-NEXT: <key>line</key><integer>186</integer> 1609// CHECK-NEXT: <key>col</key><integer>3</integer> 1610// CHECK-NEXT: <key>file</key><integer>0</integer> 1611// CHECK-NEXT: </dict> 1612// CHECK-NEXT: <dict> 1613// CHECK-NEXT: <key>line</key><integer>186</integer> 1614// CHECK-NEXT: <key>col</key><integer>8</integer> 1615// CHECK-NEXT: <key>file</key><integer>0</integer> 1616// CHECK-NEXT: </dict> 1617// CHECK-NEXT: </array> 1618// CHECK-NEXT: <key>end</key> 1619// CHECK-NEXT: <array> 1620// CHECK-NEXT: <dict> 1621// CHECK-NEXT: <key>line</key><integer>187</integer> 1622// CHECK-NEXT: <key>col</key><integer>3</integer> 1623// CHECK-NEXT: <key>file</key><integer>0</integer> 1624// CHECK-NEXT: </dict> 1625// CHECK-NEXT: <dict> 1626// CHECK-NEXT: <key>line</key><integer>187</integer> 1627// CHECK-NEXT: <key>col</key><integer>5</integer> 1628// CHECK-NEXT: <key>file</key><integer>0</integer> 1629// CHECK-NEXT: </dict> 1630// CHECK-NEXT: </array> 1631// CHECK-NEXT: </dict> 1632// CHECK-NEXT: </array> 1633// CHECK-NEXT: </dict> 1634// CHECK-NEXT: <dict> 1635// CHECK-NEXT: <key>kind</key><string>event</string> 1636// CHECK-NEXT: <key>location</key> 1637// CHECK-NEXT: <dict> 1638// CHECK-NEXT: <key>line</key><integer>187</integer> 1639// CHECK-NEXT: <key>col</key><integer>3</integer> 1640// CHECK-NEXT: <key>file</key><integer>0</integer> 1641// CHECK-NEXT: </dict> 1642// CHECK-NEXT: <key>ranges</key> 1643// CHECK-NEXT: <array> 1644// CHECK-NEXT: <array> 1645// CHECK-NEXT: <dict> 1646// CHECK-NEXT: <key>line</key><integer>187</integer> 1647// CHECK-NEXT: <key>col</key><integer>3</integer> 1648// CHECK-NEXT: <key>file</key><integer>0</integer> 1649// CHECK-NEXT: </dict> 1650// CHECK-NEXT: <dict> 1651// CHECK-NEXT: <key>line</key><integer>187</integer> 1652// CHECK-NEXT: <key>col</key><integer>8</integer> 1653// CHECK-NEXT: <key>file</key><integer>0</integer> 1654// CHECK-NEXT: </dict> 1655// CHECK-NEXT: </array> 1656// CHECK-NEXT: </array> 1657// CHECK-NEXT: <key>depth</key><integer>0</integer> 1658// CHECK-NEXT: <key>extended_message</key> 1659// CHECK-NEXT: <string>Variable 'p' initialized to a null pointer value</string> 1660// CHECK-NEXT: <key>message</key> 1661// CHECK-NEXT: <string>Variable 'p' initialized to a null pointer value</string> 1662// CHECK-NEXT: </dict> 1663// CHECK-NEXT: <dict> 1664// CHECK-NEXT: <key>kind</key><string>event</string> 1665// CHECK-NEXT: <key>location</key> 1666// CHECK-NEXT: <dict> 1667// CHECK-NEXT: <key>line</key><integer>188</integer> 1668// CHECK-NEXT: <key>col</key><integer>3</integer> 1669// CHECK-NEXT: <key>file</key><integer>0</integer> 1670// CHECK-NEXT: </dict> 1671// CHECK-NEXT: <key>ranges</key> 1672// CHECK-NEXT: <array> 1673// CHECK-NEXT: <array> 1674// CHECK-NEXT: <dict> 1675// CHECK-NEXT: <key>line</key><integer>188</integer> 1676// CHECK-NEXT: <key>col</key><integer>3</integer> 1677// CHECK-NEXT: <key>file</key><integer>0</integer> 1678// CHECK-NEXT: </dict> 1679// CHECK-NEXT: <dict> 1680// CHECK-NEXT: <key>line</key><integer>190</integer> 1681// CHECK-NEXT: <key>col</key><integer>4</integer> 1682// CHECK-NEXT: <key>file</key><integer>0</integer> 1683// CHECK-NEXT: </dict> 1684// CHECK-NEXT: </array> 1685// CHECK-NEXT: </array> 1686// CHECK-NEXT: <key>depth</key><integer>0</integer> 1687// CHECK-NEXT: <key>extended_message</key> 1688// CHECK-NEXT: <string>Calling '_dispatch_once'</string> 1689// CHECK-NEXT: <key>message</key> 1690// CHECK-NEXT: <string>Calling '_dispatch_once'</string> 1691// CHECK-NEXT: </dict> 1692// CHECK-NEXT: <dict> 1693// CHECK-NEXT: <key>kind</key><string>event</string> 1694// CHECK-NEXT: <key>location</key> 1695// CHECK-NEXT: <dict> 1696// CHECK-NEXT: <key>line</key><integer>162</integer> 1697// CHECK-NEXT: <key>col</key><integer>1</integer> 1698// CHECK-NEXT: <key>file</key><integer>0</integer> 1699// CHECK-NEXT: </dict> 1700// CHECK-NEXT: <key>depth</key><integer>1</integer> 1701// CHECK-NEXT: <key>extended_message</key> 1702// CHECK-NEXT: <string>Entered call from 'test_inline_dispatch_once'</string> 1703// CHECK-NEXT: <key>message</key> 1704// CHECK-NEXT: <string>Entered call from 'test_inline_dispatch_once'</string> 1705// CHECK-NEXT: </dict> 1706// CHECK-NEXT: <dict> 1707// CHECK-NEXT: <key>kind</key><string>control</string> 1708// CHECK-NEXT: <key>edges</key> 1709// CHECK-NEXT: <array> 1710// CHECK-NEXT: <dict> 1711// CHECK-NEXT: <key>start</key> 1712// CHECK-NEXT: <array> 1713// CHECK-NEXT: <dict> 1714// CHECK-NEXT: <key>line</key><integer>162</integer> 1715// CHECK-NEXT: <key>col</key><integer>1</integer> 1716// CHECK-NEXT: <key>file</key><integer>0</integer> 1717// CHECK-NEXT: </dict> 1718// CHECK-NEXT: <dict> 1719// CHECK-NEXT: <key>line</key><integer>162</integer> 1720// CHECK-NEXT: <key>col</key><integer>6</integer> 1721// CHECK-NEXT: <key>file</key><integer>0</integer> 1722// CHECK-NEXT: </dict> 1723// CHECK-NEXT: </array> 1724// CHECK-NEXT: <key>end</key> 1725// CHECK-NEXT: <array> 1726// CHECK-NEXT: <dict> 1727// CHECK-NEXT: <key>line</key><integer>164</integer> 1728// CHECK-NEXT: <key>col</key><integer>3</integer> 1729// CHECK-NEXT: <key>file</key><integer>0</integer> 1730// CHECK-NEXT: </dict> 1731// CHECK-NEXT: <dict> 1732// CHECK-NEXT: <key>line</key><integer>164</integer> 1733// CHECK-NEXT: <key>col</key><integer>15</integer> 1734// CHECK-NEXT: <key>file</key><integer>0</integer> 1735// CHECK-NEXT: </dict> 1736// CHECK-NEXT: </array> 1737// CHECK-NEXT: </dict> 1738// CHECK-NEXT: </array> 1739// CHECK-NEXT: </dict> 1740// CHECK-NEXT: <dict> 1741// CHECK-NEXT: <key>kind</key><string>event</string> 1742// CHECK-NEXT: <key>location</key> 1743// CHECK-NEXT: <dict> 1744// CHECK-NEXT: <key>line</key><integer>164</integer> 1745// CHECK-NEXT: <key>col</key><integer>3</integer> 1746// CHECK-NEXT: <key>file</key><integer>0</integer> 1747// CHECK-NEXT: </dict> 1748// CHECK-NEXT: <key>ranges</key> 1749// CHECK-NEXT: <array> 1750// CHECK-NEXT: <array> 1751// CHECK-NEXT: <dict> 1752// CHECK-NEXT: <key>line</key><integer>164</integer> 1753// CHECK-NEXT: <key>col</key><integer>3</integer> 1754// CHECK-NEXT: <key>file</key><integer>0</integer> 1755// CHECK-NEXT: </dict> 1756// CHECK-NEXT: <dict> 1757// CHECK-NEXT: <key>line</key><integer>164</integer> 1758// CHECK-NEXT: <key>col</key><integer>33</integer> 1759// CHECK-NEXT: <key>file</key><integer>0</integer> 1760// CHECK-NEXT: </dict> 1761// CHECK-NEXT: </array> 1762// CHECK-NEXT: </array> 1763// CHECK-NEXT: <key>depth</key><integer>1</integer> 1764// CHECK-NEXT: <key>extended_message</key> 1765// CHECK-NEXT: <string>Calling 'dispatch_once'</string> 1766// CHECK-NEXT: <key>message</key> 1767// CHECK-NEXT: <string>Calling 'dispatch_once'</string> 1768// CHECK-NEXT: </dict> 1769// CHECK-NEXT: <dict> 1770// CHECK-NEXT: <key>kind</key><string>event</string> 1771// CHECK-NEXT: <key>location</key> 1772// CHECK-NEXT: <dict> 1773// CHECK-NEXT: <key>line</key><integer>38</integer> 1774// CHECK-NEXT: <key>col</key><integer>1</integer> 1775// CHECK-NEXT: <key>file</key><integer>0</integer> 1776// CHECK-NEXT: </dict> 1777// CHECK-NEXT: <key>depth</key><integer>2</integer> 1778// CHECK-NEXT: <key>extended_message</key> 1779// CHECK-NEXT: <string>Entered call from '_dispatch_once'</string> 1780// CHECK-NEXT: <key>message</key> 1781// CHECK-NEXT: <string>Entered call from '_dispatch_once'</string> 1782// CHECK-NEXT: </dict> 1783// CHECK-NEXT: <dict> 1784// CHECK-NEXT: <key>kind</key><string>event</string> 1785// CHECK-NEXT: <key>location</key> 1786// CHECK-NEXT: <dict> 1787// CHECK-NEXT: <key>line</key><integer>164</integer> 1788// CHECK-NEXT: <key>col</key><integer>3</integer> 1789// CHECK-NEXT: <key>file</key><integer>0</integer> 1790// CHECK-NEXT: </dict> 1791// CHECK-NEXT: <key>ranges</key> 1792// CHECK-NEXT: <array> 1793// CHECK-NEXT: <array> 1794// CHECK-NEXT: <dict> 1795// CHECK-NEXT: <key>line</key><integer>164</integer> 1796// CHECK-NEXT: <key>col</key><integer>3</integer> 1797// CHECK-NEXT: <key>file</key><integer>0</integer> 1798// CHECK-NEXT: </dict> 1799// CHECK-NEXT: <dict> 1800// CHECK-NEXT: <key>line</key><integer>164</integer> 1801// CHECK-NEXT: <key>col</key><integer>33</integer> 1802// CHECK-NEXT: <key>file</key><integer>0</integer> 1803// CHECK-NEXT: </dict> 1804// CHECK-NEXT: </array> 1805// CHECK-NEXT: </array> 1806// CHECK-NEXT: <key>depth</key><integer>2</integer> 1807// CHECK-NEXT: <key>extended_message</key> 1808// CHECK-NEXT: <string>Calling anonymous block</string> 1809// CHECK-NEXT: <key>message</key> 1810// CHECK-NEXT: <string>Calling anonymous block</string> 1811// CHECK-NEXT: </dict> 1812// CHECK-NEXT: <dict> 1813// CHECK-NEXT: <key>kind</key><string>event</string> 1814// CHECK-NEXT: <key>location</key> 1815// CHECK-NEXT: <dict> 1816// CHECK-NEXT: <key>line</key><integer>188</integer> 1817// CHECK-NEXT: <key>col</key><integer>24</integer> 1818// CHECK-NEXT: <key>file</key><integer>0</integer> 1819// CHECK-NEXT: </dict> 1820// CHECK-NEXT: <key>depth</key><integer>3</integer> 1821// CHECK-NEXT: <key>extended_message</key> 1822// CHECK-NEXT: <string>Entered call from 'dispatch_once'</string> 1823// CHECK-NEXT: <key>message</key> 1824// CHECK-NEXT: <string>Entered call from 'dispatch_once'</string> 1825// CHECK-NEXT: </dict> 1826// CHECK-NEXT: <dict> 1827// CHECK-NEXT: <key>kind</key><string>control</string> 1828// CHECK-NEXT: <key>edges</key> 1829// CHECK-NEXT: <array> 1830// CHECK-NEXT: <dict> 1831// CHECK-NEXT: <key>start</key> 1832// CHECK-NEXT: <array> 1833// CHECK-NEXT: <dict> 1834// CHECK-NEXT: <key>line</key><integer>188</integer> 1835// CHECK-NEXT: <key>col</key><integer>24</integer> 1836// CHECK-NEXT: <key>file</key><integer>0</integer> 1837// CHECK-NEXT: </dict> 1838// CHECK-NEXT: <dict> 1839// CHECK-NEXT: <key>line</key><integer>188</integer> 1840// CHECK-NEXT: <key>col</key><integer>24</integer> 1841// CHECK-NEXT: <key>file</key><integer>0</integer> 1842// CHECK-NEXT: </dict> 1843// CHECK-NEXT: </array> 1844// CHECK-NEXT: <key>end</key> 1845// CHECK-NEXT: <array> 1846// CHECK-NEXT: <dict> 1847// CHECK-NEXT: <key>line</key><integer>189</integer> 1848// CHECK-NEXT: <key>col</key><integer>4</integer> 1849// CHECK-NEXT: <key>file</key><integer>0</integer> 1850// CHECK-NEXT: </dict> 1851// CHECK-NEXT: <dict> 1852// CHECK-NEXT: <key>line</key><integer>189</integer> 1853// CHECK-NEXT: <key>col</key><integer>4</integer> 1854// CHECK-NEXT: <key>file</key><integer>0</integer> 1855// CHECK-NEXT: </dict> 1856// CHECK-NEXT: </array> 1857// CHECK-NEXT: </dict> 1858// CHECK-NEXT: </array> 1859// CHECK-NEXT: </dict> 1860// CHECK-NEXT: <dict> 1861// CHECK-NEXT: <key>kind</key><string>event</string> 1862// CHECK-NEXT: <key>location</key> 1863// CHECK-NEXT: <dict> 1864// CHECK-NEXT: <key>line</key><integer>189</integer> 1865// CHECK-NEXT: <key>col</key><integer>4</integer> 1866// CHECK-NEXT: <key>file</key><integer>0</integer> 1867// CHECK-NEXT: </dict> 1868// CHECK-NEXT: <key>ranges</key> 1869// CHECK-NEXT: <array> 1870// CHECK-NEXT: <array> 1871// CHECK-NEXT: <dict> 1872// CHECK-NEXT: <key>line</key><integer>189</integer> 1873// CHECK-NEXT: <key>col</key><integer>5</integer> 1874// CHECK-NEXT: <key>file</key><integer>0</integer> 1875// CHECK-NEXT: </dict> 1876// CHECK-NEXT: <dict> 1877// CHECK-NEXT: <key>line</key><integer>189</integer> 1878// CHECK-NEXT: <key>col</key><integer>5</integer> 1879// CHECK-NEXT: <key>file</key><integer>0</integer> 1880// CHECK-NEXT: </dict> 1881// CHECK-NEXT: </array> 1882// CHECK-NEXT: </array> 1883// CHECK-NEXT: <key>depth</key><integer>3</integer> 1884// CHECK-NEXT: <key>extended_message</key> 1885// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable 'p')</string> 1886// CHECK-NEXT: <key>message</key> 1887// CHECK-NEXT: <string>Dereference of null pointer (loaded from variable 'p')</string> 1888// CHECK-NEXT: </dict> 1889// CHECK-NEXT: </array> 1890// CHECK-NEXT: <key>description</key><string>Dereference of null pointer (loaded from variable 'p')</string> 1891// CHECK-NEXT: <key>category</key><string>Logic error</string> 1892// CHECK-NEXT: <key>type</key><string>Dereference of null pointer</string> 1893// CHECK-NEXT: <key>location</key> 1894// CHECK-NEXT: <dict> 1895// CHECK-NEXT: <key>line</key><integer>189</integer> 1896// CHECK-NEXT: <key>col</key><integer>4</integer> 1897// CHECK-NEXT: <key>file</key><integer>0</integer> 1898// CHECK-NEXT: </dict> 1899// CHECK-NEXT: </dict> 1900// CHECK-NEXT: </array> 1901