ALT Linux Team development discussions
 help / color / mirror / Atom feed
From: Mikhail Zabaluev <mhz@altlinux.org>
To: devel@altlinux.ru
Subject: [devel] Re: perl-5.8.0-alt0.3 (important)
Date: Thu, 17 Oct 2002 12:14:13 +0400
Message-ID: <20021017081412.GB22143@mhz.mikhail.zabaluev.name> (raw)
In-Reply-To: <20021016014557.GA29249@homestead.turbinal.org>

[-- Attachment #1: Type: text/plain, Size: 4624 bytes --]

Hello at,

On Wed, Oct 16, 2002 at 05:45:57AM +0400, at@turbinal.org wrote:
>
> 2) я сделал перемещение некоторых модулей из perl в perl-base и
> perl-devel. Это требуется для более эффективного разведения перловых
> зависимостей в масштабах дистрибутива. (В частности, ExtUtils уехали в
> perl-devel, а вместе с ними и CPAN.pm; это и другие решения будут
> казаться правильными, если над ними подумать.)

Ещё лучше обосновать эти решения публично.
В оригинале, насколько я понимаю, perl-base был выделен
в Mandrake для получения минимального набора, необходимого
для инсталлятора (или drak'ов?).

> 4) libperl.so* relocated to /usr/lib; у меня сложилось мнение, что
> libperl.so* ничем не лучше и не хуже других *.so*. Сделано это следующим
> образом:
> 
> %make_build CCDLFLAGS="-rdynamic"
> $PERL -pi -e "s/,-rpath,[^\s,'\"]+//g && s/\s*-Wl(?!,)//g" $RPM_BUILD_ROOT%archlib/Config.pm
> mkdir -p $RPM_BUILD_ROOT%_libdir
> mv $RPM_BUILD_ROOT%archlib/CORE/libperl.so.%sover $RPM_BUILD_ROOT%_libdir
> ln -sf libperl.so.%sover $RPM_BUILD_ROOT%_libdir/libperl.so
> 
> Последствия этого шага для других пакетов понятны мне не до конца,
> однако проблем пока не замечено.

Я при сборке 5.6.x не стал этого делать, чтобы:
1) не лезть супротив скриптов сборки вел. и уж. Perl;
2) не предоставлять лёгкого способа собрать что-либо с libperl.so,
   не пользуясь ExtUtils. Тем самым, неграмотные скрипты сборки
   оказываются на виду и переписываются грамотным образом.

> 5) use of inc_version_list mechanism is finally deprecated. Default
> values
> 
> Configure variable	Default value
> $privlib		$prefix/lib/perl5/$version
> $archlib 		$prefix/lib/perl5/$version/$archname
> 
> were changed to
> 
> $privlib		$prefix/lib/perl5
> $archlib 		$prefix/lib/perl5/$archname
> 
> by mhz on Tue May 29 2001. Default values
> 
> $sitelib		$siteprefix/lib/perl5/site_perl/$version
> $sitearch		$siteprefix/lib/perl5/site_perl/$version/$archname
> 
> are changed to
> 
> $sitelib		$siteprefix/lib/perl5/site_perl
> $sitearch		$siteprefix/lib/perl5/site_perl/$archname
> 
> since now.
> 
> Обоснование: создатели перла предусмотрели возможность иметь в системе
> одновременно несколько версий перла, для каждого из которых существует
> отдельное дерево библиотек. Дистрибутив такой возможности не
> предусматривает; вернее, для этого есть /usr/local. В дистрибутиве есть
> более надежные механизмы контроля версий и совместимости.

Версии в sitelib/sitearch позволяли сохранять модули,
собранные под старыми версиями perl; худшее, что могло случиться,
это тихий "вывод из обращения" модулей, утративших совместимость.
В любом случае такие модули придётся пересобирать, но без версий
в sitelib/sitearch определить, под каким perl ABI был собран модуль,
"невооружённым взглядом" невозможно без дополнительных усилий
при сборке пакетов.

> Есть претензии
> и по существу механизма: возможна ситуация, когда старое дерево
> библиотек совместимо с новым перлом лишь частично. Это мы имеем сейчас в
> связи с изменениями в ABI.

Очевидно, если хоть какие-то модули могли оказаться несовместимыми,
всё дерево нужно объявлять несовместимым.

> 6) я подумал и решил оставть названия каталогов
> 
> /usr/lib/perl5/i386-linux
> /usr/lib/perl5/site_perl/i386-linux
> 
> а не i386-linux-thread-multi, как делают RH и MDK. На это есть две
> причины: а) теперь все сборки будут с тредами; во всяком случае, нужны
> будут очень веские причины, чтобы отказаться от сборки с тредами

Например, стойкая несовместимость с тредами какой-либо библиотеки,
которую использует какой-либо модуль.

> б)
> название каталога в любом случае условно и не всегда/не вполне
> соответствует действительности.

Оно соответствует некоторому выбору флагов при сборке, который стоит
отличать от других возможных наборов флагов.

Впрочем, насчёт сосуществования в системе threaded и не-threaded
версий Perl я ничего не знаю.

> 7) Замечены как минимум следующие модули, которые входят в оригинальный
> перл (некоторые из них появились только в 5.8). Есть соображения как за,
> так и против того, чтобы продолжать собирать их из/в виде отдельных
> пакетов. С ними лучше пока ничего не делать. Я ещё помедитирую.

В CPAN эти модули могут обновляться чаще, чем в дистрибутиве.
Хотя, я не знаю тонкостей политики CPAN в отношении
bundled модулей.

> perl-Time-HiRes
> perl-Storable
> perl-MIME-Base64
> perl-CGI
> perl-DB_File
> perl-Digest-MD5
> perl-libnet
> perl-Parse-RecDescent

-- 
Stay tuned,
  MhZ                                     JID: mookid@jabber.org
___________
Q:	How many lawyers does it take to change a light bulb?
A:	One.  Only it's his light bulb when he's done.

[-- Attachment #2: Type: application/pgp-signature, Size: 189 bytes --]

  parent reply	other threads:[~2002-10-17  8:14 UTC|newest]

Thread overview: 31+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2002-10-16  1:45 [devel] " at
2002-10-16  4:44 ` at
2002-10-16  8:54   ` Dmitry V. Levin
2002-10-16 14:47     ` at
2002-10-16 15:31       ` Dmitry V. Levin
2002-10-16  8:39 ` Alexander Bokovoy
2002-10-16  9:09   ` Stanislav Ievlev
2002-10-16  8:50 ` Dmitry V. Levin
2002-10-16  8:56   ` Anton V. Boyarshinov
2002-10-16 14:19     ` at
2002-10-17  8:14 ` Mikhail Zabaluev [this message]
2002-10-18  1:40   ` [devel] " at
2002-10-18 22:26     ` Mikhail Zabaluev
2002-10-18 23:42       ` at
2002-10-19  9:38         ` Mikhail Zabaluev
2002-10-19 20:45           ` [devel] Re: perl ABI detection at find-requires stage at
2002-10-20  0:06             ` at
2002-10-21 23:05               ` Mikhail Zabaluev
2002-10-21  6:00           ` [devel] Re: perl-5.8.0-alt0.3 (important) Anton V. Boyarshinov
2002-10-21 19:26             ` Alexey I. Froloff
2002-10-22  8:20               ` Dmitry V. Levin
2002-10-21 20:16             ` [devel] Re: perl inc_version_list at
2002-10-21 22:52             ` [devel] Re: perl-5.8.0-alt0.3 (important) Mikhail Zabaluev
2002-10-22  6:25               ` Anton V. Boyarshinov
2002-10-22 13:08                 ` Alexey Tourbin
2002-10-26  0:32                   ` [devel] Re: perl thread safety at
2002-10-20  1:37       ` [devel] Re: perl/Junior at
2002-10-20 13:37       ` [devel] Re: perl-5.8.0-alt0.3 (important) Michael Shigorin
2002-10-21  2:12         ` at
2002-10-21 22:50           ` Mikhail Zabaluev
2002-10-21  3:01       ` at

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=20021017081412.GB22143@mhz.mikhail.zabaluev.name \
    --to=mhz@altlinux.org \
    --cc=devel@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