pkg-configはいつ/なぜライブラリリンクパスを返さないのですか?

pkg-configはいつ/なぜライブラリリンクパスを返さないのですか?

私がpkg-config欲しいファイルの生成リンクパスを探すlibspa-0.2

私はpkg-config --libs libspa-0.2何も返されなかったことを観察しました。

pkg-config簡単にするために、シェルで直接実行して問題を説明します。ファイルの生成

$ 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これはデフォルトのライブラリパスであり、コンパイラはそれを知っているため、optionsを使用してそれを指定する必要はありません-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。)

関連情報