
Я работаю на машине 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