| // RUN: %clang_cc1 -Wno-array-bounds -analyze -analyzer-checker=core,experimental.unix,experimental.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}} |
| } |
| } |