ALT Linux Team development discussions
 help / color / mirror / Atom feed
* [devel] pkg-config Requires.private - полчища саранчи и враги народа
@ 2011-02-27 14:38 Alexey Tourbin
  2011-02-27 16:45 ` Damir Shayhutdinov
  2011-03-02  5:50 ` Yuri N. Sedunov
  0 siblings, 2 replies; 21+ messages in thread
From: Alexey Tourbin @ 2011-02-27 14:38 UTC (permalink / raw)
  To: devel

Некоторые пакеты из 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.

В связи с этими изменениями я пересоберу некоторые пакеты.


^ permalink raw reply	[flat|nested] 21+ messages in thread

end of thread, other threads:[~2011-03-10 13:10 UTC | newest]

Thread overview: 21+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2011-02-27 14:38 [devel] pkg-config Requires.private - полчища саранчи и враги народа Alexey Tourbin
2011-02-27 16:45 ` Damir Shayhutdinov
2011-02-27 17:01   ` Dmitry V. Levin
2011-02-28  9:35     ` Damir Shayhutdinov
2011-02-28 12:30       ` Dmitry V. Levin
2011-03-08 16:47         ` [devel] cpp.req Dmitry V. Levin
2011-03-08 22:57           ` Alexey Tourbin
2011-03-09 11:42           ` Sergey V Turchin
2011-03-09 12:46             ` Dmitry V. Levin
2011-03-09 13:13               ` Sergey V Turchin
2011-03-09 13:16                 ` Dmitry V. Levin
2011-03-10  8:47                   ` Michael Shigorin
2011-03-10 13:10                     ` Dmitry V. Levin
2011-02-27 17:17   ` [devel] pkg-config Requires.private - полчища саранчи и враги народа Alexey Tourbin
2011-03-02 23:29     ` Alexey Tourbin
2011-03-02 23:49       ` Dmitry V. Levin
2011-03-02  5:50 ` Yuri N. Sedunov
2011-03-02  9:10   ` Dmitry V. Levin
2011-03-02 14:02     ` Alexey Tourbin
2011-03-02 13:43   ` Alexey Tourbin
2011-03-02 13:50     ` Yuri N. Sedunov

ALT Linux Team development discussions

This inbox may be cloned and mirrored by anyone:

	git clone --mirror http://lore.altlinux.org/devel/0 devel/git/0.git

	# If you have public-inbox 1.1+ installed, you may
	# initialize and index your mirror using the following commands:
	public-inbox-init -V2 devel devel/ http://lore.altlinux.org/devel \
		devel@altlinux.org devel@altlinux.ru devel@lists.altlinux.org devel@lists.altlinux.ru devel@linux.iplabs.ru mandrake-russian@linuxteam.iplabs.ru sisyphus@linuxteam.iplabs.ru
	public-inbox-index devel

Example config snippet for mirrors.
Newsgroup available over NNTP:
	nntp://lore.altlinux.org/org.altlinux.lists.devel


AGPL code for this site: git clone https://public-inbox.org/public-inbox.git