forked from OSchip/llvm-project
[Sema] Require a complete type for __builtin_bit_cast operands
Fixes llvm.org/PR42936 llvm-svn: 368600
This commit is contained in:
parent
1308011e1b
commit
0a223d981e
|
@ -2803,6 +2803,14 @@ void CastOperation::CheckBuiltinBitCast() {
|
|||
SrcExpr = Self.CreateMaterializeTemporaryExpr(SrcType, SrcExpr.get(),
|
||||
/*IsLValueReference=*/false);
|
||||
|
||||
if (Self.RequireCompleteType(OpRange.getBegin(), DestType,
|
||||
diag::err_typecheck_cast_to_incomplete) ||
|
||||
Self.RequireCompleteType(OpRange.getBegin(), SrcType,
|
||||
diag::err_incomplete_type)) {
|
||||
SrcExpr = ExprError();
|
||||
return;
|
||||
}
|
||||
|
||||
CharUnits DestSize = Self.Context.getTypeSizeInChars(DestType);
|
||||
CharUnits SourceSize = Self.Context.getTypeSizeInChars(SrcType);
|
||||
if (DestSize != SourceSize) {
|
||||
|
|
|
@ -37,3 +37,12 @@ constexpr unsigned long ul = __builtin_bit_cast(unsigned long, not_trivially_cop
|
|||
|
||||
// expected-error@+1 {{__builtin_bit_cast destination type must be trivially copyable}}
|
||||
constexpr long us = __builtin_bit_cast(unsigned long &, 0L);
|
||||
|
||||
namespace PR42936 {
|
||||
template <class T> struct S { int m; };
|
||||
|
||||
extern S<int> extern_decl;
|
||||
|
||||
int x = __builtin_bit_cast(int, extern_decl);
|
||||
S<char> y = __builtin_bit_cast(S<char>, 0);
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue