diff options
author | Douglas Gregor <dgregor@apple.com> | 2009-02-12 00:26:06 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2009-02-12 00:26:06 +0000 |
commit | b7b5d13de34272b31681e7eafa9851e39bde2ef9 (patch) | |
tree | aba50fd7bed1e636c6a5103972786c468543d259 /lib/Sema/SemaOverload.cpp | |
parent | 5cdf82164dd7c2b2320d6735c63ace4331e0716d (diff) |
Expand the definition of a complex promotion to include complex ->
complex conversions where the conversion between the real types is an
integral promotion. This is how G++ handles complex promotions for its
complex integer extension.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@64344 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/SemaOverload.cpp')
-rw-r--r-- | lib/Sema/SemaOverload.cpp | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/lib/Sema/SemaOverload.cpp b/lib/Sema/SemaOverload.cpp index 48d31056a7..c96fec70bb 100644 --- a/lib/Sema/SemaOverload.cpp +++ b/lib/Sema/SemaOverload.cpp @@ -738,7 +738,9 @@ bool Sema::IsIntegralPromotion(Expr *From, QualType FromType, QualType ToType) // the bit-field is larger yet, no integral promotion applies to // it. If the bit-field has an enumerated type, it is treated as any // other value of that type for promotion purposes (C++ 4.5p3). - if (MemberExpr *MemRef = dyn_cast<MemberExpr>(From)) { + // FIXME: We should delay checking of bit-fields until we actually + // perform the conversion. + if (MemberExpr *MemRef = dyn_cast_or_null<MemberExpr>(From)) { using llvm::APSInt; if (FieldDecl *MemberDecl = dyn_cast<FieldDecl>(MemRef->getMemberDecl())) { APSInt BitWidth; @@ -803,7 +805,7 @@ bool Sema::IsFloatingPointPromotion(QualType FromType, QualType ToType) /// /// A complex promotion is defined as a complex -> complex conversion /// where the conversion between the underlying real types is a -/// floating-point conversion. +/// floating-point or integral promotion. bool Sema::IsComplexPromotion(QualType FromType, QualType ToType) { const ComplexType *FromComplex = FromType->getAsComplexType(); if (!FromComplex) @@ -814,7 +816,9 @@ bool Sema::IsComplexPromotion(QualType FromType, QualType ToType) { return false; return IsFloatingPointPromotion(FromComplex->getElementType(), - ToComplex->getElementType()); + ToComplex->getElementType()) || + IsIntegralPromotion(0, FromComplex->getElementType(), + ToComplex->getElementType()); } /// BuildSimilarlyQualifiedPointerType - In a pointer conversion from |