From: Alexey Tourbin <at@altlinux.ru> To: devel@lists.altlinux.org Subject: [devel] pkg-config Requires.private - полчища саранчи и враги народа Date: Sun, 27 Feb 2011 17:38:06 +0300 Message-ID: <20110227143806.GD22224@altlinux.org> (raw) Некоторые пакеты из 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. В связи с этими изменениями я пересоберу некоторые пакеты.
next reply other threads:[~2011-02-27 14:38 UTC|newest] Thread overview: 21+ messages / expand[flat|nested] mbox.gz Atom feed top 2011-02-27 14:38 Alexey Tourbin [this message] 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
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=20110227143806.GD22224@altlinux.org \ --to=at@altlinux.ru \ --cc=devel@lists.altlinux.org \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: link
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