diff options
author | Fariborz Jahanian <fjahanian@apple.com> | 2009-07-21 22:36:06 +0000 |
---|---|---|
committer | Fariborz Jahanian <fjahanian@apple.com> | 2009-07-21 22:36:06 +0000 |
commit | aee31ac31696b9c956987e655dc06adb34f992df (patch) | |
tree | 8a1579aea3b3c59c2031592510cd0b035caa43f1 /clang/lib/Sema/SemaDecl.cpp | |
parent | 83e6f9370d118ab2fb08142a2b0b1f367d6c774f (diff) | |
download | bcm5719-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.cpp | 11 |
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; } |