<html><head><meta http-equiv="Content-Type" content="text/html charset=utf-8"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><br class=""><div><blockquote type="cite" class=""><div class="">On Oct 20, 2014, at 4:19 PM, Richard Smith <<a href="mailto:richard@metafoo.co.uk" class="">richard@metafoo.co.uk</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><div dir="ltr" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;" class=""><div class="gmail_extra"><div class="gmail_quote">On Mon, Oct 20, 2014 at 3:19 PM, Justin Bogner<span class="Apple-converted-space"> </span><span dir="ltr" class=""><<a href="mailto:mail@justinbogner.com" target="_blank" class="">mail@justinbogner.com</a>></span><span class="Apple-converted-space"> </span>wrote:<br class=""><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-color: rgb(204, 204, 204); border-left-style: solid; padding-left: 1ex;"><span class="">Richard Smith <<a href="mailto:richard@metafoo.co.uk" class="">richard@metafoo.co.uk</a>> writes:<br class="">> On Mon, Oct 20, 2014 at 10:43 AM, Justin Bogner <<a href="mailto:mail@justinbogner.com" class="">mail@justinbogner.com</a>> wrote:<br class="">><br class="">> Currently, when --serialize-diagnostics is passed this only includes the<br class="">> diagnostics from clang -cc1, and driver diagnostics are dropped. This<br class="">> causes issues for tools that use the serialized diagnostics, since<br class="">> stderr is lost and these diagnostics aren't seen at all.<br class="">><br class="">> This patch handles this by merging the diagnostics from the CC1 process<br class="">> and the driver diagnostics into a single file when the driver invokes<br class="">> CC1.<br class="">><br class="">> The idea seems (superficially) reasonable to me. Have you tested this in the<br class="">> case where the driver is given multiple input files to process? Please add a<br class="">> test covering that case.<br class=""><br class=""></span>Multiple input files don't DTRT with serialized diagnostics in the first<br class="">place. I've just filed pr21318 about that.<br class=""><br class="">This doesn't make it worse (the driver diags *and* the last -cc1 will be<br class="">included) and potentially makes that easier to fix, since the driver<br class="">could be taught to merge after each execution. It looks to me that to<br class="">actually do that work involves a fair amount of restructuring of the<br class="">driver though.</blockquote><div class=""><br class=""></div><div class="">OK, fair enough. I'll leave it to someone with more knowledge of --serialize-diagnostics to approve this (or otherwise), though.</div><div class=""><br class=""></div><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-color: rgb(204, 204, 204); border-left-style: solid; padding-left: 1ex;"><span class="">> What about the case where the clang driver runs a tool other than the clang<br class="">> frontend? Your hypothetical process that runs clang with<br class="">> --serialize-diagnostics and drops its stderr will lose diagnostics there too,<br class="">> right?<br class=""><br class=""></span>I'm not sure what you mean here. If the driver runs a tool that creates<br class="">a serialized diagnostics file, this will merge it in. If the tool<br class="">doesn't create a diagnostics file, the diagnostics will only include the<br class="">driver's diags.<br class=""></blockquote></div><br class=""></div><div class="gmail_extra">My point is that a tool that drops stderr on the floor will also not work in lots of other cases. For instance, compiling with split-dwarf also runs objcopy, which might fail, and you'd not get an error message for that because it goes to stderr. Essentially, I was obliquely pointing out that this patch is addressing only a symptom and not the root cause, and whatever process you're fixing with this change may still be broken in the same way in other cases. You can fix the root cause by not discarding stderr =)</div></div></div></blockquote></div><br class=""><div class="">Stderr is not dropped on the floor, but you have to go in Xcode’s build log to see it; the diagnostic navigator only shows a generic ‘command failed’ error.</div><div class="">The diagnostic navigator has native support for clang diagnostics using the serialized diagnostic mechanism; by enhancing that mechanism we can get clang driver issues in the navigator and enhance it automatically.</div><div class=""><br class=""></div><div class="">I’ll comment on the patch soon(ish).</div></body></html>