diff options
author | Douglas Gregor <dgregor@apple.com> | 2011-08-17 19:13:00 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2011-08-17 19:13:00 +0000 |
commit | 14208800fa7f57420bb1b412e58b575123684865 (patch) | |
tree | 0c504a74b925847302e844e53e9be54b7de21c33 /clang/lib/Basic/DiagnosticIDs.cpp | |
parent | 217f91fc57cb1067cad5358d74f44d6fc6075a57 (diff) | |
download | bcm5719-llvm-14208800fa7f57420bb1b412e58b575123684865.tar.gz bcm5719-llvm-14208800fa7f57420bb1b412e58b575123684865.zip |
Fix -ferror-limit= to properly emit notes following the last error
messages. Fi from David Blaikie, tests from Nikola Smiljanic!
llvm-svn: 137851
Diffstat (limited to 'clang/lib/Basic/DiagnosticIDs.cpp')
-rw-r--r-- | clang/lib/Basic/DiagnosticIDs.cpp | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/clang/lib/Basic/DiagnosticIDs.cpp b/clang/lib/Basic/DiagnosticIDs.cpp index 907e826a33c..fa397c9ac93 100644 --- a/clang/lib/Basic/DiagnosticIDs.cpp +++ b/clang/lib/Basic/DiagnosticIDs.cpp @@ -733,11 +733,13 @@ bool DiagnosticIDs::ProcessDiag(Diagnostic &Diag) const { ++Diag.NumErrors; } - // If we've emitted a lot of errors, emit a fatal error after it to stop a - // flood of bogus errors. - if (Diag.ErrorLimit && Diag.NumErrors >= Diag.ErrorLimit && - DiagLevel == DiagnosticIDs::Error) + // If we've emitted a lot of errors, emit a fatal error instead of it to + // stop a flood of bogus errors. + if (Diag.ErrorLimit && Diag.NumErrors > Diag.ErrorLimit && + DiagLevel == DiagnosticIDs::Error) { Diag.SetDelayedDiagnostic(diag::fatal_too_many_errors); + return false; + } } // If we have any Fix-Its, make sure that all of the Fix-Its point into |