pkg-config
我想在我的Makefile中使用来查找libspa-0.2的链接路径。
我观察到pkg-config --libs libspa-0.2
没有返回任何内容。
pkg-config
为简单起见,我将通过直接从 shell运行来演示该问题,即不是从我的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
$
奇怪的是,pkg-config
当要求报告libspa-0.2的 cflags 时,其行为与预期一致:
$ pkg-config --cflags libspa-0.2
-D_REENTRANT -I/usr/include/spa-0.2
$
这是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
$
...所以我期待pkg-config --libs libspa-0.2
返回类似的东西/usr/lib/x86_64-linux-gnu
。
为什么pkg-config --libs libspa-0.2
返回空字符串?
如果知识渊博的回答者能够描述一下pkg-config
、apt-get
和各个.pc
文件的内容之间的关系,我将不胜感激。
我想了解专门针对libspa-0.2-dev 的问题/观察到的行为,但如果有概括,我也想了解这一点。
更新:这很奇怪——看起来pkg-config
正在对库链接路径的内容进行一些(智能)格式化/剥离。这是zlib.pc的内容——预安装的东西(这应该可以排除我的混乱):
$ 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}
$
...这就是pkg-config
其库链接路径的报告:
$ pkg-config --libs zlib
-lz
$
...即它似乎正在剥离该-L${libdir} -L${sharedlibdir}
部分。
至少行为是一致的......这可能意味着这不是一个“问题”,而是pkg-config
. 但我无法弄清楚为什么它会这样做的理由:它何时以及为什么会删除库链接路径,即-L
内容?
libspa-0.2
是一个仅包含标头的包,它不提供任何库。这就是为什么它的.pc
文件没有指定Libs
条目。pkg-config
删除编译器已知的参数。在您的系统上,/usr/lib/x86_64-linux-gnu
是默认库路径,编译器知道它,因此不需要使用选项指定它-L
。可以使用以下选项禁用此行为--keep-system-libs
(至少通过 的实现pkgconf
,pkgconfig
这可能是您的系统使用的):但它仅包含实际需要的
-L
选项-l
,因此不会显示libspa-0.2
:(有一个等效标志
CFLAGS
,--keep-system-cflags
。)