svn commit: r362304 - head/x11-toolkits/pango
John Marino
freebsd.contact at marino.st
Mon Jul 21 10:56:03 UTC 2014
On 7/21/2014 12:12, Tijl Coosemans wrote:
> On Mon, 21 Jul 2014 07:58:18 +0200 John Marino wrote:
>> On 7/21/2014 01:33, Tijl Coosemans wrote:
>>>> The is not the only port that sets the explicit-depends configure option
>>>> either.
>>>
>>> Yes I know. It must all be removed. The worst case is the gtk20 port
>>> which forces everything that uses gtk20 to link with many Xorg libraries
>>> for no reason.
>>
>> For no reason?
>> Pango contains symbols from each of those libraries. If you link pango
>> without linking the xorg library, you're going to get a reference error
>> if the linker requires explicit linking.
>
> Pango uses Xorg symbols, so pango must link with Xorg libraries.
> Executable X uses Pango symbols, so X must link with Pango libraries.
> Executable X does not use Xorg symbols and does not use libm symbols
> so it should not be forced to link with Xorg libraries and libm just
> because it links with pango libraries.
>
>> For a linker not requiring explicit linking, it just searches each
>> shared library listed in the dynamic symbols section until it finds the
>> symbol it's looking for.
>
> Yes, if executable X did use libm symbols then implicit linking would
> find libm via the pango libraries. Explicit linking requires that you
> add -lm to the linker command line.
>
> FreeBSD 10 and up use explicit linking.
>
>>>> What is the concern here?
>>>
>>> The concern is overlinking. You are forcing everything that uses pango
>>> to link with libm just to fix a few ports that require libm but forget
>>> to link with it explicitly. You are also forcing everything that uses
>>> pangocairo to link with libfreetype and libfontconfig now.
>>
>> It's not the port that requires libm,
>
> Then why are you linking it with libm?
>
>> it's libpango that references
>> libm.
>
> Correct and therefore libpango must link with libm. It doesn't mean
> that everything that links with libpango must also link with libm.
Everything that uses a pango function that has a libm symbol must also
link with libm. We don't have the granularity down to the function
level. We know at least one function needs to link with libm (probably
more but we can assume at least one)
> root at draco:/usr/local/lib # readelf -a libpango-1.0.so | grep ceil
> 00000024ec78 000800000007 R_X86_64_JUMP_SLO 0000000000000000 ceil + 0
> 8: 0000000000000000 305 FUNC GLOBAL DEFAULT UND ceil at FBSD_1.0 (3)
And there's one now^
>
>> As such, it's pango's responsibility to link libm through the pc
>> file.
>
> No, the .pc file is what other ports use to figure out how to link
> with libpango, through the output of "pkgconf --libs pango". You
> have now added -lm to that output forcing all ports that use libpango
> to link with libm even if they don't contain any libm symbols.
As we don't have granularity down to function level, the pc files has to
assume the port might reference a function that references a libm
symbol. It's certainly wrong to assume it won't.
If the port contained a libm symbol then it would need to have -lm
LDFLAG on it's own and not rely on it to come from an unrelated library
(in this case pango). The -lm flag is for pango, not the individual port.
John
More information about the svn-ports-head
mailing list