[devel] pkg-config Requires.private - полчища саранчи и враги народа
Alexey Tourbin
at на altlinux.ru
Вс Фев 27 14:38:06 UTC 2011
Некоторые пакеты из freedesktop.org испортили враги народа -
они переместили pkgconfig зависимости из Requires в Requires.private.
По их логике, если программа не линкуется напрямую с дополнительными
библиотеками, то в Requires их указывать не надо. Но в то же время
при компиляции могут включаться хедеры дополнительных библиотек.
Так что сборка пакетов стала ломаться из-за отсутствия нужных хедеров,
и в rpm 4.0.4-alt100.2 пришлось приравнять Requires.private к Requires.
В результате многие пакеты обросли лишними pkgconfig зависимостями на
*-devel пакеты.
Новый план выхода из кризиса (реализован в 4.0.4-alt100.22):
1) Оставлять в зависимостях только Requires, а Requires.private убрать.
2) Продувать хедеры через /usr/bin/cpp и смотреть, какие ещё хедеры
включаются, чтобы появились дополнительные зависимости на *-devel
пакеты с хедерами. Скрипт cpp.req был написан почти три года назад,
но в нём не было необходимости, т.к. pkgconfig.req давал неплохой
результат. Никогда не знаешь, чего придётся доставать из штанин.
Вот примеры того, как изменятся зависимости.
$ compare_packages -i -a -R libXft-devel-2.2.0-alt3.x86_64.rpm
--- /tmp/.private/at/compare_packages.GHMfrhdqbY/1 2011-02-27 17:20:58.018880241 +0300
+++ /tmp/.private/at/compare_packages.GHMfrhdqbY/2 2011-02-27 17:20:58.006881010 +0300
@@ -1,7 +1,8 @@
/usr/lib64/pkgconfig
+fontconfig-devel
libXft = 2.2.0-alt3
-pkgconfig(fontconfig)
-pkgconfig(freetype2)
+libXrender-devel
+libfreetype-devel
pkgconfig(xproto)
-pkgconfig(xrender)
rpmlib(PayloadIsLzma)
+xorg-xproto-devel
$
Здесь зависимости, по сути, не изменились: убрались pkgconfig зависимости
из Requires.private, но добавились сходные зависимости, полученные через
cpp.req. Мы просто отыграли то, что испортили враги народа.
$ compare_packages -i -a -R libcairo-devel-1.10.2-alt2.x86_64.rpm
--- /tmp/.private/at/compare_packages.yWch2sMnSM/1 2011-02-27 17:24:39.507763649 +0300
+++ /tmp/.private/at/compare_packages.yWch2sMnSM/2 2011-02-27 17:24:39.491765038 +0300
@@ -1,14 +1,16 @@
/usr/lib64/pkgconfig
+fontconfig-devel
libGL-devel
+libX11-devel
+libXrender-devel
libcairo = 1:1.10.2-alt2
+libfreetype-devel
+libxcb-devel
pkgconfig(fontconfig) >= 2.2.95
pkgconfig(freetype2) >= 9.7.3
pkgconfig(gl)
-pkgconfig(glib-2.0)
-pkgconfig(gobject-2.0)
pkgconfig(libpng)
pkgconfig(libudev) >= 136
-pkgconfig(pixman-1) >= 0.18.4
pkgconfig(x11)
pkgconfig(xcb) >= 1.1.92
pkgconfig(xcb-render) >= 0.9.92
$
Тут более интересная картина. Зависимость на pkgconfig(pixman-1)
удалилась, а сходной зависимости на libpixman-devel не появилось - т.е.
pixman указан только в Requires.private, а в хедерах нигде не включается.
Т.е. pixman является настоящей private зависимостью, которой и не должно
быть в libcairo-devel. Обращает на себя зависимость pkgconfig(libpng) -
сходной зависимости на libpng-devel не появилось. Это, скорее всего,
означает, что pkgconfig зависимость ошибочно указана в Requires, тогда как
должна быть указана в Requires.private.
В связи с этими изменениями я пересоберу некоторые пакеты.
Подробная информация о списке рассылки Devel