diff options
author | Sebastian Redl <sebastian.redl@getdesigned.at> | 2012-02-19 16:03:09 +0000 |
---|---|---|
committer | Sebastian Redl <sebastian.redl@getdesigned.at> | 2012-02-19 16:03:09 +0000 |
commit | 972edf0534d8a50f87fac1d0ff34eb22f593df11 (patch) | |
tree | b0c119edcbbf2e81d8d9efb3027cc82671e28146 /lib | |
parent | 924db71fc8f6076c532c8c2ae93acc7f477452c8 (diff) |
Make heap-allocation of std::initializer_list 'work'.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@150931 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r-- | lib/CodeGen/CGClass.cpp | 2 | ||||
-rw-r--r-- | lib/CodeGen/CGDecl.cpp | 2 | ||||
-rw-r--r-- | lib/CodeGen/CGExprAgg.cpp | 12 | ||||
-rw-r--r-- | lib/CodeGen/CGExprCXX.cpp | 2 | ||||
-rw-r--r-- | lib/CodeGen/CodeGenFunction.h | 2 |
5 files changed, 10 insertions, 10 deletions
diff --git a/lib/CodeGen/CGClass.cpp b/lib/CodeGen/CGClass.cpp index f269b675a0..2cea434f62 100644 --- a/lib/CodeGen/CGClass.cpp +++ b/lib/CodeGen/CGClass.cpp @@ -456,7 +456,7 @@ static void EmitAggMemberInitializer(CodeGenFunction &CGF, // Now, outside of the initializer cleanup scope, destroy the backing array // for a std::initializer_list member. - CGF.MaybeEmitStdInitializerListCleanup(LV, Init); + CGF.MaybeEmitStdInitializerListCleanup(LV.getAddress(), Init); return; } diff --git a/lib/CodeGen/CGDecl.cpp b/lib/CodeGen/CGDecl.cpp index 83d74106f3..fcea927c63 100644 --- a/lib/CodeGen/CGDecl.cpp +++ b/lib/CodeGen/CGDecl.cpp @@ -1093,7 +1093,7 @@ void CodeGenFunction::EmitExprAsInit(const Expr *init, AggValueSlot::IsDestructed, AggValueSlot::DoesNotNeedGCBarriers, AggValueSlot::IsNotAliased)); - MaybeEmitStdInitializerListCleanup(lvalue, init); + MaybeEmitStdInitializerListCleanup(lvalue.getAddress(), init); } } diff --git a/lib/CodeGen/CGExprAgg.cpp b/lib/CodeGen/CGExprAgg.cpp index 13f5bc47d5..afe70a5dda 100644 --- a/lib/CodeGen/CGExprAgg.cpp +++ b/lib/CodeGen/CGExprAgg.cpp @@ -1263,19 +1263,17 @@ void CodeGenFunction::EmitAggregateCopy(llvm::Value *DestPtr, Alignment, isVolatile); } -void CodeGenFunction::MaybeEmitStdInitializerListCleanup(LValue lvalue, - const Expr *init) { +void CodeGenFunction::MaybeEmitStdInitializerListCleanup(llvm::Value *loc, + const Expr *init) { const ExprWithCleanups *cleanups = dyn_cast<ExprWithCleanups>(init); - if (!cleanups) - return; // Nothing interesting here. - init = cleanups->getSubExpr(); + if (cleanups) + init = cleanups->getSubExpr(); if (isa<InitListExpr>(init) && cast<InitListExpr>(init)->initializesStdInitializerList()) { // We initialized this std::initializer_list with an initializer list. // A backing array was created. Push a cleanup for it. - EmitStdInitializerListCleanup(lvalue.getAddress(), - cast<InitListExpr>(init)); + EmitStdInitializerListCleanup(loc, cast<InitListExpr>(init)); } } diff --git a/lib/CodeGen/CGExprCXX.cpp b/lib/CodeGen/CGExprCXX.cpp index 548bbc9e61..7c7bdd9eda 100644 --- a/lib/CodeGen/CGExprCXX.cpp +++ b/lib/CodeGen/CGExprCXX.cpp @@ -762,6 +762,8 @@ static void StoreAnyExprIntoOneUnit(CodeGenFunction &CGF, const CXXNewExpr *E, AggValueSlot::DoesNotNeedGCBarriers, AggValueSlot::IsNotAliased); CGF.EmitAggExpr(Init, Slot); + + CGF.MaybeEmitStdInitializerListCleanup(NewPtr, Init); } } diff --git a/lib/CodeGen/CodeGenFunction.h b/lib/CodeGen/CodeGenFunction.h index 95420e5344..6327fa2225 100644 --- a/lib/CodeGen/CodeGenFunction.h +++ b/lib/CodeGen/CodeGenFunction.h @@ -1811,7 +1811,7 @@ public: llvm::Value* EmitCXXTypeidExpr(const CXXTypeidExpr *E); llvm::Value *EmitDynamicCast(llvm::Value *V, const CXXDynamicCastExpr *DCE); - void MaybeEmitStdInitializerListCleanup(LValue lvalue, const Expr *init); + void MaybeEmitStdInitializerListCleanup(llvm::Value *loc, const Expr *init); void EmitStdInitializerListCleanup(llvm::Value *loc, const InitListExpr *init); |