* [devel] Циклическая зависимость. @ 2011-03-20 15:52 Sergey Y. Afonin 2011-03-20 17:25 ` Alexey Tourbin 0 siblings, 1 reply; 7+ messages in thread From: Sergey Y. Afonin @ 2011-03-20 15:52 UTC (permalink / raw) To: devel Приветствую. Раз уж про зависимости заговорили. http://git.altlinux.org/tasks/40548/task/log.8.1 warning [i586]: mysql-workbench-gpl=5.2.33-alt2: circular dependencies on mysql-workbench-gpl-data=5.2.33-alt2 warning [i586]: mysql-workbench-gpl-data=5.2.33-alt2: circular dependencies on mysql-workbench-gpl=5.2.33-alt2 Пакеты должны быть строго зависимы. Можно сделать один пакет, но mysql-workbench-gpl-data - noarch на самом деле и размер почти 7M. Не обращать внимания на warning, или есть другой метод ? -- С уважением, Сергей Афонин ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [devel] Циклическая зависимость. 2011-03-20 15:52 [devel] Циклическая зависимость Sergey Y. Afonin @ 2011-03-20 17:25 ` Alexey Tourbin 2011-03-20 19:39 ` Sergey Y. Afonin 0 siblings, 1 reply; 7+ messages in thread From: Alexey Tourbin @ 2011-03-20 17:25 UTC (permalink / raw) To: ALT Linux Team development discussions On Sun, Mar 20, 2011 at 06:52:33PM +0300, Sergey Y. Afonin wrote: > Приветствую. > > Раз уж про зависимости заговорили. > http://git.altlinux.org/tasks/40548/task/log.8.1 > > warning [i586]: mysql-workbench-gpl=5.2.33-alt2: circular dependencies on mysql-workbench-gpl-data=5.2.33-alt2 > warning [i586]: mysql-workbench-gpl-data=5.2.33-alt2: circular dependencies on mysql-workbench-gpl=5.2.33-alt2 > > Пакеты должны быть строго зависимы. Можно сделать один пакет, но > mysql-workbench-gpl-data - noarch на самом деле и размер почти 7M. > Не обращать внимания на warning, или есть другой метод ? У пакета mysql-workbench-gpl-data можно убрать зависимость. Т.к. для работоспособности программы требуются данные, а даные в свою очередь сами по себе ничего не требуют. Если пакет с данными был отпилен недавно, то при его установке может возникнуть конфликт со старой версией программы, когда пакет с данными ещё не был отпилен. Если данные отпилились при переходе на новую версию, то лучше использовать конструкцию типа %package data Conclicts: %name < %version Если же данные отпилились на прежней версии, то нужно использовать конструкцию %package data Conclicts: %name < %version-%release и при обновлении на новую версию убрать из этой конструкции %release. ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [devel] Циклическая зависимость. 2011-03-20 17:25 ` Alexey Tourbin @ 2011-03-20 19:39 ` Sergey Y. Afonin 2011-03-20 20:24 ` Alexey Tourbin 0 siblings, 1 reply; 7+ messages in thread From: Sergey Y. Afonin @ 2011-03-20 19:39 UTC (permalink / raw) To: ALT Linux Team development discussions On Sunday 20 March 2011, Alexey Tourbin wrote: > У пакета mysql-workbench-gpl-data можно убрать зависимость. Т.к. для > работоспособности программы требуются данные, а даные в свою очередь > сами по себе ничего не требуют. Но тут будет возможна ситуация, когда удаляется mysql-workbench-gpl, и остаётся безхозный mysql-workbench-gpl-data. Наверное, это тоже не очень хороший вариант ? Или это лучше, чем циклическая зависимость ? > ещё не был отпилен. Если данные отпилились при переходе на новую версию, > то лучше использовать конструкцию типа > > %package data > Conclicts: %name < %version Отпилились давно, но сейчас именно переход будет: alt1 в Сизифе не было. -- С уважением, Сергей Афонин ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [devel] Циклическая зависимость. 2011-03-20 19:39 ` Sergey Y. Afonin @ 2011-03-20 20:24 ` Alexey Tourbin 2011-03-21 6:50 ` Sergey Y. Afonin 0 siblings, 1 reply; 7+ messages in thread From: Alexey Tourbin @ 2011-03-20 20:24 UTC (permalink / raw) To: ALT Linux Team development discussions On Sun, Mar 20, 2011 at 10:39:58PM +0300, Sergey Y. Afonin wrote: > On Sunday 20 March 2011, Alexey Tourbin wrote: > > > У пакета mysql-workbench-gpl-data можно убрать зависимость. Т.к. для > > работоспособности программы требуются данные, а даные в свою очередь > > сами по себе ничего не требуют. > > Но тут будет возможна ситуация, когда удаляется mysql-workbench-gpl, > и остаётся безхозный mysql-workbench-gpl-data. Наверное, это тоже не > очень хороший вариант ? Или это лучше, чем циклическая зависимость ? Если так подумать, то при установке mysql-workbench кроме основного бинарного пакета и пакета с данными будут установлены ещё какие-то дополнительные пакеты - например, MySQL-client. Тогда возможна ситуация, когда mysql-workbench удаляется, а бесхозный MySQL-client остаётся. Может, тогда стоит добавить в MySQL-client циклическую зависимость на mysql-workbench? > > ещё не был отпилен. Если данные отпилились при переходе на новую версию, > > то лучше использовать конструкцию типа > > > > %package data > > Conclicts: %name < %version > > Отпилились давно, но сейчас именно переход будет: alt1 в Сизифе не было. Если совсем давно - если во времена бранча 4.0 подпакет с данными был уже отпилен - то конфликт можно вообще удалить. Иначе оставить в процитированном варианте. ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [devel] Циклическая зависимость. 2011-03-20 20:24 ` Alexey Tourbin @ 2011-03-21 6:50 ` Sergey Y. Afonin 2011-03-21 7:45 ` Alexey Tourbin 0 siblings, 1 reply; 7+ messages in thread From: Sergey Y. Afonin @ 2011-03-21 6:50 UTC (permalink / raw) To: ALT Linux Team development discussions On Sunday, March 20, 2011, Alexey Tourbin wrote: > Если так подумать, то при установке mysql-workbench кроме основного > бинарного пакета и пакета с данными будут установлены ещё какие-то > дополнительные пакеты - например, MySQL-client. Тогда возможна ситуация, > когда mysql-workbench удаляется, а бесхозный MySQL-client остаётся. > Может, тогда стоит добавить в MySQL-client циклическую зависимость > на mysql-workbench? С одной стороны, оно резонно, но, с другой, lib* может использовать кто-то ещё, а этот "data" однозначно нужен только для основного пакета. > Если совсем давно - если во времена бранча 4.0 подпакет с данными был > уже отпилен - то конфликт можно вообще удалить. Иначе оставить в > процитированном варианте. Тогда в ALT его ещё не было. В бранч 5.1 и Сизиф он попал чуть меньше года назад, Requires есть в основном пакете в виде "Requires: %name-data", в mysql-workbench-gpl-data в репозитариях Requires совсем отсутствует. Я так понимаю, что в data, в этом случае, вообще ничего менять не надо. -- С уважением, Сергей Афонин asy@altlinux.ru ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [devel] Циклическая зависимость. 2011-03-21 6:50 ` Sergey Y. Afonin @ 2011-03-21 7:45 ` Alexey Tourbin 2011-03-21 7:56 ` Rinat Bikov 0 siblings, 1 reply; 7+ messages in thread From: Alexey Tourbin @ 2011-03-21 7:45 UTC (permalink / raw) To: ALT Linux Team development discussions On Mon, Mar 21, 2011 at 09:50:59AM +0300, Sergey Y. Afonin wrote: > On Sunday, March 20, 2011, Alexey Tourbin wrote: > > > Если так подумать, то при установке mysql-workbench кроме основного > > бинарного пакета и пакета с данными будут установлены ещё какие-то > > дополнительные пакеты - например, MySQL-client. Тогда возможна ситуация, > > когда mysql-workbench удаляется, а бесхозный MySQL-client остаётся. > > Может, тогда стоит добавить в MySQL-client циклическую зависимость > > на mysql-workbench? > > С одной стороны, оно резонно, но, с другой, lib* может использовать > кто-то ещё, а этот "data" однозначно нужен только для основного пакета. Но если удалён последний клиент библиотеки, то библиотека однозначно тоже не нужна. Короче, мораль такая: не надо пытаться за счёт зависимостей решать проблему синхронного удаления неиспользуемых компонентов. Эта задача не решается за счет зависимостей в общем случае, а частный случай bin<->data не делает погоды. Это задача решается на верхнем уровне package management. Пакет может быть либо указан/выбран пользователем напрямую, либо выбран автоматически по зависимостям. В дальнейшем к этим двум категорями пакетов применяются разные правила обновления/удаления. Автоматически выбранные пакеты можно автоматически удалять, если они не требуются другими пакетами (фактически собирать мусор), а выбранные пользователем - нельзя. Это реализовано где-то в synaptic или aptitude. > > Если совсем давно - если во времена бранча 4.0 подпакет с данными был > > уже отпилен - то конфликт можно вообще удалить. Иначе оставить в > > процитированном варианте. > > Тогда в ALT его ещё не было. В бранч 5.1 и Сизиф он попал чуть меньше > года назад, Requires есть в основном пакете в виде "Requires: %name-data", > в mysql-workbench-gpl-data в репозитариях Requires совсем отсутствует. > Я так понимаю, что в data, в этом случае, вообще ничего менять не надо. В основном пакете: Requires: %name-data = %version В -data подпакете: Conflicts: %name < %version ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [devel] Циклическая зависимость. 2011-03-21 7:45 ` Alexey Tourbin @ 2011-03-21 7:56 ` Rinat Bikov 0 siblings, 0 replies; 7+ messages in thread From: Rinat Bikov @ 2011-03-21 7:56 UTC (permalink / raw) To: ALT Linux Team development discussions 21 марта 2011 г. 10:45 Alexey Tourbin написал: > собирать мусор), а выбранные пользователем - нельзя. Это реализовано > где-то в synaptic или aptitude. Ещё бы в apt такое реализовать, в частности, autoremove, тогда можно будет надеяться на пакетных менеджеров... -- С уважением, Ринат Биков. ^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2011-03-21 7:56 UTC | newest] Thread overview: 7+ messages (download: mbox.gz / follow: Atom feed) -- links below jump to the message on this page -- 2011-03-20 15:52 [devel] Циклическая зависимость Sergey Y. Afonin 2011-03-20 17:25 ` Alexey Tourbin 2011-03-20 19:39 ` Sergey Y. Afonin 2011-03-20 20:24 ` Alexey Tourbin 2011-03-21 6:50 ` Sergey Y. Afonin 2011-03-21 7:45 ` Alexey Tourbin 2011-03-21 7:56 ` Rinat Bikov
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