diff options
author | Anders Carlsson <andersca@mac.com> | 2009-04-17 00:06:03 +0000 |
---|---|---|
committer | Anders Carlsson <andersca@mac.com> | 2009-04-17 00:06:03 +0000 |
commit | b14095aa98c6fedd3625920c4ce834bcaf24d9f7 (patch) | |
tree | ff9e31b69547be398d8ccd80b87c8344ccc9386e /lib/CodeGen/CGCXX.cpp | |
parent | 025452fa0eda63e150cfaeebe64f0a19c96b3a06 (diff) |
Implement basic code generation of constructor calls. We can now compile:
struct S {
S(int, int);
};
void f() {
S s(10, 10);
}
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@69330 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/CGCXX.cpp')
-rw-r--r-- | lib/CodeGen/CGCXX.cpp | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/lib/CodeGen/CGCXX.cpp b/lib/CodeGen/CGCXX.cpp index f76bd122a0..e61cef3498 100644 --- a/lib/CodeGen/CGCXX.cpp +++ b/lib/CodeGen/CGCXX.cpp @@ -145,6 +145,51 @@ void CodeGenModule::EmitCXXConstructor(const CXXConstructorDecl *D, SetLLVMFunctionAttributesForDefinition(D, Fn); } +void +CodeGenFunction::EmitCXXConstructorCall(const CXXConstructorDecl *D, + CXXCtorType Type, + llvm::Value *This, + CallExpr::const_arg_iterator ArgBeg, + CallExpr::const_arg_iterator ArgEnd) { + CallArgList Args; + + // Push the 'this' pointer. + Args.push_back(std::make_pair(RValue::get(This), + D->getThisType(getContext()))); + + EmitCallArgs(Args, D->getType()->getAsFunctionProtoType(), ArgBeg, ArgEnd); + + EmitCall(CGM.getTypes().getFunctionInfo(getContext().VoidTy, Args), + CGM.GetAddrOfCXXConstructor(D, Type), Args, D); +} + +LValue +CodeGenFunction::EmitCXXTemporaryObjectExprLValue( + const CXXTemporaryObjectExpr *E) { + // Allocate the destination. + llvm::Value *Dest = CreateTempAlloca(ConvertType(E->getType()), "tmp"); + + EmitCXXTemporaryObjectExpr(Dest, E); + + return LValue::MakeAddr(Dest, E->getType().getCVRQualifiers(), + getContext().getObjCGCAttrKind(E->getType())); +} + +void +CodeGenFunction::EmitCXXTemporaryObjectExpr(llvm::Value *Dest, + const CXXTemporaryObjectExpr *E) { + assert(Dest && "Must have a destination!"); + + const CXXRecordDecl *RD = + cast<CXXRecordDecl>(E->getType()->getAsRecordType()->getDecl()); + if (RD->hasTrivialConstructor()) + return; + + // Call the constructor. + EmitCXXConstructorCall(E->getConstructor(), Ctor_Complete, Dest, + E->arg_begin(), E->arg_end()); +} + static bool canGenerateCXXConstructor(const CXXConstructorDecl *D, ASTContext &Context) { const CXXRecordDecl *RD = D->getParent(); |