Added warning for unary minus used with unsigned type
Summary:
Inspired by MSVC, which found some occurrences of this expression on our code base.
Fixes PR38950
Reviewers: rsmith, craig.topper, spatel, RKSimon, aaron.ballman, thakis
Reviewed By: rsmith
Subscribers: joerg, Quuxplusone, lebedev.ri, craig.topper, RKSimon, cfe-commits
Differential Revision: https://reviews.llvm.org/D52137
llvm-svn: 343560
2018-10-02 14:02:30 +08:00
|
|
|
// RUN: %clang_cc1 %s -verify -Wconversion -fsyntax-only -triple x86_64-pc-linux-gnu
|
|
|
|
// RUN: %clang_cc1 %s -verify -Wconversion -fsyntax-only -triple i386-pc-linux-gnu
|
|
|
|
|
|
|
|
void test(void) {
|
|
|
|
unsigned int a = 1;
|
|
|
|
|
|
|
|
unsigned long long b = -a; // expected-warning {{higher order bits are zeroes after implicit conversion}}
|
|
|
|
long long c = -a; // expected-warning {{the resulting value is always non-negative after implicit conversion}}
|
|
|
|
|
|
|
|
unsigned long b2 = -a;
|
|
|
|
#ifdef __x86_64__
|
|
|
|
// expected-warning@-2 {{higher order bits are zeroes after implicit conversion}}
|
|
|
|
#endif
|
|
|
|
long c2 = -a;
|
|
|
|
#ifdef __x86_64__
|
|
|
|
// expected-warning@-2 {{the resulting value is always non-negative after implicit conversion}}
|
|
|
|
#else
|
|
|
|
// expected-warning@-4 {{implicit conversion changes signedness: 'unsigned int' to 'long'}}
|
|
|
|
#endif
|
2020-09-02 08:39:57 +08:00
|
|
|
|
|
|
|
unsigned m;
|
|
|
|
int n = -(m & 0xff); // no warning
|
Added warning for unary minus used with unsigned type
Summary:
Inspired by MSVC, which found some occurrences of this expression on our code base.
Fixes PR38950
Reviewers: rsmith, craig.topper, spatel, RKSimon, aaron.ballman, thakis
Reviewed By: rsmith
Subscribers: joerg, Quuxplusone, lebedev.ri, craig.topper, RKSimon, cfe-commits
Differential Revision: https://reviews.llvm.org/D52137
llvm-svn: 343560
2018-10-02 14:02:30 +08:00
|
|
|
}
|