From 4ba675006b5a8edfc48b6a9bd3dcf54a70cc08f2 Mon Sep 17 00:00:00 2001 From: Roman Divacky Date: Tue, 13 Jul 2010 17:21:42 +0000 Subject: Update clang to r108243. --- test/Sema/self-comparison.c | 55 ++++++++++++++++++++++++++++++++++++++------- 1 file changed, 47 insertions(+), 8 deletions(-) (limited to 'test/Sema/self-comparison.c') diff --git a/test/Sema/self-comparison.c b/test/Sema/self-comparison.c index 1baba2755f43f..c5c0611e7c94d 100644 --- a/test/Sema/self-comparison.c +++ b/test/Sema/self-comparison.c @@ -1,11 +1,21 @@ // RUN: %clang_cc1 -fsyntax-only -verify %s int foo(int x) { - return x == x; // expected-warning {{self-comparison always results}} + return x == x; // expected-warning {{self-comparison always evaluates to true}} } int foo2(int x) { - return (x) != (((x))); // expected-warning {{self-comparison always results}} + return (x) != (((x))); // expected-warning {{self-comparison always evaluates to false}} +} + +void foo3(short s, short t) { + if (s == s) {} // expected-warning {{self-comparison always evaluates to true}} + if (s == t) {} // no-warning +} + +void foo4(void* v, void* w) { + if (v == v) {} // expected-warning {{self-comparison always evaluates to true}} + if (v == w) {} // no-warning } int qux(int x) { @@ -24,15 +34,44 @@ int bar2(float x) { return x != x; // no-warning } -// Motivated by , self-comparisons of enum constants -// should not be warned about. These can be expanded from macros, and thus -// are usually deliberate. -int compare_enum() { - enum { A }; - return A == A; // no-warning +#define IS_THE_ANSWER(x) (x == 42) + +int macro_comparison() { + return IS_THE_ANSWER(42); } // Don't complain in unevaluated contexts. int compare_sizeof(int x) { return sizeof(x == x); // no-warning } + +int array_comparisons() { + int array1[2]; + int array2[2]; + + // + // compare same array + // + return array1 == array1; // expected-warning{{self-comparison always evaluates to true}} + return array1 != array1; // expected-warning{{self-comparison always evaluates to false}} + return array1 < array1; // expected-warning{{self-comparison always evaluates to false}} + return array1 <= array1; // expected-warning{{self-comparison always evaluates to true}} + return array1 > array1; // expected-warning{{self-comparison always evaluates to false}} + return array1 >= array1; // expected-warning{{self-comparison always evaluates to true}} + + // + // compare differrent arrays + // + return array1 == array2; // expected-warning{{array comparison always evaluates to false}} + return array1 != array2; // expected-warning{{array comparison always evaluates to true}} + + // + // we don't know what these are going to be + // + return array1 < array2; // expected-warning{{array comparison always evaluates to a constant}} + return array1 <= array2; // expected-warning{{array comparison always evaluates to a constant}} + return array1 > array2; // expected-warning{{array comparison always evaluates to a constant}} + return array1 >= array2; // expected-warning{{array comparison always evaluates to a constant}} + +} + -- cgit v1.2.3