[devel] Repocop, debuginfo и compat-пакеты
Ivan A. Melnikov
iv на altlinux.org
Вт Мар 8 20:57:01 UTC 2011
On Tue, 8 Mar 2011 21:59:22 +0300
"Dmitry V. Levin" <ldv на altlinux.org> wrote:
> On Tue, Mar 08, 2011 at 09:32:21PM +0300, Ivan A. Melnikov wrote:
> > Repocop интересно ругается на boost, например так:
> >
> > value of
> > symlink /usr/lib/debug/usr/lib64/libboost_graph_parallel.so.debug is
> > different from the same symlink in the package
> > libboost_graph_parallel1.45.0-debuginfo-1.45.0-alt7.x86_64.
> > Moreover, the packages have no explicit conflicts with each other.
> > You should add explicit conflicts, or, if conflicts are avoidable,
> > consider using alternatives.
> >
> > Ругань, вообще говоря, правильная. Что-нибудь можно предпринять по
> > этому поводу? А надо ли?
>
> А пакеты, которые вытягивают эти debuginfo по зависимостям, можно
> установить одновременно? Если нет, то можно ничего не предпринимать,
> наверное.
>
Конфликтуют debuginfo библиотек и соответствующих compat-библиотек,
поскольку и библиотека (например, libboost_graph_parallel.so.1.46.0) и
compat-библиотек (например, libboost_graph_parallel.so.1.45.0) --
видимо, потому что на них есть (была) одна и та же ссылка для линковки
(в нашем примере %_lib/libboost_graph_parallel.so).
debuginfo библиотек из boost 1.45.0 ничего зависеть не может, так как
этот debuginfo появился при сборке compat-пакета одновременно с более
новым бустом -- то есть, после этого собрать что-то с 1.45.0 стало
невозможно.
Однако формально ничего не мешает наличию библиотек из 1.45.0 и 1.46.0
одовременно, а значит в системе могут одновременно присутствовать и их
клиенты, со всеми вытекающими.
Боюсь, проблема вернётся и будет уже актуальной, например, когда будет
boost 1.46.1 (а это довльно скоро), или обновится любая другая
библиотека, собираемая так (в духе shared library policy с разными и
одновременно живущими в системе пакетами для разных версий,
но с одним devel-пакетом для последней версии).
--
WBR,
Ivan A. Melnikov
Подробная информация о списке рассылки Devel