RHEL 6.8でpkg-config --cflags opensslが何も返さないのはなぜですか?

RHEL 6.8でpkg-config --cflags opensslが何も返さないのはなぜですか?

私はRHEL 6.8 Linuxシステムで動作しています。ソースtarballs/git-repos/whateferからさまざまなパッケージをビルドしようとしています。いいえシステム構成を変更します(ルートまたはsudoから)。

RHEL 6.8 システムで実行中です。

bash-4.1$ cat /etc/issue
Red Hat Enterprise Linux Workstation release 6.8 (Santiago)
Kernel \r on an \m

openssl-develインストール済み:

bash-4.1$ rpm -q -a | grep openssl
openssl-1.0.1e-48.el6.i686
openssl098e-0.9.8e-20.el6_7.1.x86_64
openssl098e-0.9.8e-20.el6_7.1.i686
openssl-devel-1.0.1e-48.el6.i686
openssl-1.0.1e-48.el6.x86_64
openssl-devel-1.0.1e-48.el6.x86_64

したがって、pkg-configを使用してソースからパッケージをビルドするときに必要なCFLAGS値を見つけることができるように、このコマンドはいくつかの出力を返したいと思います。

bash-4.1$ pkg-config --cflags openssl

ただし、改行文字のみを返します。なぜ?

追加のデバッグ:

使用中のファイルを表示します。

bash-4.1$ pkg-config --debug --list-all 2>&1 | grep 'Will find package.*openssl'
Will find package 'openssl' in file '/usr/lib64/pkgconfig/openssl.pc'

読み取るファイルを表示します。

bash-4.1$ cat /usr/lib64/pkgconfig/openssl.pc
prefix=/usr
exec_prefix=${prefix}
libdir=${exec_prefix}/lib64
includedir=${prefix}/include

Name: OpenSSL
Description: Secure Sockets Layer and cryptography libraries and tools
Version: 1.0.1e
Requires: 
Libs: -L${libdir} -lssl -lcrypto
Libs.private: -Wl,-z,relro -ldl -lz -L/usr/lib -lgssapi_krb5 -lkrb5 -lcom_err -lk5crypto -lresolv
Cflags: -I${includedir} -I/usr/include

grep 範囲拡張:

bash-4.1$ pkg-config --debug --list-all 2>&1 | grep 'openssl'
File 'openssl.pc' appears to be a .pc file
Will find package 'openssl' in file '/usr/lib64/pkgconfig/openssl.pc'
Looking for package 'openssl'
Looking for package 'openssl-uninstalled'
Reading 'openssl' from file '/usr/lib64/pkgconfig/openssl.pc'
Parsing package file '/usr/lib64/pkgconfig/openssl.pc'
Unknown keyword 'Libs.private' in '/usr/lib64/pkgconfig/openssl.pc'
Removing -I/usr/include from cflags for openssl
Removing -I/usr/include from cflags for openssl
Removing -L /usr/lib64 from libs for openssl
Adding 'openssl' to list of known packages, returning as package 'openssl'
openssl                     OpenSSL - Secure Sockets Layer and cryptography libraries and tools
bash-4.1$ 

それではそこで何をしますかRemoving -I/usr/include from cflags for openssl

また、Cflags変数が定義されます。これはバグですか?そうすべきですかcflags

pkg-configまた、同じ動作を提供する独自のバージョン0.29.2をダウンロードして構築しました。したがって、ファイルにバグがあるようですが、openssl.pcわかりません。

それにもかかわらず、さまざまなパッケージスクリプトを呼び出す前にハードコードされた値をエクスポートすることに加えて、他のCFLAGS解決策はありますか?LDFLAGS./configure

答え1

これはpkg-config重複したフラグを削除し、/usr/includeなどの「デフォルト」パスもスキップするようです。

望むより、

$ printf "Name: whatever\nVersion: 1\nDescription: bla\nCflags: -I/usr/include" > /tmp/x.pc
$ pkg-config --cflags  /tmp/x.pc

$ printf "Name: whatever\nVersion: 1\nDescription: bla\nCflags: -I/usr/includeX" > /tmp/y.pc
$ pkg-config --cflags  /tmp/y.pc
-I/usr/includeX

これらのデフォルトディレクトリはpkg-configのビルド時に設定されます。ソースのREADME.mdを参照してください。

./configure \
     --prefix=/opt/pkgconf \
     --with-system-libdir=/lib:/usr/lib \
     --with-system-includedir=/usr/include

環境変数を使用すると、実行時にこの動作を無効にできます。

$ PKG_CONFIG_ALLOW_SYSTEM_CFLAGS=1 pkg-config --cflags  /tmp/x.pc
-I/usr/include

または、組み込みのデフォルト値をオーバーライドします。

$ PKG_CONFIG_SYSTEM_INCLUDE_PATH="/whatever" pkg-config --cflags  /tmp/x.pc
-I/usr/include

最近のpkg-configにはコマンドラインオプションも--keep-system-cflagsあります--keep-system-libs

関連情報