From 44ec82b4a1597802f5bf17721481b8c265bc8dc5 Mon Sep 17 00:00:00 2001 From: Anders Carlsson Date: Tue, 30 Mar 2010 03:14:41 +0000 Subject: Introduce a CXXTemporariesCleanupScope RAII object and use it to cleanup the temporaries code. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@99865 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/CodeGen/CGClass.cpp | 46 +++++++++++++++++++++------------------------- 1 file changed, 21 insertions(+), 25 deletions(-) (limited to 'lib/CodeGen/CGClass.cpp') diff --git a/lib/CodeGen/CGClass.cpp b/lib/CodeGen/CGClass.cpp index 8d565f6d41..0cf1ac45b8 100644 --- a/lib/CodeGen/CGClass.cpp +++ b/lib/CodeGen/CGClass.cpp @@ -550,29 +550,27 @@ void CodeGenFunction::EmitClassMemberwiseCopy( CallArgs.push_back(std::make_pair(RValue::get(Src), BaseCopyCtor->getParamDecl(0)->getType())); - unsigned OldNumLiveTemporaries = LiveTemporaries.size(); + { + CXXTemporariesCleanupScope Scope(*this); - // If the copy constructor has default arguments, emit them. - for (unsigned I = 1, E = BaseCopyCtor->getNumParams(); I < E; ++I) { - const ParmVarDecl *Param = BaseCopyCtor->getParamDecl(I); - const Expr *DefaultArgExpr = Param->getDefaultArg(); - - assert(DefaultArgExpr && "Ctor parameter must have default arg!"); + // If the copy constructor has default arguments, emit them. + for (unsigned I = 1, E = BaseCopyCtor->getNumParams(); I < E; ++I) { + const ParmVarDecl *Param = BaseCopyCtor->getParamDecl(I); + const Expr *DefaultArgExpr = Param->getDefaultArg(); - QualType ArgType = Param->getType(); - CallArgs.push_back(std::make_pair(EmitCallArg(DefaultArgExpr, ArgType), - ArgType)); + assert(DefaultArgExpr && "Ctor parameter must have default arg!"); - } + QualType ArgType = Param->getType(); + CallArgs.push_back(std::make_pair(EmitCallArg(DefaultArgExpr, ArgType), + ArgType)); - const FunctionProtoType *FPT = - BaseCopyCtor->getType()->getAs(); - EmitCall(CGM.getTypes().getFunctionInfo(CallArgs, FPT), - Callee, ReturnValueSlot(), CallArgs, BaseCopyCtor); - - // Pop temporaries. - while (LiveTemporaries.size() > OldNumLiveTemporaries) - PopCXXTemporary(); + } + + const FunctionProtoType *FPT = + BaseCopyCtor->getType()->getAs(); + EmitCall(CGM.getTypes().getFunctionInfo(CallArgs, FPT), + Callee, ReturnValueSlot(), CallArgs, BaseCopyCtor); + } } } @@ -1306,14 +1304,12 @@ CodeGenFunction::EmitCXXAggrConstructorCall(const CXXConstructorDecl *D, // before the construction of the next array element, if any. // Keep track of the current number of live temporaries. - unsigned OldNumLiveTemporaries = LiveTemporaries.size(); + { + CXXTemporariesCleanupScope Scope(*this); - EmitCXXConstructorCall(D, Ctor_Complete, Address, ArgBeg, ArgEnd); + EmitCXXConstructorCall(D, Ctor_Complete, Address, ArgBeg, ArgEnd); + } - // Pop temporaries. - while (LiveTemporaries.size() > OldNumLiveTemporaries) - PopCXXTemporary(); - EmitBlock(ContinueBlock); // Emit the increment of the loop counter. -- cgit v1.2.3-70-g09d2