summaryrefslogtreecommitdiffstats
path: root/clang/lib/Sema/SemaDecl.cpp
diff options
context:
space:
mode:
authorFariborz Jahanian <fjahanian@apple.com>2009-07-21 22:36:06 +0000
committerFariborz Jahanian <fjahanian@apple.com>2009-07-21 22:36:06 +0000
commitaee31ac31696b9c956987e655dc06adb34f992df (patch)
tree8a1579aea3b3c59c2031592510cd0b035caa43f1 /clang/lib/Sema/SemaDecl.cpp
parent83e6f9370d118ab2fb08142a2b0b1f367d6c774f (diff)
downloadbcm5719-llvm-aee31ac31696b9c956987e655dc06adb34f992df.tar.gz
bcm5719-llvm-aee31ac31696b9c956987e655dc06adb34f992df.zip
Patch to accomodate Doug's comment on default
destruction of base/members for each destructor AST. llvm-svn: 76663
Diffstat (limited to 'clang/lib/Sema/SemaDecl.cpp')
-rw-r--r--clang/lib/Sema/SemaDecl.cpp11
1 files changed, 7 insertions, 4 deletions
diff --git a/clang/lib/Sema/SemaDecl.cpp b/clang/lib/Sema/SemaDecl.cpp
index 989e08ee9da..4674327e6cf 100644
--- a/clang/lib/Sema/SemaDecl.cpp
+++ b/clang/lib/Sema/SemaDecl.cpp
@@ -3282,12 +3282,15 @@ Sema::DeclPtrTy Sema::ActOnFinishFunctionBody(DeclPtrTy D, StmtArg BodyArg,
// Verify that that gotos and switch cases don't jump into scopes illegally.
if (CurFunctionNeedsScopeChecking)
DiagnoseInvalidJumps(Body);
-
- // C++ constructors that have function-try-blocks can't have return statements
- // in the handlers of that block. (C++ [except.handle]p14) Verify this.
+
+ // C++ constructors that have function-try-blocks can't have return
+ // statements in the handlers of that block. (C++ [except.handle]p14)
+ // Verify this.
if (isa<CXXConstructorDecl>(dcl) && isa<CXXTryStmt>(Body))
DiagnoseReturnInConstructorExceptionHandler(cast<CXXTryStmt>(Body));
-
+
+ if (CXXDestructorDecl *Destructor = dyn_cast<CXXDestructorDecl>(dcl))
+ Destructor->computeBaseOrMembersToDestroy(Context);
return D;
}
OpenPOWER on IntegriCloud