diff options
Diffstat (limited to 'lib/Sema/JumpDiagnostics.cpp')
| -rw-r--r-- | lib/Sema/JumpDiagnostics.cpp | 22 | 
1 files changed, 18 insertions, 4 deletions
| diff --git a/lib/Sema/JumpDiagnostics.cpp b/lib/Sema/JumpDiagnostics.cpp index 255845282dfa..fd75c02bb1ed 100644 --- a/lib/Sema/JumpDiagnostics.cpp +++ b/lib/Sema/JumpDiagnostics.cpp @@ -84,6 +84,7 @@ private:    void CheckJump(Stmt *From, Stmt *To, SourceLocation DiagLoc,                   unsigned JumpDiag, unsigned JumpDiagWarning,                   unsigned JumpDiagCXX98Compat); +  void CheckGotoStmt(GotoStmt *GS);    unsigned GetDeepestCommonScope(unsigned A, unsigned B);  }; @@ -489,10 +490,14 @@ void JumpScopeChecker::VerifyJumps() {      // With a goto,      if (GotoStmt *GS = dyn_cast<GotoStmt>(Jump)) { -      CheckJump(GS, GS->getLabel()->getStmt(), GS->getGotoLoc(), -                diag::err_goto_into_protected_scope, -                diag::ext_goto_into_protected_scope, -                diag::warn_cxx98_compat_goto_into_protected_scope); +      // The label may not have a statement if it's coming from inline MS ASM. +      if (GS->getLabel()->getStmt()) { +        CheckJump(GS, GS->getLabel()->getStmt(), GS->getGotoLoc(), +                  diag::err_goto_into_protected_scope, +                  diag::ext_goto_into_protected_scope, +                  diag::warn_cxx98_compat_goto_into_protected_scope); +      } +      CheckGotoStmt(GS);        continue;      } @@ -789,6 +794,15 @@ void JumpScopeChecker::CheckJump(Stmt *From, Stmt *To, SourceLocation DiagLoc,    }  } +void JumpScopeChecker::CheckGotoStmt(GotoStmt *GS) { +  if (GS->getLabel()->isMSAsmLabel()) { +    S.Diag(GS->getGotoLoc(), diag::err_goto_ms_asm_label) +        << GS->getLabel()->getIdentifier(); +    S.Diag(GS->getLabel()->getLocation(), diag::note_goto_ms_asm_label) +        << GS->getLabel()->getIdentifier(); +  } +} +  void Sema::DiagnoseInvalidJumps(Stmt *Body) {    (void)JumpScopeChecker(Body, *this);  } | 
