diff options
author | Richard Trieu <rtrieu@google.com> | 2015-05-20 23:29:18 +0000 |
---|---|---|
committer | Richard Trieu <rtrieu@google.com> | 2015-05-20 23:29:18 +0000 |
commit | cbab79a4f8853bd796bf6b90de48e64a5728e8c0 (patch) | |
tree | 6d7ee850b39c2a9166fc425061da10278d3d6170 /clang/test/Sema/warn-string-conversion.c | |
parent | 69fc4418ab2845a5cbbd08c913ec16c6f73890ad (diff) | |
download | bcm5719-llvm-cbab79a4f8853bd796bf6b90de48e64a5728e8c0.tar.gz bcm5719-llvm-cbab79a4f8853bd796bf6b90de48e64a5728e8c0.zip |
Check for bool-like conversion in conditional expressions.
Add a check for bool-like conversions for the condition expression of
conditional operators. This is similiar to the checking of condition
expressions of if statements, for-loops, while-loops, and do-while loops.
Specificially, this is to fix the problem of assert("message") not triggering
-Wstring-conversion when the assert macro uses a conditional operator.
llvm-svn: 237856
Diffstat (limited to 'clang/test/Sema/warn-string-conversion.c')
-rw-r--r-- | clang/test/Sema/warn-string-conversion.c | 25 |
1 files changed, 21 insertions, 4 deletions
diff --git a/clang/test/Sema/warn-string-conversion.c b/clang/test/Sema/warn-string-conversion.c index 708dd543e40..28dfc1b67dd 100644 --- a/clang/test/Sema/warn-string-conversion.c +++ b/clang/test/Sema/warn-string-conversion.c @@ -1,12 +1,28 @@ // RUN: %clang_cc1 -verify -fsyntax-only -Wstring-conversion %s -#define assert(EXPR) (void)(EXPR); +void do_nothing(); +void assert_error(); + +#define assert1(expr) \ + if (expr) \ + do_nothing(); \ + else \ + assert_error() + +#define assert2(expr) \ + ((expr) ? do_nothing() : assert_error()) // Expection for common assert form. void test1() { - assert(0 && "foo"); - assert("foo" && 0); - assert(0 || "foo"); // expected-warning {{string literal}} + assert1(0 && "foo"); + assert1("foo" && 0); + assert1(0 || "foo"); // expected-warning {{string literal}} + assert1("foo"); // expected-warning {{string literal}} + + assert2(0 && "foo"); + assert2("foo" && 0); + assert2(0 || "foo"); // expected-warning {{string literal}} + assert2("foo"); // expected-warning {{string literal}} } void test2() { @@ -14,4 +30,5 @@ void test2() { while ("hello") {} // expected-warning {{string literal}} for (;"howdy";) {} // expected-warning {{string literal}} do { } while ("hey"); // expected-warning {{string literal}} + int x = "hey" ? 1 : 2; // expected-warning {{string literal}} } |