From 30d0cfda354ec7f271ff3fa006db02d10a9e9610 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Mon, 1 Mar 2010 20:59:53 +0000 Subject: Implement jump checking for initialized c++ variables, implementing a fixme and PR6451. Only perform jump checking if the containing function has no errors, and add the infrastructure needed to do this. On the testcase in the PR, we produce: t.cc:6:3: error: illegal goto into protected scope goto later; ^ t.cc:7:5: note: jump bypasses variable initialization X x; ^ llvm-svn: 97497 --- clang/lib/Sema/SemaExpr.cpp | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) (limited to 'clang/lib/Sema/SemaExpr.cpp') diff --git a/clang/lib/Sema/SemaExpr.cpp b/clang/lib/Sema/SemaExpr.cpp index 0d1614abe96..966cbc72a25 100644 --- a/clang/lib/Sema/SemaExpr.cpp +++ b/clang/lib/Sema/SemaExpr.cpp @@ -6734,8 +6734,10 @@ void Sema::ActOnBlockStart(SourceLocation CaretLoc, Scope *BlockScope) { BSI->hasBlockDeclRefExprs = false; BSI->hasPrototype = false; BSI->SavedFunctionNeedsScopeChecking = CurFunctionNeedsScopeChecking; + BSI->SavedNumErrorsAtStartOfFunction = NumErrorsAtStartOfFunction; CurFunctionNeedsScopeChecking = false; - + NumErrorsAtStartOfFunction = getDiagnostics().getNumErrors(); + BSI->TheDecl = BlockDecl::Create(Context, CurContext, CaretLoc); CurContext->addDecl(BSI->TheDecl); PushDeclContext(BlockScope, BSI->TheDecl); @@ -6849,6 +6851,7 @@ void Sema::ActOnBlockError(SourceLocation CaretLoc, Scope *CurScope) { llvm::OwningPtr CC(CurBlock); CurFunctionNeedsScopeChecking = CurBlock->SavedFunctionNeedsScopeChecking; + NumErrorsAtStartOfFunction = CurBlock->SavedNumErrorsAtStartOfFunction; // Pop off CurBlock, handle nested blocks. PopDeclContext(); @@ -6895,9 +6898,12 @@ Sema::OwningExprResult Sema::ActOnBlockStmtExpr(SourceLocation CaretLoc, BlockTy = Context.getBlockPointerType(BlockTy); // If needed, diagnose invalid gotos and switches in the block. - if (CurFunctionNeedsScopeChecking) + if (CurFunctionNeedsScopeChecking && + NumErrorsAtStartOfFunction == getDiagnostics().getNumErrors()) DiagnoseInvalidJumps(static_cast(body.get())); + CurFunctionNeedsScopeChecking = BSI->SavedFunctionNeedsScopeChecking; + NumErrorsAtStartOfFunction = BSI->SavedNumErrorsAtStartOfFunction; BSI->TheDecl->setBody(body.takeAs()); -- cgit v1.2.3