<div dir="ltr">Sure, this is <a href="http://llvm.org/pr23071">http://llvm.org/pr23071</a>.<div><br></div><div>Can this be handled locally by this code?</div><div><div>          // If we're in microsoft extensions mode, downgrade this from a hard</div><div>          // error to an extension that defaults to an error.  This allows</div><div>          // disabling it.</div><div>          PP.Diag(Loc, PP.getLangOpts().MicrosoftExt ? diag::ext_pp_bad_paste_ms</div><div>                                                     : diag::err_pp_bad_paste)</div><div>              << Buffer;</div></div><div><br></div><div>Any reason we can't do RHS.clearFlag(Token::LeadingSpace) here in -fms-extensions mode?</div></div><div class="gmail_extra"><br><div class="gmail_quote">On Fri, Apr 10, 2015 at 12:45 PM, Will Wilson <span dir="ltr"><<a href="mailto:will@indefiant.com" target="_blank">will@indefiant.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">Hi Reid,
<div><br></div><div>Attached is a patch to handle a corner case supported by MSVC. I decided to attempt to workaround the behaviour in clang after encountering it in public MS headers for XAudio where clang would fail to generate a valid UUID due to the UUID components being combined with the '-' UUID separators. Clang was attempting to recover but would preserve the leading whitespace from the tokens after each failed paste leading to spaces creeping into the UUID and causing an error in the __declspace(uuid()) parsing.</div><div><br></div><div>Reference: Microsoft DirectX SDK (June 2010)\Include\XAudio2.h(51)</div><div><br></div><div>Test case included and tested against latest trunk.</div><div><br></div><div>Let me know if it looks acceptable!</div><div><br></div><div>Cheers,</div><div>Will.</div></div>
</blockquote></div><br></div>