diff options
| author | John McCall <rjmccall@apple.com> | 2010-07-21 06:29:51 +0000 |
|---|---|---|
| committer | John McCall <rjmccall@apple.com> | 2010-07-21 06:29:51 +0000 |
| commit | 8680f87d99f79a4fa8b948b7c77a8802dd39f273 (patch) | |
| tree | 0773063f3360ac133a69a5cf472e865ca7f558e3 /clang/lib/CodeGen | |
| parent | da650e091f3d2f63a5016422b2b9bc0c1ce39bfe (diff) | |
| download | llvm-8680f87d99f79a4fa8b948b7c77a8802dd39f273.zip llvm-8680f87d99f79a4fa8b948b7c77a8802dd39f273.tar.gz llvm-8680f87d99f79a4fa8b948b7c77a8802dd39f273.tar.bz2 | |
Switch the destructor for a temporary arising from a reference binding over to
using a lazy cleanup.
llvm-svn: 108994
Diffstat (limited to 'clang/lib/CodeGen')
| -rw-r--r-- | clang/lib/CodeGen/CGClass.cpp | 8 | ||||
| -rw-r--r-- | clang/lib/CodeGen/CGExpr.cpp | 12 | ||||
| -rw-r--r-- | clang/lib/CodeGen/CodeGenFunction.h | 6 |
3 files changed, 14 insertions, 12 deletions
diff --git a/clang/lib/CodeGen/CGClass.cpp b/clang/lib/CodeGen/CGClass.cpp index 5fe471e..f6357ec 100644 --- a/clang/lib/CodeGen/CGClass.cpp +++ b/clang/lib/CodeGen/CGClass.cpp @@ -1178,14 +1178,18 @@ namespace { }; } +void CodeGenFunction::PushDestructorCleanup(const CXXDestructorDecl *D, + llvm::Value *Addr) { + EHStack.pushLazyCleanup<CallLocalDtor>(NormalAndEHCleanup, D, Addr); +} + void CodeGenFunction::PushDestructorCleanup(QualType T, llvm::Value *Addr) { CXXRecordDecl *ClassDecl = T->getAsCXXRecordDecl(); if (!ClassDecl) return; if (ClassDecl->hasTrivialDestructor()) return; const CXXDestructorDecl *D = ClassDecl->getDestructor(); - - EHStack.pushLazyCleanup<CallLocalDtor>(NormalAndEHCleanup, D, Addr); + PushDestructorCleanup(D, Addr); } llvm::Value * diff --git a/clang/lib/CodeGen/CGExpr.cpp b/clang/lib/CodeGen/CGExpr.cpp index b4ec0ca..173aadc 100644 --- a/clang/lib/CodeGen/CGExpr.cpp +++ b/clang/lib/CodeGen/CGExpr.cpp @@ -362,16 +362,8 @@ CodeGenFunction::EmitReferenceBindingToExpr(const Expr* E, return RValue::get(Value); } } - - CleanupBlock Cleanup(*this, NormalCleanup); - EmitCXXDestructorCall(ReferenceTemporaryDtor, Dtor_Complete, - /*ForVirtualBase=*/false, ReferenceTemporary); - - if (Exceptions) { - Cleanup.beginEHCleanup(); - EmitCXXDestructorCall(ReferenceTemporaryDtor, Dtor_Complete, - /*ForVirtualBase=*/false, ReferenceTemporary); - } + + PushDestructorCleanup(ReferenceTemporaryDtor, ReferenceTemporary); return RValue::get(Value); } diff --git a/clang/lib/CodeGen/CodeGenFunction.h b/clang/lib/CodeGen/CodeGenFunction.h index 60fd3a3..3823ff3 100644 --- a/clang/lib/CodeGen/CodeGenFunction.h +++ b/clang/lib/CodeGen/CodeGenFunction.h @@ -466,6 +466,12 @@ public: /// non-trivial destructor. void PushDestructorCleanup(QualType T, llvm::Value *Addr); + /// PushDestructorCleanup - Push a cleanup to call the + /// complete-object variant of the given destructor on the object at + /// the given address. + void PushDestructorCleanup(const CXXDestructorDecl *Dtor, + llvm::Value *Addr); + /// PopCleanupBlock - Will pop the cleanup entry on the stack and /// process all branch fixups. void PopCleanupBlock(); |
