diff options
| author | Fariborz Jahanian <fjahanian@apple.com> | 2009-08-03 20:20:07 +0000 |
|---|---|---|
| committer | Fariborz Jahanian <fjahanian@apple.com> | 2009-08-03 20:20:07 +0000 |
| commit | 18c062361d6322e2fcfb2c234c527083264b8c5f (patch) | |
| tree | af7a4cdbdffae4e7a5290676c1692dc41cfdb55a /clang/lib | |
| parent | 49bfce4227b7b7f5806f68cdef8d969d15a203a5 (diff) | |
| download | bcm5719-llvm-18c062361d6322e2fcfb2c234c527083264b8c5f.tar.gz bcm5719-llvm-18c062361d6322e2fcfb2c234c527083264b8c5f.zip | |
ir-gen for destructor calls.
llvm-svn: 77991
Diffstat (limited to 'clang/lib')
| -rw-r--r-- | clang/lib/CodeGen/CGDecl.cpp | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/clang/lib/CodeGen/CGDecl.cpp b/clang/lib/CodeGen/CGDecl.cpp index 9fd571b8164..347a0af6968 100644 --- a/clang/lib/CodeGen/CGDecl.cpp +++ b/clang/lib/CodeGen/CGDecl.cpp @@ -432,6 +432,18 @@ void CodeGenFunction::EmitLocalBlockVarDecl(const VarDecl &D) { } } + // Handle CXX destruction of variables. + // FIXME - destruction of arrays NYI. + if (const RecordType *RT = Ty->getAs<RecordType>()) + if (CXXRecordDecl *ClassDecl = dyn_cast<CXXRecordDecl>(RT->getDecl())) { + if (!ClassDecl->hasTrivialDestructor()) { + const CXXDestructorDecl *D = ClassDecl->getDestructor(getContext()); + assert(D && "EmitLocalBlockVarDecl - destructor is nul"); + CleanupScope scope(*this); + EmitCXXDestructorCall(D, Dtor_Complete, DeclPtr); + } + } + // Handle the cleanup attribute if (const CleanupAttr *CA = D.getAttr<CleanupAttr>()) { const FunctionDecl *FD = CA->getFunctionDecl(); |

