qmake configured correctly for multiarch library directories?
Stephen M. Webb
stephen at ubuntu.com
Fri May 18 01:34:57 UTC 2012
-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1
On 05/17/2012 04:09 PM, Josh Stratton wrote:
>>> Like I said, the majority of my libraries are still in /usr/lib and now qmake doesn't link against them by
>>> default. Is this a bug? Is this just an accepted consequence of multiarch? Or is there something I need to
>>> configure that wasn't handled properly in my upgrade?
>>
>> Well, qmake only generates makefiles. GCC has /usr/lib hardcoded in its library resolver search path and is
>> always used implicitly, so that should not be a problem. If qmake is not using its linker symbol ($(GXX) or
>> $(LD)) to generate library search paths if it needs them explicitly, it is certainly a major bug in qmake and
>> should have been noticed long ago. The multi-arch paths are in addition to the default paths, not instead of.
>
> I'm not very familiar with how that works. I know when I run cmake it will add the -L/usr/lib and
> -L/usr/lib/i386-linux-gnu to the makefiles, so is it just being redundant? On another machine I tried a quick test
> of adding a file to the LIBS path and it worked without -L/usr/lib being set explicitly.
To see where GCC looks for libraries by default, run 'gcc -print-search-dirs | grep libraries'. In the absence of
special options, using the -L switch will augment the library search path. Adding the standard paths to the command
line is redundant.
>> How do you know the /usr/lib libraries are not being linked against? What is the symptom, other than not
>> appearing explicitly on the command line?
>
> The actual problem I experienced after upgrading was the missing library assimp, which was still sitting in my
> /usr/lib directory. Since the library file was still there and didn't see /usr/lib explicitly included, I figured
> that was the problem. I'm having similar issues with including aqsis, so it seemed dubious that a handful of
> packages were broken and more likely that it was some issue with qmake specific to my machine.
It's possible the library in /usr/lib is the wrong architecture, which would cause GCC to ignore it. You can use the
'file' utility to see whether a file in /usr/lib was built for i386 (ELF 32-bit LSB shared object, Intel 80386) or
x86_64 (ELF 64-bit LSB shared object, x86-64). You can also force -L or -l flags explicitly when running 'make' after
qmake by setting the LDFLAGS environment variable, if you want to experiment.
- --
Stephen M. Webb <stephen at ubuntu.com>
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.4.11 (GNU/Linux)
Comment: Using GnuPG with Mozilla - http://enigmail.mozdev.org/
iEYEARECAAYFAk+1p0AACgkQTLRKqWcl7vP5cQCfZziZvr35fM12zzNFBP3Gs7/0
HZsAn0rcc0cuxJv7SWZ2wxib0Jw0VLZP
=40pI
-----END PGP SIGNATURE-----
More information about the ubuntu-devel
mailing list