diff options
author | John McCall <rjmccall@apple.com> | 2010-02-06 00:25:16 +0000 |
---|---|---|
committer | John McCall <rjmccall@apple.com> | 2010-02-06 00:25:16 +0000 |
commit | ca972cd1f1e016cc144a47eb34bcca51e59a6fab (patch) | |
tree | ce3c9d2352999d0085cb43ad97714dcb36e1f6c4 | |
parent | 5638c36efd86444d6c752d5ae9789f3cb1bc0ac8 (diff) | |
download | bcm5719-llvm-ca972cd1f1e016cc144a47eb34bcca51e59a6fab.tar.gz bcm5719-llvm-ca972cd1f1e016cc144a47eb34bcca51e59a6fab.zip |
Rearrange some checks to avoid call to isCopyConstructor() and clarify path
taken for non-trivial constructors.
llvm-svn: 95457
-rw-r--r-- | clang/lib/CodeGen/CGClass.cpp | 26 |
1 files changed, 14 insertions, 12 deletions
diff --git a/clang/lib/CodeGen/CGClass.cpp b/clang/lib/CodeGen/CGClass.cpp index c3901a5ae1a..648e37e9acf 100644 --- a/clang/lib/CodeGen/CGClass.cpp +++ b/clang/lib/CodeGen/CGClass.cpp @@ -1227,20 +1227,22 @@ CodeGenFunction::EmitCXXConstructorCall(const CXXConstructorDecl *D, llvm::Value *This, CallExpr::const_arg_iterator ArgBeg, CallExpr::const_arg_iterator ArgEnd) { - if (D->isCopyConstructor()) { - const CXXRecordDecl *ClassDecl = cast<CXXRecordDecl>(D->getDeclContext()); - if (ClassDecl->hasTrivialCopyConstructor()) { - assert(!ClassDecl->hasUserDeclaredCopyConstructor() && - "EmitCXXConstructorCall - user declared copy constructor"); - const Expr *E = (*ArgBeg); - QualType Ty = E->getType(); - llvm::Value *Src = EmitLValue(E).getAddress(); - EmitAggregateCopy(This, Src, Ty); + if (D->isTrivial()) { + if (ArgBeg == ArgEnd) { + // Trivial default constructor, no codegen required. + assert(D->isDefaultConstructor() && + "trivial 0-arg ctor not a default ctor"); return; } - } else if (D->isTrivial()) { - // FIXME: Track down why we're trying to generate calls to the trivial - // default constructor! + + assert(ArgBeg + 1 == ArgEnd && "unexpected argcount for trivial ctor"); + assert(D->isCopyConstructor() && "trivial 1-arg ctor not a copy ctor"); + + const CXXRecordDecl *ClassDecl = cast<CXXRecordDecl>(D->getDeclContext()); + const Expr *E = (*ArgBeg); + QualType Ty = E->getType(); + llvm::Value *Src = EmitLValue(E).getAddress(); + EmitAggregateCopy(This, Src, Ty); return; } |