From: Chris Lattner Date: Sun, 8 Mar 2009 08:11:22 +0000 (+0000) Subject: generalize the "end of line" checking logic to stop at any \0 at the X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=cd1148b6145094ae3cabd02e6ef1d50dcc2d07b0;p=clang generalize the "end of line" checking logic to stop at any \0 at the end of line instead of just the end of buffer. Scratch buffers contain embedded \0's between tokens which are logic line separators. If a normal text buffer contains \0's, it doesn't make a lot of sense to include them in the caret diag output anyway. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@66374 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Frontend/TextDiagnosticPrinter.cpp b/lib/Frontend/TextDiagnosticPrinter.cpp index d3e46ff029..3e6c3ae74b 100644 --- a/lib/Frontend/TextDiagnosticPrinter.cpp +++ b/lib/Frontend/TextDiagnosticPrinter.cpp @@ -145,7 +145,6 @@ void TextDiagnosticPrinter::EmitCaretDiagnostic(SourceLocation Loc, // Get information about the buffer it points into. std::pair BufferInfo = SM.getBufferData(FID); const char *BufStart = BufferInfo.first; - const char *BufEnd = BufferInfo.second; unsigned ColNo = SM.getColumnNumber(FID, FileOffset); @@ -157,8 +156,7 @@ void TextDiagnosticPrinter::EmitCaretDiagnostic(SourceLocation Loc, // Compute the line end. Scan forward from the error position to the end of // the line. const char *LineEnd = TokPtr; - while (LineEnd != BufEnd && - *LineEnd != '\n' && *LineEnd != '\r') + while (*LineEnd != '\n' && *LineEnd != '\r' && *LineEnd != '\0') ++LineEnd; // Copy the line of code into an std::string for ease of manipulation.