diff options
author | Anders Carlsson <andersca@mac.com> | 2010-03-30 02:57:48 +0000 |
---|---|---|
committer | Anders Carlsson <andersca@mac.com> | 2010-03-30 02:57:48 +0000 |
commit | 46bbf8d352fcd615420c5759a112ccd6e61516ad (patch) | |
tree | 1403f6030729bdce747e1587d1796695d8b1e677 /lib/CodeGen/CGClass.cpp | |
parent | d09020d87a69803b02c68eb6bf0b38e6ca660eda (diff) |
Handle default arguments when calling copy constructors for bases or members when synthesizing a copy constructor. Fixes PR6628.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@99864 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/CGClass.cpp')
-rw-r--r-- | lib/CodeGen/CGClass.cpp | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/lib/CodeGen/CGClass.cpp b/lib/CodeGen/CGClass.cpp index ebefba2411..8d565f6d41 100644 --- a/lib/CodeGen/CGClass.cpp +++ b/lib/CodeGen/CGClass.cpp @@ -549,10 +549,30 @@ void CodeGenFunction::EmitClassMemberwiseCopy( // Push the Src ptr. CallArgs.push_back(std::make_pair(RValue::get(Src), BaseCopyCtor->getParamDecl(0)->getType())); + + unsigned OldNumLiveTemporaries = LiveTemporaries.size(); + + // 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!"); + + QualType ArgType = Param->getType(); + CallArgs.push_back(std::make_pair(EmitCallArg(DefaultArgExpr, ArgType), + ArgType)); + + } + const FunctionProtoType *FPT = BaseCopyCtor->getType()->getAs<FunctionProtoType>(); EmitCall(CGM.getTypes().getFunctionInfo(CallArgs, FPT), Callee, ReturnValueSlot(), CallArgs, BaseCopyCtor); + + // Pop temporaries. + while (LiveTemporaries.size() > OldNumLiveTemporaries) + PopCXXTemporary(); } } |