diff options
| author | Anders Carlsson <andersca@mac.com> | 2009-05-31 00:34:10 +0000 |
|---|---|---|
| committer | Anders Carlsson <andersca@mac.com> | 2009-05-31 00:34:10 +0000 |
| commit | 8eb93e72f7402ec7eb5787f7a91123eac4d06466 (patch) | |
| tree | fcd64c8757c6af68349da62cf3928adc7000b996 /clang/lib/CodeGen/CGCXX.cpp | |
| parent | f3f91cee43b3c7cce74a028c1af4783a7cb6fdc4 (diff) | |
| download | bcm5719-llvm-8eb93e72f7402ec7eb5787f7a91123eac4d06466.tar.gz bcm5719-llvm-8eb93e72f7402ec7eb5787f7a91123eac4d06466.zip | |
Emit destructors correctly for temporaries.
llvm-svn: 72655
Diffstat (limited to 'clang/lib/CodeGen/CGCXX.cpp')
| -rw-r--r-- | clang/lib/CodeGen/CGCXX.cpp | 28 |
1 files changed, 27 insertions, 1 deletions
diff --git a/clang/lib/CodeGen/CGCXX.cpp b/clang/lib/CodeGen/CGCXX.cpp index 4b4ed12abb2..3186ccde666 100644 --- a/clang/lib/CodeGen/CGCXX.cpp +++ b/clang/lib/CodeGen/CGCXX.cpp @@ -189,14 +189,40 @@ CodeGenFunction::EmitCXXConstructExpr(llvm::Value *Dest, E->arg_begin(), E->arg_end()); } +void CodeGenFunction::PushCXXTemporary(const CXXTemporary *Temporary, + llvm::Value *Ptr) { + LiveTemporaries.push_back(Temporary); + + // Make a cleanup scope and emit the destructor. + { + CleanupScope Scope(*this); + + EmitCXXDestructorCall(Temporary->getDestructor(), Dtor_Complete, Ptr); + } +} + RValue CodeGenFunction::EmitCXXExprWithTemporaries(const CXXExprWithTemporaries *E, llvm::Value *AggLoc, bool isAggLocVolatile) { + // Keep track of the current cleanup stack depth. + size_t CleanupStackDepth = CleanupEntries.size(); + + unsigned OldNumLiveTemporaries = LiveTemporaries.size(); + RValue RV = EmitAnyExpr(E->getSubExpr(), AggLoc, isAggLocVolatile); - // FIXME: Handle the temporaries. + // Go through the temporaries backwards. + for (unsigned i = E->getNumTemporaries(); i != 0; --i) { + assert(LiveTemporaries.back() == E->getTemporary(i - 1)); + LiveTemporaries.pop_back(); + } + + assert(OldNumLiveTemporaries == LiveTemporaries.size() && + "Live temporary stack mismatch!"); + EmitCleanupBlocks(CleanupStackDepth); + return RV; } |

