summaryrefslogtreecommitdiffstats
path: root/clang/test/Sema/warn-string-conversion.c
diff options
context:
space:
mode:
authorRichard Trieu <rtrieu@google.com>2015-05-20 23:29:18 +0000
committerRichard Trieu <rtrieu@google.com>2015-05-20 23:29:18 +0000
commitcbab79a4f8853bd796bf6b90de48e64a5728e8c0 (patch)
tree6d7ee850b39c2a9166fc425061da10278d3d6170 /clang/test/Sema/warn-string-conversion.c
parent69fc4418ab2845a5cbbd08c913ec16c6f73890ad (diff)
downloadbcm5719-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.c25
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}}
}
OpenPOWER on IntegriCloud