diff options
author | Jordan Rose <jordan_rose@apple.com> | 2014-05-20 17:31:11 +0000 |
---|---|---|
committer | Jordan Rose <jordan_rose@apple.com> | 2014-05-20 17:31:11 +0000 |
commit | 7afd71e4ff5d13fdea68cd1261a96b19488d39db (patch) | |
tree | 386aabbe4f8b56b23161b66b32bc5ff0e77b8f92 /clang/test/Sema/warn-bitwise-compare.c | |
parent | d2402470ee1b1253f6dc312b22fd967906ae8bd4 (diff) | |
download | bcm5719-llvm-7afd71e4ff5d13fdea68cd1261a96b19488d39db.tar.gz bcm5719-llvm-7afd71e4ff5d13fdea68cd1261a96b19488d39db.zip |
Add a check for tautological bitwise comparisons to -Wtautological-compare.
This catches issues like:
if ((x & 8) == 4) { ... }
if ((x | 4) != 3) { ... }
Patch by Anders Rönnholm!
llvm-svn: 209221
Diffstat (limited to 'clang/test/Sema/warn-bitwise-compare.c')
-rw-r--r-- | clang/test/Sema/warn-bitwise-compare.c | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/clang/test/Sema/warn-bitwise-compare.c b/clang/test/Sema/warn-bitwise-compare.c new file mode 100644 index 00000000000..175f8f5367f --- /dev/null +++ b/clang/test/Sema/warn-bitwise-compare.c @@ -0,0 +1,28 @@ +// RUN: %clang_cc1 -fsyntax-only -verify -Wtautological-compare %s + +#define mydefine 2 + +void f(int x) { + if ((8 & x) == 3) {} // expected-warning {{bitwise comparison always evaluates to false}} + if ((x & 8) == 4) {} // expected-warning {{bitwise comparison always evaluates to false}} + if ((x & 8) != 4) {} // expected-warning {{bitwise comparison always evaluates to true}} + if ((2 & x) != 4) {} // expected-warning {{bitwise comparison always evaluates to true}} + if ((x | 4) == 3) {} // expected-warning {{bitwise comparison always evaluates to false}} + if ((x | 3) != 4) {} // expected-warning {{bitwise comparison always evaluates to true}} + if ((5 | x) != 3) {} // expected-warning {{bitwise comparison always evaluates to true}} + if ((x & 0x15) == 0x13) {} // expected-warning {{bitwise comparison always evaluates to false}} + if ((0x23 | x) == 0x155){} // expected-warning {{bitwise comparison always evaluates to false}} + + if ((x & 8) == 8) {} + if ((x & 8) != 8) {} + if ((x | 4) == 4) {} + if ((x | 4) != 4) {} + + if ((x & 9) == 8) {} + if ((x & 9) != 8) {} + if ((x | 4) == 5) {} + if ((x | 4) != 5) {} + + if ((x & mydefine) == 8) {} + if ((x | mydefine) == 4) {} +} |