diff options
Diffstat (limited to 'clang/lib')
| -rw-r--r-- | clang/lib/Basic/DiagnosticIDs.cpp | 21 | 
1 files changed, 11 insertions, 10 deletions
| diff --git a/clang/lib/Basic/DiagnosticIDs.cpp b/clang/lib/Basic/DiagnosticIDs.cpp index 282e75e4ca3..1c68375f3cd 100644 --- a/clang/lib/Basic/DiagnosticIDs.cpp +++ b/clang/lib/Basic/DiagnosticIDs.cpp @@ -606,9 +606,6 @@ StringRef DiagnosticIDs::getNearestOption(diag::Flavor Flavor,  bool DiagnosticIDs::ProcessDiag(DiagnosticsEngine &Diag) const {    Diagnostic Info(&Diag); -  if (Diag.SuppressAllDiagnostics) -    return false; -    assert(Diag.getClient() && "DiagnosticClient not set!");    // Figure out the diagnostic level of this message. @@ -616,6 +613,17 @@ bool DiagnosticIDs::ProcessDiag(DiagnosticsEngine &Diag) const {    DiagnosticIDs::Level DiagLevel      = getDiagnosticLevel(DiagID, Info.getLocation(), Diag); +  // Update counts for DiagnosticErrorTrap even if a fatal error occurred +  // or diagnostics are suppressed. +  if (DiagLevel >= DiagnosticIDs::Error) { +    ++Diag.TrapNumErrorsOccurred; +    if (isUnrecoverable(DiagID)) +      ++Diag.TrapNumUnrecoverableErrorsOccurred; +  } + +  if (Diag.SuppressAllDiagnostics) +    return false; +    if (DiagLevel != DiagnosticIDs::Note) {      // Record that a fatal error occurred only when we see a second      // non-note diagnostic. This allows notes to be attached to the @@ -627,13 +635,6 @@ bool DiagnosticIDs::ProcessDiag(DiagnosticsEngine &Diag) const {      Diag.LastDiagLevel = DiagLevel;    } -  // Update counts for DiagnosticErrorTrap even if a fatal error occurred. -  if (DiagLevel >= DiagnosticIDs::Error) { -    ++Diag.TrapNumErrorsOccurred; -    if (isUnrecoverable(DiagID)) -      ++Diag.TrapNumUnrecoverableErrorsOccurred; -  } -    // If a fatal error has already been emitted, silence all subsequent    // diagnostics.    if (Diag.FatalErrorOccurred) { | 

