ALT Linux Team development discussions
 help / color / mirror / Atom feed
* [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