<html><head></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; ">Hi Andrew,<div><br><div><div><div>On May 18, 2011, at 12:03 AM, Andrew Fish wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><div>For EFI firmware we use x86_64-pc-win32-darwin, but the default behavior for diagnostics on this triple is to suppress column number printing, and format line numbers to be compatible with Visual Studio. This breaks our Xcode IDE, and command line yank put. Attached is my first take at a patch to fix this. IMHO the default diagnostic output for clang, should be clangs native diagnostic output that matches the documentation. I understand the need to modify the output to match the IDE that is being used, as I'm fixing that reverse problem. It would seem OK to add a flag, like -fno-diagnostic-standard-format, when clang is being used with an incompatible IDE. </div><div><br></div><div><br></div><dt id="opt_fshow-column" style="color: rgb(34, 34, 34); font-family: 'Lucida Grande', 'Lucida Sans Unicode', Arial, Verdana, Helvetica, sans-serif; line-height: 19px; font-size: small; "><b>-f[no-]diagnostics-standard-format</b>: Print diagnostics in standard clang format, or a non standard OS specific format.</dt><dd style="color: rgb(34, 34, 34); font-family: 'Lucida Grande', 'Lucida Sans Unicode', Arial, Verdana, Helvetica, sans-serif; line-height: 19px; font-size: small; ">This option, which defaults to on, controls whether or not Clang uses the default diagnostic output format, or use an OS specific diagnostic format. For example, when this is disabled for the x86_64-pc-win32 triple, Clang will modify diagnostic output something like:<pre> test.c(2): error: unknown type name 'asdkjf' </pre><pre> asdkjf</pre><pre> ^</pre></dd><div>Note: This changes the default behavior today so it would look like this (normal clang):</div><div><br></div><div><div>clang -ccc-host-triple x86_64-pc-win32 ve.c -S </div><div>ve.c:2:1: error: unknown type name 'asdkjf'</div><div>asdkjf </div><div>^</div></div><div><br></div><div>To get the old behavior you need to add the new flag:</div><div><br></div><div><div>clang -ccc-host-triple x86_64-pc-win32 ve.c -S -fno-diagnostics-standard-format</div><div>ve.c(2) : error: unknown type name 'asdkjf'</div><div>asdkjf </div><div>^</div></div><div><br></div><div><br></div><div>If I was doing this from scratch I would probably add a flag per IDE that was not compatible with the clang diagnostics format that would modify the clang diagnostic output to be compatible for that IDE. So something like -fdiagnostics-ide=VisualStudio or -fdiagnostics-vi. </div></div></blockquote><div><br></div><div>I think this is the superior design, with something like -fdiagnostics-format=msvc used to indicate how we should format diagnostics. It'll scale if we end up having to support some other display format for a different IDE or compiler.</div><div><br></div><blockquote type="cite"><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><div>I picked --fno-diagnostic-standard-format to better match what the currently code was doing:</div><div><br></div><div> if (LangOpts && LangOpts->Microsoft) {</div></div></blockquote><div><br></div><div>The current code is really sketchy, since it conflates a language-parsing option with a diagnostic-display option, when these should be disjoint subsystems. </div><br><blockquote type="cite"><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><div>Given I'm a novice at clang, llvm, and C++ I figured changing as little as possible was a good plan. </div></div></blockquote><div><br></div>That's understandable, and your patch looks quite good. The only change I would have requested would be to add "-fdiagnostic-standard-format" as well as "-fno-diagnostic-standard-format", because then the driver can be taught how to take the last flag from the command line, e.g.,</div><div><br></div><div><span class="Apple-tab-span" style="white-space:pre"> </span>clang -fno-diagnostic-standard-format t.c -fdiagnostic-standard-format</div><div><br></div><div>However, I think the best way forward is to implement -fdiagnostics-format=xxx, where "xxx" is either clang (the default) or msvc (Visual Studio-style). If the -fdiagnostics-format=xxx option isn't provided to the driver, the driver will pick based on the target triple, so that non-EFI MSVC targets get "msvc" and other targets get "clang". </div><div><br><span class="Apple-tab-span" style="white-space:pre"> </span>- Doug</div><br></div></div></body></html>