diff options
author | Chris Lattner <sabre@nondot.org> | 2010-03-01 20:59:53 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2010-03-01 20:59:53 +0000 |
commit | 6d97e5e4b7abdae710c2548b51f4ed0298e86d80 (patch) | |
tree | 1bfd4ca64b65979839394efe939d3310598c81e9 /lib/Sema/SemaExpr.cpp | |
parent | 632c9d26925f9aa8179607956c83ee348930b6d7 (diff) |
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;
^
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@97497 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/SemaExpr.cpp')
-rw-r--r-- | lib/Sema/SemaExpr.cpp | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/lib/Sema/SemaExpr.cpp b/lib/Sema/SemaExpr.cpp index 0d1614abe9..966cbc72a2 100644 --- a/lib/Sema/SemaExpr.cpp +++ b/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<BlockScopeInfo> 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<CompoundStmt*>(body.get())); + CurFunctionNeedsScopeChecking = BSI->SavedFunctionNeedsScopeChecking; + NumErrorsAtStartOfFunction = BSI->SavedNumErrorsAtStartOfFunction; BSI->TheDecl->setBody(body.takeAs<CompoundStmt>()); |