ALT Linux Team development discussions
 help / color / mirror / Atom feed
* [devel] проблемы с поиском зависимостей
@ 2007-03-01 20:31 Alexey Tourbin
  2007-03-01 23:02 ` Alexey Tourbin
  2007-03-02  0:46 ` Alexey Tourbin
  0 siblings, 2 replies; 4+ messages in thread
From: Alexey Tourbin @ 2007-03-01 20:31 UTC (permalink / raw)
  To: devel

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

У нас есть две "фундаментальные" проблемы с поиском зависимостей.

1) вариации шарпбанга можно использовать для отключения распознавания.
Напр. "#!/usr/bin/env bash" искать зависимости не будет.
Возможно более хитрое уклонение от поиска зависимостей,
см. напр. /usr/lib/rpm/tcl.req

Предлагаю написать какой-нибудь фиксер для /usr/lib/rpm/brp-fixup.

2) find-requires и find-provides не модульные.  Приходится
модифицировать их для подключения каждого нового типа зависимостей.
Чтобы сделать его модульным, при этом не переделывая всё вообще, можно
сделать вот что.  На каждый тип зависимостей уже есть по два файла,
напр. shell.req и shell.prov.  В этой схеме не хватает только ещё одной
"штуки", назову ee shell.files, которая будет определять, какие файлы
нужно (а какие не нужно) скармливать в shell.req и shell.prov.
При этом $(basename shell.files .files) может являться идентификатором
для всей группы shell.* скриптов поиска зависимостей, а этот
идентификатор можно учитывать в "AutoReqProv: yes, noshell".

Скрит shell.files на входе может брать список файлов и их типов, чтобы
повторно не дергать file(1), напр.
/usr/bin/cg-commit<TAB>bash script text executable
/usr/bin/buildreq<TAB>Bourne shell script text executable
(надеюсь, что tab достаточно хороший сепаратор, чтобы не мучиться с нулями)
a на выходе отдавать просто список файлов, которые подходят, т.е.
/usr/bin/cg-commit
/usr/bin/buildreq

Соответственно реализация этого shell.req может быть очень простой.
#!/bin/sh
while IFS=$'\t' read -r file type; do
	if [ -z "${type##*Bourne shell script*" ]; then
		echo "$file"
	elif [ -z "${type##*bash script text*" ]; then
		echo "$file"
	elif ...
	elif [ -z "${file##*.sh}" -a -z "${type##*text*}" ]; then
		echo "$file"
done

Соответственно find-requires превращается в простой диспетчер: запустить
file(1), отфильтровать его через все доступные /usr/lib/rpm/*.files и по
очереди скормить соответствующие списки файлов в соответствующие
/usr/lib/rpm/*.req.

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

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: [devel] проблемы с поиском зависимостей
  2007-03-01 20:31 [devel] проблемы с поиском зависимостей Alexey Tourbin
@ 2007-03-01 23:02 ` Alexey Tourbin
  2007-03-02  0:46 ` Alexey Tourbin
  1 sibling, 0 replies; 4+ messages in thread
From: Alexey Tourbin @ 2007-03-01 23:02 UTC (permalink / raw)
  To: devel

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

On Thu, Mar 01, 2007 at 11:31:09PM +0300, Alexey Tourbin wrote:
> У нас есть две "фундаментальные" проблемы с поиском зависимостей.
> 
> 1) вариации шарпбанга можно использовать для отключения распознавания.
> 2) find-requires и find-provides не модульные.

Есть ещё одна проблема: все стандартные скрипты из rpm-build жестко
делают ValidateBuildRoot, из-за чего их нельзя использовать штатным
образом для анализа/отладки.  Предлагают делать ValidateBuildRoot
только в top-level /usr/lib/rpm/find-requires.

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

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: [devel] проблемы с поиском зависимостей
  2007-03-01 20:31 [devel] проблемы с поиском зависимостей Alexey Tourbin
  2007-03-01 23:02 ` Alexey Tourbin
@ 2007-03-02  0:46 ` Alexey Tourbin
  2007-03-02 17:03   ` Dmitry V. Levin
  1 sibling, 1 reply; 4+ messages in thread
From: Alexey Tourbin @ 2007-03-02  0:46 UTC (permalink / raw)
  To: devel


[-- Attachment #1.1: Type: text/plain, Size: 491 bytes --]

On Thu, Mar 01, 2007 at 11:31:09PM +0300, Alexey Tourbin wrote:
> 2) find-requires и find-provides не модульные.  Приходится

Вот что у меня нарисовалось за пару часов.  Я думал о том, как распилить
brp-fixup, т.е. сделать из него диспетчер для /usr/lib/rpm/*.fixup
файлов, куда переместить pam.fixup, а также добавить scripts.fixup,
который будет вычищать '#!/usr/bin/env bash'.

Понятно, что это распространяется также на find-requires
и find-provides, хотя там не всё идеально.

[-- Attachment #1.2: methods.sh --]
[-- Type: application/x-sh, Size: 1307 bytes --]

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

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: [devel] проблемы с поиском зависимостей
  2007-03-02  0:46 ` Alexey Tourbin
@ 2007-03-02 17:03   ` Dmitry V. Levin
  0 siblings, 0 replies; 4+ messages in thread
From: Dmitry V. Levin @ 2007-03-02 17:03 UTC (permalink / raw)
  To: ALT Devel discussion list

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

On Fri, Mar 02, 2007 at 03:46:31AM +0300, Alexey Tourbin wrote:
> On Thu, Mar 01, 2007 at 11:31:09PM +0300, Alexey Tourbin wrote:
> > 2) find-requires и find-provides не модульные.  Приходится
> 
> Вот что у меня нарисовалось за пару часов.  Я думал о том, как распилить
> brp-fixup, т.е. сделать из него диспетчер для /usr/lib/rpm/*.fixup
> файлов, куда переместить pam.fixup, а также добавить scripts.fixup,
> который будет вычищать '#!/usr/bin/env bash'.
> 
> Понятно, что это распространяется также на find-requires
> и find-provides, хотя там не всё идеально.

А кто такой "Fatail"? ;)


-- 
ldv

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

^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2007-03-02 17:03 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2007-03-01 20:31 [devel] проблемы с поиском зависимостей Alexey Tourbin
2007-03-01 23:02 ` Alexey Tourbin
2007-03-02  0:46 ` Alexey Tourbin
2007-03-02 17:03   ` Dmitry V. Levin

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