blob: 12264ff89270d2567c1b9c846f028221ecc9b3c4 [file] [log] [blame]
// RUN: %clang_cc1 -x c -fsyntax-only -verify -Wenum-compare-conditional %s
// RUN: %clang_cc1 -x c++ -fsyntax-only -verify -Wenum-compare-conditional %s
enum ro { A = 0x10 };
enum rw { B = 0xFF };
enum { C = 0x1A};
enum {
STATUS_SUCCESS,
STATUS_FAILURE,
MAX_BASE_STATUS_CODE
};
enum ExtendedStatusCodes {
STATUS_SOMETHING_INTERESTING = MAX_BASE_STATUS_CODE + 1000,
};
int get_flag(int cond) {
return cond ? A : B;
#ifdef __cplusplus
// expected-warning@-2 {{enumeration type mismatch in conditional expression ('ro' and 'rw')}}
#else
// expected-no-diagnostics
#endif
}
// In the following cases we purposefully differ from GCC and dont warn because
// this code pattern is quite sensitive and we dont want to produce so many false positives.
int get_flag_anon_enum(int cond) {
return cond ? A : C;
}
int foo(int c) {
return c ? STATUS_SOMETHING_INTERESTING : STATUS_SUCCESS;
}