<div class="gmail_quote">On Tue, May 29, 2012 at 2:08 PM, Joerg Sonnenberger <span dir="ltr"><<a href="mailto:joerg@britannica.bec.de" target="_blank">joerg@britannica.bec.de</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div class="im">On Tue, May 22, 2012 at 03:36:25PM -0700, Richard Smith wrote:<br>
> Hi,<br>
><br>
> Some popular open-source projects have a code layout which looks something<br>
> like this:<br>
><br>
> project/<br>
> libs/<br>
> some_third_party_lib/<br>
> my_own_lib/<br>
> foo/my_code/<br>
> bar/my_code/<br>
><br>
> ... with a single include path pointing at the root of the project. When<br>
> rolling out new warnings to such projects, warnings in the project's own<br>
> code should be fixed, and warnings in third-party headers should typically<br>
> be ignored. However, this is currently hard to achieve.<br>
<br>
</div>Is that really common?</blockquote><div><br></div><div>We've run into it in several contexts, Chrome not the least among them.</div><div><br></div><div>Clearly this is common enough for us to care about it and write the patch, and we're hoping to minimize the impact on the rest of Clang.</div>
<div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"> Projects I'm familar with all have<br>
libs/foo/include that's added to the include path. I think you can get<br>
the same results with an additional include directory containing<br>
symlinks for the 3rd party libraries you don't care about. Which should<br>
be both faster and work for a bunch of other compilers as well.<br></blockquote><div><br></div><div>Just to be clear, we're primarily focused on optimizing the user experience for Clang warnings. Our recommendation is usually to simply disable the warnings from other compilers that are problematic, and this has worked quite well.</div>
<div><br></div><div>Put another way, the codebases in question are compiling cleanly and without warnings today. The goal is to be able to turn on more of Clang's warnings by default, and turn on new warnings easily without having to mop up other libraries' header files.</div>
</div>