From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Date: Sun, 27 Feb 2011 17:38:06 +0300 From: Alexey Tourbin To: devel@lists.altlinux.org Message-ID: <20110227143806.GD22224@altlinux.org> Mime-Version: 1.0 Content-Type: text/plain; charset=koi8-r Content-Disposition: inline Content-Transfer-Encoding: 8bit Subject: [devel] =?koi8-r?b?cGtnLWNvbmZpZyBSZXF1aXJlcy5wcml2YXRlIC0g0M/M?= =?koi8-r?b?3sndwSDTwdLBzt7JIMkg19LBx8kgzsHSz8TB?= X-BeenThere: devel@lists.altlinux.org X-Mailman-Version: 2.1.12 Precedence: list Reply-To: ALT Linux Team development discussions List-Id: ALT Linux Team development discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sun, 27 Feb 2011 14:38:07 -0000 Archived-At: List-Archive: List-Post: Некоторые пакеты из 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. В связи с этими изменениями я пересоберу некоторые пакеты.