diff options
author | Douglas Gregor <dgregor@apple.com> | 2011-02-03 23:41:12 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2011-02-03 23:41:12 +0000 |
commit | 4814fb560322daf009fda6226cffccb10bd44620 (patch) | |
tree | c1ef5ce5c613b5ed518ce0aac98ad300fd511cfe /lib/Basic/DiagnosticIDs.cpp | |
parent | 2100fe952a644134b1dca462f2e6330cf14ef47c (diff) |
If any Fix-Its attached to a diagnostic have invalid source locations
or source locations that refer into a macro instantiation, delete all
of the Fix-Its on that diagnostic.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@124833 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Basic/DiagnosticIDs.cpp')
-rw-r--r-- | lib/Basic/DiagnosticIDs.cpp | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/lib/Basic/DiagnosticIDs.cpp b/lib/Basic/DiagnosticIDs.cpp index 8efeb6897d..8725e7f9c0 100644 --- a/lib/Basic/DiagnosticIDs.cpp +++ b/lib/Basic/DiagnosticIDs.cpp @@ -560,6 +560,19 @@ bool DiagnosticIDs::ProcessDiag(Diagnostic &Diag) const { Diag.SetDelayedDiagnostic(diag::fatal_too_many_errors); } + // If we have any Fix-Its, make sure that all of the Fix-Its point into + // source locations that aren't macro instantiations. If any point into + // macro instantiations, remove all of the Fix-Its. + for (unsigned I = 0, N = Diag.NumFixItHints; I != N; ++I) { + const FixItHint &FixIt = Diag.FixItHints[I]; + if (FixIt.RemoveRange.isInvalid() || + FixIt.RemoveRange.getBegin().isMacroID() || + FixIt.RemoveRange.getEnd().isMacroID()) { + Diag.NumFixItHints = 0; + break; + } + } + // Finally, report it. Diag.Client->HandleDiagnostic((Diagnostic::Level)DiagLevel, Info); if (Diag.Client->IncludeInDiagnosticCounts()) { |