| // RUN: %clang_cc1 -Wno-array-bounds -analyze -analyzer-checker=core,alpha.security.ArrayBound -analyzer-store=region -verify %s | 
 | // XFAIL: * | 
 |  | 
 | // Once we better handle modeling of sizes of VLAs, we can pull this back | 
 | // into outofbound.c. | 
 |  | 
 | void sizeof_vla(int a) { | 
 |   if (a == 5) { | 
 |     char x[a]; | 
 |     int y[sizeof(x)]; | 
 |     y[4] = 4; // no-warning | 
 |     y[5] = 5; // expected-warning{{out-of-bound}} | 
 |   } | 
 | } | 
 |  | 
 | void sizeof_vla_2(int a) { | 
 |   if (a == 5) { | 
 |     char x[a]; | 
 |     int y[sizeof(x) / sizeof(char)]; | 
 |     y[4] = 4; // no-warning | 
 |     y[5] = 5; // expected-warning{{out-of-bound}} | 
 |   } | 
 | } | 
 |  | 
 | void sizeof_vla_3(int a) { | 
 |   if (a == 5) { | 
 |     char x[a]; | 
 |     int y[sizeof(*&*&*&x)]; | 
 |     y[4] = 4; // no-warning | 
 |     y[5] = 5; // expected-warning{{out-of-bound}} | 
 |   } | 
 | } |