1 // RUN: %clang_analyze_cc1 -analyzer-checker=core,debug.ExprInspection -triple x86_64-apple-darwin13 -Wno-shift-count-overflow -verify %s
3 void clang_analyzer_eval(int);
4 #define CHECK(expr) if (!(expr)) return; clang_analyzer_eval(expr)
6 void testPersistentConstraints(int x
, int y
) {
8 CHECK(x
); // expected-warning{{TRUE}}
9 CHECK(x
& 1); // expected-warning{{TRUE}}
11 CHECK(1 - x
); // expected-warning{{TRUE}}
12 CHECK(x
& y
); // expected-warning{{TRUE}}
15 int testConstantShifts_PR18073(int which
) {
16 // FIXME: We should have a checker that actually specifically checks bitwise
17 // shifts against the width of the LHS's /static/ type, rather than just
18 // having BasicValueFactory return "undefined" when dealing with two constant
22 return 0ULL << 63; // no-warning
24 return 0ULL << 64; // expected-warning{{The result of the left shift is undefined due to shifting by '64', which is greater or equal to the width of type 'unsigned long long'}}
26 return 0ULL << 65; // expected-warning{{The result of the left shift is undefined due to shifting by '65', which is greater or equal to the width of type 'unsigned long long'}}
33 int testOverflowShift(int a
) {
35 return 1 << a
; // expected-warning{{The result of the left shift is undefined due to shifting by '323', which is greater or equal to the width of type 'int'}}
40 int testNegativeShift(int a
) {
42 return 1 << a
; // expected-warning{{The result of the left shift is undefined because the right operand is negative}}
47 int testNegativeLeftShift(int a
) {
49 return a
<< 1; // expected-warning{{The result of the left shift is undefined because the left operand is negative}}
54 int testUnrepresentableLeftShift(int a
) {
56 return a
<< 30; // expected-warning{{The result of the left shift is undefined due to shifting '8' by '30', which is unrepresentable in the unsigned version of the return type 'int'}}