diff options
author | Anders Carlsson <andersca@mac.com> | 2010-05-02 23:01:10 +0000 |
---|---|---|
committer | Anders Carlsson <andersca@mac.com> | 2010-05-02 23:01:10 +0000 |
commit | 4c638f1217df296ffdb1599dd938568cd38f3df3 (patch) | |
tree | 21c1b1c510a208b2fb883a71c3002a70705de251 /clang/lib | |
parent | bcc066b659c5d2c4c4f8bad79b0ed200db1cdbb0 (diff) | |
download | bcm5719-llvm-4c638f1217df296ffdb1599dd938568cd38f3df3.tar.gz bcm5719-llvm-4c638f1217df296ffdb1599dd938568cd38f3df3.zip |
Pass the construction kind down to EmitCXXConstructorCall.
llvm-svn: 102880
Diffstat (limited to 'clang/lib')
-rw-r--r-- | clang/lib/CodeGen/CGClass.cpp | 8 | ||||
-rw-r--r-- | clang/lib/CodeGen/CGExprCXX.cpp | 6 | ||||
-rw-r--r-- | clang/lib/CodeGen/CodeGenFunction.h | 3 |
3 files changed, 10 insertions, 7 deletions
diff --git a/clang/lib/CodeGen/CGClass.cpp b/clang/lib/CodeGen/CGClass.cpp index 0f1b015966f..27eb1d76431 100644 --- a/clang/lib/CodeGen/CGClass.cpp +++ b/clang/lib/CodeGen/CGClass.cpp @@ -1085,7 +1085,8 @@ CodeGenFunction::EmitCXXAggrConstructorCall(const CXXConstructorDecl *D, { CXXTemporariesCleanupScope Scope(*this); - EmitCXXConstructorCall(D, Ctor_Complete, Address, ArgBeg, ArgEnd); + EmitCXXConstructorCall(D, CXXConstructExpr::CK_Complete, Address, + ArgBeg, ArgEnd); } EmitBlock(ContinueBlock); @@ -1222,10 +1223,13 @@ CodeGenFunction::GenerateCXXAggrDestructorHelper(const CXXDestructorDecl *D, void CodeGenFunction::EmitCXXConstructorCall(const CXXConstructorDecl *D, - CXXCtorType Type, + CXXConstructExpr::ConstructionKind Kind, llvm::Value *This, CallExpr::const_arg_iterator ArgBeg, CallExpr::const_arg_iterator ArgEnd) { + CXXCtorType Type = + (Kind == CXXConstructExpr::CK_Complete) ? Ctor_Complete : Ctor_Base; + if (D->isTrivial()) { if (ArgBeg == ArgEnd) { // Trivial default constructor, no codegen required. diff --git a/clang/lib/CodeGen/CGExprCXX.cpp b/clang/lib/CodeGen/CGExprCXX.cpp index 1f25f2de267..d4e26cf506d 100644 --- a/clang/lib/CodeGen/CGExprCXX.cpp +++ b/clang/lib/CodeGen/CGExprCXX.cpp @@ -323,9 +323,7 @@ CodeGenFunction::EmitCXXConstructExpr(llvm::Value *Dest, } else // Call the constructor. - EmitCXXConstructorCall(CD, - E->isBaseInitialization()? Ctor_Base : Ctor_Complete, - Dest, + EmitCXXConstructorCall(CD, E->getConstructionKind(), Dest, E->arg_begin(), E->arg_end()); } @@ -470,7 +468,7 @@ static void EmitNewInitializer(CodeGenFunction &CGF, const CXXNewExpr *E, QualType AllocType = E->getAllocatedType(); if (CXXConstructorDecl *Ctor = E->getConstructor()) { - CGF.EmitCXXConstructorCall(Ctor, Ctor_Complete, NewPtr, + CGF.EmitCXXConstructorCall(Ctor, CXXConstructExpr::CK_Complete, NewPtr, E->constructor_arg_begin(), E->constructor_arg_end()); diff --git a/clang/lib/CodeGen/CodeGenFunction.h b/clang/lib/CodeGen/CodeGenFunction.h index 5ecc9a20c38..f98cbb43069 100644 --- a/clang/lib/CodeGen/CodeGenFunction.h +++ b/clang/lib/CodeGen/CodeGenFunction.h @@ -815,7 +815,8 @@ public: void EmitDelegateCXXConstructorCall(const CXXConstructorDecl *Ctor, CXXCtorType CtorType, const FunctionArgList &Args); - void EmitCXXConstructorCall(const CXXConstructorDecl *D, CXXCtorType Type, + void EmitCXXConstructorCall(const CXXConstructorDecl *D, + CXXConstructExpr::ConstructionKind ConstructKind, llvm::Value *This, CallExpr::const_arg_iterator ArgBeg, CallExpr::const_arg_iterator ArgEnd); |