Date: Tue, 11 Oct 2011 15:51:46 +0200 From: Dimitry Andric <dim@FreeBSD.org> To: Larry Rosenman <ler@lerctr.org> Cc: =?ISO-8859-1?Q?Ren=E9_Ladan?= <rene@freebsd.org>, freebsd-current@FreeBSD.ORG Subject: Re: System headers with clang? Message-ID: <4E9449F2.2000801@FreeBSD.org> In-Reply-To: <alpine.BSF.2.00.1110110830200.21480@lrosenman.dyndns.org> References: <alpine.BSF.2.00.1110091229550.43656@lrosenman.dyndns.org> <4E942FF1.9000805@FreeBSD.org> <alpine.BSF.2.00.1110110830200.21480@lrosenman.dyndns.org>
next in thread | previous in thread | raw e-mail | index | archive | help
On 2011-10-11 15:31, Larry Rosenman wrote: > On Tue, 11 Oct 2011, Dimitry Andric wrote: ... >> I've attached a fix for the lsof port, which also makes it build on >> 10.0-CURRENT (this was easy to fix here, as lsof uses its own >> hand-rolled configuration script). Let me know if it works for you. >> > Unless the headers are fixed, Vic Abell (lsof Author) will NOT support it. > > We need to get clang/system headers to allow warning free compilation > just like GCC does. The system headers compile without warning, if you use them as intended (e.g. from the kernel), which lsof obviously doesn't do. There is no easy workaround here, except by modifying lsof. For example, the warning about KASSERT is because lsof's headers don't include the required headers for this macro. And gcc is apparently not smart enough to generate warnings for this. :) In any case, isn't lsof's dlsof.h header full of special cases already? What does it matter to add another one? Besides, even if you fix it in the system headers now, at compile time you cannot be sure if the user has the correct version of them installed anyway, so you would still have to work around the problem.
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?4E9449F2.2000801>