mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2024-12-12 01:18:53 +00:00
3b00e48679
https://reviews.llvm.org/D131255 (82afc9b169
)
began warning about conversion causing data loss for a single-bit
bit-field. However, after landing the changes, there were reports about
significant false positives from some code bases.
This alters the approach taken in that patch by introducing a new
warning group (-Wsingle-bit-bitfield-constant-conversion) which is
grouped under -Wbitfield-constant-conversion to allow users to
selectively disable the single-bit warning without losing the other
constant conversion warnings.
Differential Revision: https://reviews.llvm.org/D132851
34 lines
1.2 KiB
C++
34 lines
1.2 KiB
C++
// RUN: %clang_cc1 -fsyntax-only -verify -triple x86_64-apple-darwin %s
|
|
|
|
// This file tests -Wconstant-conversion, a subcategory of -Wconversion
|
|
// which is on by default.
|
|
|
|
constexpr int nines() { return 99999; }
|
|
|
|
void too_big_for_char(int param) {
|
|
char warn1 = false ? 0 : 99999;
|
|
// expected-warning@-1 {{implicit conversion from 'int' to 'char' changes value from 99999 to -97}}
|
|
char warn2 = false ? 0 : nines();
|
|
// expected-warning@-1 {{implicit conversion from 'int' to 'char' changes value from 99999 to -97}}
|
|
|
|
char warn3 = param > 0 ? 0 : 99999;
|
|
// expected-warning@-1 {{implicit conversion from 'int' to 'char' changes value from 99999 to -97}}
|
|
char warn4 = param > 0 ? 0 : nines();
|
|
// expected-warning@-1 {{implicit conversion from 'int' to 'char' changes value from 99999 to -97}}
|
|
|
|
char ok1 = true ? 0 : 99999;
|
|
char ok2 = true ? 0 : nines();
|
|
|
|
char ok3 = true ? 0 : 99999 + 1;
|
|
char ok4 = true ? 0 : nines() + 1;
|
|
}
|
|
|
|
void test_bitfield() {
|
|
struct S {
|
|
int one_bit : 1;
|
|
} s;
|
|
|
|
s.one_bit = 1; // expected-warning {{implicit truncation from 'int' to a one-bit wide bit-field changes value from 1 to -1}}
|
|
s.one_bit = true; // no-warning
|
|
}
|