何时/为什么 pkg-config 不返回库链接路径?

何时/为什么 pkg-config 不返回库链接路径?

我想pkg-config在我的生成文件找到链接路径libspa-0.2

我观察到pkg-config --libs libspa-0.2没有返回任何内容。

为了简单起见,我将通过pkg-config直接从 shell 运行来演示该问题,即不是从我的内部运行生成文件

$ 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的配置:

$ 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对库链接路径的内容进行了一些(智能)格式化/剥离。这是内容兹库文件-- 预安装的东西(这应该可以排除我搞砸的情况):

$ 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内容?

答案1

为什么pkg-config --libs libspa-0.2返回空字符串?

libspa-0.2是一个仅包含标头的包,它不提供任何库。这就是为什么它的.pc文件没有指定Libs条目。

它何时以及为何删除库链接路径(即-L内容)?

pkg-config删除编译器已知的参数。在您的系统上,/usr/lib/x86_64-linux-gnu是默认库路径,编译器知道它,因此不需要使用选项指定它-L。可以使用以下--keep-system-libs选项禁用此行为(至少通过pkgconf的实现pkgconfig,这可能是您的系统使用的):

$ pkg-config --keep-system-libs --libs zlib
-L/usr/lib/x86_64-linux-gnu -lz

但它仅包含实际需要的-L选项-l,因此不会显示libspa-0.2

$ pkg-config --keep-system-libs --libs libspa-0.2

(有一个等效标志CFLAGS, --keep-system-cflags。)

相关内容