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/CodeGen | |
| 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/CodeGen')
| -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();  | 

