[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