Почему pkg-config --cflags openssl ничего не возвращает в RHEL 6.8?

Почему pkg-config --cflags openssl ничего не возвращает в RHEL 6.8?

Я работаю на машине RHEL 6.8 Linux. Я пытаюсь собрать различные пакеты из исходных tarballs/git-repos/whateferбезизменение конфигурации системы (под учетной записью root или 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

Связанный контент