llvm-project/clang/test/SemaCXX/constant-conversion.cpp
Sam McCall 880fa7faa9 Revert "[clang][SemaCXX] Diagnose tautological uses of consteval if and is_constant_evaluated"
This reverts commit 491b2810fb7fe5f080fa9c4f5945ed0a6909dc92.

This change broke valid code and generated incorrect diagnostics, see
https://reviews.llvm.org/D155064
2023-09-27 18:58:01 +02:00

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
}