diff options
author | Chris Lattner <sabre@nondot.org> | 2008-07-26 22:37:01 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2008-07-26 22:37:01 +0000 |
commit | 9619662a1d42e2008b865d3459c0677e149dad1b (patch) | |
tree | 0714b13525e4c45644753ff246259e78f6775fd5 /lib/CodeGen/CGExprAgg.cpp | |
parent | 8b51fd76319d8b71f401cc6ad56e6f4f7be77958 (diff) |
remove uses of QualType::getCanonicalType() from codegen for PR2189
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@54107 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/CGExprAgg.cpp')
-rw-r--r-- | lib/CodeGen/CGExprAgg.cpp | 41 |
1 files changed, 19 insertions, 22 deletions
diff --git a/lib/CodeGen/CGExprAgg.cpp b/lib/CodeGen/CGExprAgg.cpp index b9e850a473..ac2e6dec90 100644 --- a/lib/CodeGen/CGExprAgg.cpp +++ b/lib/CodeGen/CGExprAgg.cpp @@ -180,20 +180,15 @@ void AggExprEmitter::EmitAggLoadOfLValue(const Expr *E) { // Visitor Methods //===----------------------------------------------------------------------===// -void AggExprEmitter::VisitImplicitCastExpr(ImplicitCastExpr *E) -{ - QualType STy = E->getSubExpr()->getType().getCanonicalType(); - QualType Ty = E->getType().getCanonicalType(); - +void AggExprEmitter::VisitImplicitCastExpr(ImplicitCastExpr *E) { assert(CGF.getContext().typesAreCompatible( - STy.getUnqualifiedType(), Ty.getUnqualifiedType()) - && "Implicit cast types must be compatible"); - + E->getSubExpr()->getType().getUnqualifiedType(), + E->getType().getUnqualifiedType()) && + "Implicit cast types must be compatible"); Visit(E->getSubExpr()); } -void AggExprEmitter::VisitCallExpr(const CallExpr *E) -{ +void AggExprEmitter::VisitCallExpr(const CallExpr *E) { RValue RV = CGF.EmitCallExpr(E); assert(RV.isAggregate() && "Return value must be aggregate value!"); @@ -204,8 +199,8 @@ void AggExprEmitter::VisitCallExpr(const CallExpr *E) EmitAggregateCopy(DestPtr, RV.getAggregateAddr(), E->getType()); } -void AggExprEmitter::VisitObjCMessageExpr(ObjCMessageExpr *E) -{ + +void AggExprEmitter::VisitObjCMessageExpr(ObjCMessageExpr *E) { RValue RV = RValue::getAggregate(CGF.EmitObjCMessageExpr(E)); // If the result is ignored, don't copy from the value. @@ -215,8 +210,7 @@ void AggExprEmitter::VisitObjCMessageExpr(ObjCMessageExpr *E) EmitAggregateCopy(DestPtr, RV.getAggregateAddr(), E->getType()); } -void AggExprEmitter::VisitOverloadExpr(const OverloadExpr *E) -{ +void AggExprEmitter::VisitOverloadExpr(const OverloadExpr *E) { RValue RV = CGF.EmitCallExpr(E->getFn(), E->arg_begin(), E->arg_end(CGF.getContext())); @@ -230,8 +224,7 @@ void AggExprEmitter::VisitOverloadExpr(const OverloadExpr *E) EmitAggregateCopy(DestPtr, RV.getAggregateAddr(), E->getType()); } -void AggExprEmitter::VisitBinComma(const BinaryOperator *E) -{ +void AggExprEmitter::VisitBinComma(const BinaryOperator *E) { CGF.EmitAnyExpr(E->getLHS()); CGF.EmitAggExpr(E->getRHS(), DestPtr, false); } @@ -389,17 +382,21 @@ void AggExprEmitter::VisitInitListExpr(InitListExpr *E) { uint64_t NumInitElements = E->getNumInits(); - if (E->getNumInits() > 0 && - E->getType().getCanonicalType().getUnqualifiedType() == - E->getInit(0)->getType().getCanonicalType().getUnqualifiedType()) { - EmitAggLoadOfLValue(E->getInit(0)); - return; + if (E->getNumInits() > 0) { + QualType T1 = E->getType(); + QualType T2 = E->getInit(0)->getType(); + if (CGF.getContext().getCanonicalType(T1).getUnqualifiedType() == + CGF.getContext().getCanonicalType(T2).getUnqualifiedType()) { + EmitAggLoadOfLValue(E->getInit(0)); + return; + } } uint64_t NumArrayElements = AType->getNumElements(); QualType ElementType = E->getType()->getAsArrayType()->getElementType(); - unsigned CVRqualifier = E->getType().getCanonicalType()->getAsArrayType() + unsigned CVRqualifier = + CGF.getContext().getCanonicalType(E->getType())->getAsArrayType() ->getElementType().getCVRQualifiers(); for (uint64_t i = 0; i != NumArrayElements; ++i) { |