ALT Linux Team development discussions
 help / color / mirror / Atom feed
From: Igor Vlasenko <vlasenko@imath.kiev.ua>
To: ALT Linux Team development discussions <devel@lists.altlinux.org>
Cc: "Денис Смирнов" <mithraen@freesource.info>,
	"Vitaly Kuznetsov" <vitty@altlinux.ru>
Subject: Re: [devel] GHC-7.4
Date: Fri, 10 Feb 2012 18:49:30 +0200
Message-ID: <20120210164930.GA20757@dad.imath.kiev.ua> (raw)
In-Reply-To: <c6d8a8d21d3b0fec03b84d04c3bcc49f@hadoop.ru>

On Fri, Feb 10, 2012 at 08:44:45AM +0400, Vitaly Kuznetsov wrote:
> Мне непонятно, откуда в этой схеме будет появляться несколько версий
> одной библиотеки. Они будут собираться из разных исходных пакетов?

Да. Основное различие в значениях макросов GHC_VER, 
и опционально, GHC_SERIAL (обычно %nil; нужен, если вдруг придется
собирать несколько поколений с одной версией ghc).

> Если я правильно понял Дениса, то хочется получить следующий workflow:
> 1) Вышел новый ghc - собираем в репозиторий его и
> rpm-build-ghc-whatever
> 2) По одной пересобираем библиотеки с новым ghc (и вот тут как раз
> должны рождаться 2 версии)
> 3) Пересобираем приложения, проверяем что старые библиотеки никому
> не нужны

> 4) Пересобираем библиоткеки ещё раз, оставляем только новую версию.
В предложенной схеме в пункте 4 нет необходимости.
Можно просто удалить старые библиотеки. А можно и не удалять.

> В предложеной схеме, если я правильно понял, на шаге 2 нужно будет
> автоматизированным способом создать клоны исходных пакетов с
> библиотеками.

Да, + еще автоматизированно обновляться из Hackage
и инструменты подготовки транзакций для заливки.

> Можно, наверное, пойти другим путём: собирать все возможные версии
> библиотеки (точнее - все, которые собираются) из одного спека. При
> этом потребуется устроить циклы в %build и %install, ну да это не
> сложно.

Это подход к автоматизации, при которой мы по сути 
хотим хранить скрипты автоматизации в спек файле.
IMHO, это не эффективно, так как придется руками хардкодить
списки и т.д., внешние скрипты эффективнее, IMHO.

> Можно также предположить, что почти всё с новым ghc собирается. Это
> означает, что нужно лишь придумать возможность собрать
> compat-библиотеку и держать в Сизифе несколько ghc. Спеки же самих
> пакетов можно не менять.

Я тоже сначала думал о таких подходах, но если спеки самих
пакетов не менять, то у нас сразу же возникает шаг 4)
выше -- обязательная всеобщая пересборка. 
А всеобщая пересборка -- вещь очень коварная, когда семеро одного ждут.
Если у нас 20 ghc пакетов -- этот аспект не заметен.
Если у нас 90 ghc пакетов, как сейчас - это еще терпимо.
Но если у нас будет 900 ghc пакетов (не обязательно в Сизифе;
может быть, в отдельной песочнице автоимпорта из Hackage)
то необходимость всеобщей пересборки на шаге 4) обязательно
выстрелит в ногу и рано или поздно парализует работу.

Вспомним героические усилия для обновления питона.

-- 

Dr. Igor Vlasenko
--------------------
Topology Department
Institute of Math
Kiev, Ukraine



  reply	other threads:[~2012-02-10 16:49 UTC|newest]

Thread overview: 19+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2012-02-06  6:34 Vitaly Kuznetsov
2012-02-06  8:22 ` Денис Смирнов
2012-02-06 10:01   ` Vitaly Kuznetsov
2012-02-06 13:51     ` Денис Смирнов
2012-02-06 15:32       ` Igor Vlasenko
2012-02-08 22:28         ` Денис Смирнов
2012-02-09 21:22           ` Igor Vlasenko
2012-02-10  4:44             ` Vitaly Kuznetsov
2012-02-10 16:49               ` Igor Vlasenko [this message]
2012-02-10 17:54                 ` Igor Vlasenko
2012-02-10 22:52                   ` Денис Смирнов
2012-02-10 23:04                     ` Igor Zubkov
2012-02-10 23:40                       ` Денис Смирнов
2012-02-11 18:54                     ` Igor Vlasenko
2012-02-12 21:32                       ` Денис Смирнов
2012-02-13 15:06             ` Денис Смирнов
2012-02-13 19:17               ` Igor Vlasenko
2012-02-14 12:19                   ` Igor Vlasenko
2012-02-14 12:46                     ` Igor Vlasenko

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=20120210164930.GA20757@dad.imath.kiev.ua \
    --to=vlasenko@imath.kiev.ua \
    --cc=devel@lists.altlinux.org \
    --cc=mithraen@freesource.info \
    --cc=vitty@altlinux.ru \
    /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