Artem Dergachev | 5570595 | 2017-01-25 10:21:45 +0000 | [diff] [blame] | 1 | // RUN: %clang_cc1 -w -fblocks -analyze -analyzer-checker=core,deadcode,alpha.core,debug.ExprInspection -verify %s |
| 2 | |
| 3 | void *malloc(unsigned long); |
| 4 | void clang_analyzer_warnIfReached(); |
| 5 | |
| 6 | void test_static_from_block() { |
| 7 | static int *x; |
| 8 | ^{ |
| 9 | *x; // no-warning |
| 10 | }; |
| 11 | } |
| 12 | |
| 13 | void test_static_within_block() { |
| 14 | ^{ |
| 15 | static int *x; |
| 16 | *x; // expected-warning{{Dereference of null pointer}} |
| 17 | }; |
| 18 | } |
| 19 | |
| 20 | void test_static_control_flow(int y) { |
| 21 | static int *x; |
| 22 | if (x) { |
| 23 | // FIXME: Should be reachable. |
| 24 | clang_analyzer_warnIfReached(); // no-warning |
| 25 | } |
| 26 | if (y) { |
| 27 | // We are not sure if this branch is possible, because the developer |
| 28 | // may argue that function is always called with y == 1 for the first time. |
| 29 | // In this case, we can only advise the developer to add assertions |
| 30 | // for suppressing such path. |
| 31 | *x; // expected-warning{{Dereference of null pointer}} |
| 32 | } else { |
| 33 | x = malloc(1); |
| 34 | } |
| 35 | } |