2009-12-16 04:14:24 +08:00
|
|
|
// RUN: %clang_cc1 -fsyntax-only -verify %s
|
2007-10-30 00:58:49 +08:00
|
|
|
|
|
|
|
int foo(int x) {
|
|
|
|
return x == x; // expected-warning {{self-comparison always results}}
|
|
|
|
}
|
|
|
|
|
|
|
|
int foo2(int x) {
|
|
|
|
return (x) != (((x))); // expected-warning {{self-comparison always results}}
|
|
|
|
}
|
|
|
|
|
2007-10-30 01:02:56 +08:00
|
|
|
int qux(int x) {
|
|
|
|
return x < x; // expected-warning {{self-comparison}}
|
|
|
|
}
|
|
|
|
|
|
|
|
int qux2(int x) {
|
|
|
|
return x > x; // expected-warning {{self-comparison}}
|
|
|
|
}
|
|
|
|
|
2007-10-30 00:58:49 +08:00
|
|
|
int bar(float x) {
|
|
|
|
return x == x; // no-warning
|
|
|
|
}
|
|
|
|
|
|
|
|
int bar2(float x) {
|
|
|
|
return x != x; // no-warning
|
2007-10-30 01:02:56 +08:00
|
|
|
}
|
2009-03-21 02:35:45 +08:00
|
|
|
|
|
|
|
// Motivated by <rdar://problem/6703892>, 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
|
|
|
|
}
|
2010-01-13 07:18:54 +08:00
|
|
|
|
|
|
|
// Don't complain in unevaluated contexts.
|
|
|
|
int compare_sizeof(int x) {
|
|
|
|
return sizeof(x == x); // no-warning
|
|
|
|
}
|