<div class="gmail_extra"><br><br><div class="gmail_quote">On Fri, Apr 27, 2012 at 2:17 AM, Seth Cantrell <span dir="ltr"><<a href="mailto:seth.cantrell@gmail.com" target="_blank">seth.cantrell@gmail.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Okay, thanks. Without understanding exactly how the scratch buffer is used, it seems to me like the right solution is to make the scratch buffer or the source manager understand where the actual used portion of the buffer ends. I'll take a look and see if I can make that work or think of anything else.<br>
<br>
I'm not sure I understand your comment about embedded newlines. A new line character constitutes the end of a line, and so can never be embedded inside a line. And emitSnippetAndCaret takes a SourceLocation and outputs in a diagnostic with just the line containing that source location.<br>
<div class="HOEnZb"><div class="h5"><br>
<br></div></div></blockquote><div>Hi Seth,<br><br>I believe Nico is referring to something like: printf("%s", "Hello Seth\n");<br><br>This statement has a newline character embedded, which should be rendered as '\n' and not cause a newline character to be printed.<br>
<br>-- Matthieu<br> </div><blockquote class="gmail_quote" style="margin:0pt 0pt 0pt 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div class="HOEnZb"><div class="h5">
On Apr 26, 2012, at 5:37 PM, Nico Weber wrote:<br>
<br>
> Hi Seth,<br>
><br>
> On Tue, Apr 17, 2012 at 7:44 PM, Seth Cantrell <<a href="mailto:seth.cantrell@gmail.com">seth.cantrell@gmail.com</a>> wrote:<br>
>> Author: socantre<br>
>> Date: Tue Apr 17 21:44:48 2012<br>
>> New Revision: 154981<br>
>><br>
>> URL: <a href="http://llvm.org/viewvc/llvm-project?rev=154981&view=rev" target="_blank">http://llvm.org/viewvc/llvm-project?rev=154981&view=rev</a><br>
>> Log:<br>
>> fix display of source lines with null characters<br>
>><br>
>> Added:<br>
>> cfe/trunk/test/Misc/wnull-character.cpp<br>
>> Modified:<br>
>> cfe/trunk/lib/Frontend/TextDiagnostic.cpp<br>
>><br>
>> Modified: cfe/trunk/lib/Frontend/TextDiagnostic.cpp<br>
>> URL: <a href="http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Frontend/TextDiagnostic.cpp?rev=154981&r1=154980&r2=154981&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Frontend/TextDiagnostic.cpp?rev=154981&r1=154980&r2=154981&view=diff</a><br>
>> ==============================================================================<br>
>> --- cfe/trunk/lib/Frontend/TextDiagnostic.cpp (original)<br>
>> +++ cfe/trunk/lib/Frontend/TextDiagnostic.cpp Tue Apr 17 21:44:48 2012<br>
>> @@ -839,10 +839,13 @@<br>
>><br>
>> // Get information about the buffer it points into.<br>
>> bool Invalid = false;<br>
>> - const char *BufStart = SM.getBufferData(FID, &Invalid).data();<br>
>> + StringRef BufData = SM.getBufferData(FID, &Invalid);<br>
>> if (Invalid)<br>
>> return;<br>
>><br>
>> + const char *BufStart = BufData.data();<br>
>> + const char *BufEnd = BufStart + BufData.size();<br>
>> +<br>
>> unsigned LineNo = SM.getLineNumber(FID, FileOffset);<br>
>> unsigned ColNo = SM.getColumnNumber(FID, FileOffset);<br>
>> unsigned CaretEndColNo<br>
>> @@ -856,7 +859,7 @@<br>
>> // Compute the line end. Scan forward from the error position to the end of<br>
>> // the line.<br>
>> const char *LineEnd = TokPtr;<br>
>> - while (*LineEnd != '\n' && *LineEnd != '\r' && *LineEnd != '\0')<br>
>> + while (*LineEnd != '\n' && *LineEnd != '\r' && LineEnd!=BufEnd)<br>
><br>
> this caused PR12674. I can't think of a good fix, so I'll revert this,<br>
> with a test that shows what went wrong. Note that even with this CL,<br>
> strings with embedded newline characters weren't printed correctly.<br>
><br>
> Nico<br>
><br>
>> ++LineEnd;<br>
>><br>
>> // FIXME: This shouldn't be necessary, but the CaretEndColNo can extend past<br>
>><br>
>> Added: cfe/trunk/test/Misc/wnull-character.cpp<br>
>> URL: <a href="http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Misc/wnull-character.cpp?rev=154981&view=auto" target="_blank">http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Misc/wnull-character.cpp?rev=154981&view=auto</a><br>
>> ==============================================================================<br>
>> Binary files cfe/trunk/test/Misc/wnull-character.cpp (added) and cfe/trunk/test/Misc/wnull-character.cpp Tue Apr 17 21:44:48 2012 differ<br>
>><br>
>><br>
>> _______________________________________________<br>
>> cfe-commits mailing list<br>
>> <a href="mailto:cfe-commits@cs.uiuc.edu">cfe-commits@cs.uiuc.edu</a><br>
>> <a href="http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits</a><br>
<br>
<br>
_______________________________________________<br>
cfe-commits mailing list<br>
<a href="mailto:cfe-commits@cs.uiuc.edu">cfe-commits@cs.uiuc.edu</a><br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits</a><br>
</div></div></blockquote></div><br></div>