aboutsummaryrefslogtreecommitdiff
path: root/test/Sema/self-comparison.c
blob: db56e8bf17d80efae9f9aafd30698af7391616b0 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
// RUN: clang-cc -fsyntax-only -verify %s

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}}
}

int qux(int x) {
   return x < x; // expected-warning {{self-comparison}}
}

int qux2(int x) {
   return x > x; // expected-warning {{self-comparison}}
}

int bar(float x) {
  return x == x; // no-warning
}

int bar2(float x) {
  return x != x; // no-warning
}

// 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
}