Quero usar pkg-config
meu Makefile para encontrar o caminho do link para libspa-0.2 .
Observo que pkg-config --libs libspa-0.2
não retorna nada.
Para simplificar, demonstrarei o problema executando pkg-config
diretamente do shell, ou seja, não de dentro do meu Makefile .
$ uname -a
Linux MY_LINUX_PC 5.15.133.1-microsoft-standard-WSL2 #1 SMP Thu Oct 5 21:02:42 UTC 2023 x86_64 x86_64 x86_64 GNU/Linux
$
$ sudo apt-get install -y libspa-0.2-dev
Reading package lists... Done
Building dependency tree... Done
Reading state information... Done
The following package was automatically installed and is no longer required:
libwebrtc-audio-processing1
Use 'sudo apt autoremove' to remove it.
Suggested packages:
pipewire-doc
The following NEW packages will be installed:
libspa-0.2-dev
0 upgraded, 1 newly installed, 0 to remove and 3 not upgraded.
Need to get 0 B/81.7 kB of archives.
After this operation, 625 kB of additional disk space will be used.
Selecting previously unselected package libspa-0.2-dev:amd64.
(Reading database ... 34966 files and directories currently installed.)
Preparing to unpack .../libspa-0.2-dev_0.3.48-1ubuntu3_amd64.deb ...
Unpacking libspa-0.2-dev:amd64 (0.3.48-1ubuntu3) ...
Setting up libspa-0.2-dev:amd64 (0.3.48-1ubuntu3) ...
$
$ pkg-config --libs libspa-0.2
$
Estranhamente, pkg-config
ele se comporta conforme esperado quando solicitado a reportar os cflags de libspa-0.2 :
$ pkg-config --cflags libspa-0.2
-D_REENTRANT -I/usr/include/spa-0.2
$
Este é o conteúdo de libspa-0.2.pc :
$ cat /usr/lib/x86_64-linux-gnu/pkgconfig/libspa-0.2.pc
prefix=/usr
libdir=${prefix}/lib/x86_64-linux-gnu
includedir=${prefix}/include
plugindir=${libdir}/spa-0.2
Name: libspa
Description: Simple Plugin API
Version: 0.2
Cflags: -I${includedir}/spa-0.2 -D_REENTRANT
$
... então eu esperava pkg-config --libs libspa-0.2
retornar algo parecido com /usr/lib/x86_64-linux-gnu
.
Por que pkg-config --libs libspa-0.2
retorna uma string vazia?
Ficaria grato se um respondente experiente pudesse descrever um pouco sobre a relação entre pkg-config
, apt-get
e o conteúdo dos respectivos .pc
arquivos.
Eu gostaria de entender o problema/comportamento observado especificamente em relação a libspa-0.2-dev , mas se houver uma generalização, gostaria de aprender isso também.
Atualização : isso é estranho - parece que pkg-config
está fazendo alguma formatação/remoção (inteligente) de conteúdo para os caminhos de link da biblioteca. Este é o conteúdo do zlib.pc - algo pré-instalado (o que deve descartar minha bagunça):
$ cat /usr/lib/x86_64-linux-gnu/pkgconfig/zlib.pc
prefix=/usr
exec_prefix=${prefix}
libdir=${prefix}/lib/x86_64-linux-gnu
sharedlibdir=${libdir}
includedir=${prefix}/include
Name: zlib
Description: zlib compression library
Version: 1.2.11
Requires:
Libs: -L${libdir} -L${sharedlibdir} -lz
Cflags: -I${includedir}
$
... e isto é o que pkg-config
informa os caminhos de link da biblioteca:
$ pkg-config --libs zlib
-lz
$
...ou seja, parece estar retirando a -L${libdir} -L${sharedlibdir}
peça.
Pelo menos o comportamento é consistente... o que talvez implique que este não é um "problema", mas um comportamento definido pkg-config
. Mas não consigo entender a razão pela qual ele está se comportando dessa maneira: quando e por que ele elimina os caminhos dos links da biblioteca, ou seja, o -L
conteúdo?
libspa-0.2
é um pacote somente de cabeçalhos e não contém nenhuma biblioteca. É por isso que seu.pc
arquivo não especifica umaLibs
entrada.pkg-config
remove argumentos que já são conhecidos pelo compilador. No seu sistema,/usr/lib/x86_64-linux-gnu
é o caminho da biblioteca padrão e o compilador sabe disso, portanto não precisa ser especificado com uma-L
opção. Este comportamento pode ser desabilitado com a--keep-system-libs
opção (pelo menos, com apkgconf
implementação depkgconfig
, que provavelmente é o que seu sistema utiliza):Mas inclui apenas
-L
se uma-l
opção for realmente necessária, por isso não aparece paralibspa-0.2
:(Há um sinalizador equivalente para
CFLAGS
,--keep-system-cflags
.)