2017-01-25 18:21:45 +08:00
|
|
|
// RUN: %clang_cc1 -w -fblocks -analyze -analyzer-checker=core,deadcode,alpha.core,debug.ExprInspection -verify %s
|
|
|
|
|
|
|
|
void *malloc(unsigned long);
|
2022-02-13 21:02:46 +08:00
|
|
|
void clang_analyzer_warnIfReached(void);
|
2017-01-25 18:21:45 +08:00
|
|
|
|
2022-02-13 21:02:46 +08:00
|
|
|
void test_static_from_block(void) {
|
2017-01-25 18:21:45 +08:00
|
|
|
static int *x;
|
|
|
|
^{
|
|
|
|
*x; // no-warning
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2022-02-13 21:02:46 +08:00
|
|
|
void test_static_within_block(void) {
|
2017-01-25 18:21:45 +08:00
|
|
|
^{
|
|
|
|
static int *x;
|
|
|
|
*x; // expected-warning{{Dereference of null pointer}}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
void test_static_control_flow(int y) {
|
|
|
|
static int *x;
|
|
|
|
if (x) {
|
|
|
|
// FIXME: Should be reachable.
|
|
|
|
clang_analyzer_warnIfReached(); // no-warning
|
|
|
|
}
|
|
|
|
if (y) {
|
|
|
|
// We are not sure if this branch is possible, because the developer
|
|
|
|
// may argue that function is always called with y == 1 for the first time.
|
|
|
|
// In this case, we can only advise the developer to add assertions
|
|
|
|
// for suppressing such path.
|
|
|
|
*x; // expected-warning{{Dereference of null pointer}}
|
|
|
|
} else {
|
|
|
|
x = malloc(1);
|
|
|
|
}
|
|
|
|
}
|