ALT Linux Team development discussions
 help / color / mirror / Atom feed
* [devel] Strange rpm errors
@ 2008-10-16 12:02 Vitaly Ostanin
  2008-10-16 13:09 ` Alexey Tourbin
  0 siblings, 1 reply; 5+ messages in thread
From: Vitaly Ostanin @ 2008-10-16 12:02 UTC (permalink / raw)
  To: ALT Devel discussion list

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

Здравствуйте.

Обнаружил, что при наличии в спеке в %files такой строки
%doc %_defaultdocdir/%name-%version

пакет не собирается со странными сообщениями:

Wrote: /usr/src/RPM/SRPMS/heartbeat-2.1.3-alt1.src.rpm
error: create archive failed on file 
/usr/src/tmp/heartbeat-buildroot/usr/share/doc/heartbeat-2.1.3/AUTHORS: 
cpio: open failed - Bad file descriptor

RPM build errors:
     File listed twice: /etc/ha.d/resource.d/ldirectord
     File listed twice: /usr/lib/ocf/resource.d/heartbeat/ldirectord
     File listed twice: /usr/share/doc/heartbeat-2.1.3

Если эту строку удалить, то пакет собирается нормально. Я 
понимаю, что сам дурак и всё такое, но всё же rpm мог бы выводить 
более понятное сообщение об ошибке.

Не собирающийся коммит:
http://git.altlinux.org/people/vyt/packages/?p=heartbeat.git;a=commit;h=5f30983b0956d58906f39a8389a0d288ba3759e4
Собирающийся:
http://git.altlinux.org/people/vyt/packages/?p=heartbeat.git;a=commit;h=394bef3755c3ebfa30672854d9d403b9e46cd07b

-- 
Regards, Vyt
mailto:  vyt@altlinux.org
JID:     vitaly.ostanin@gmail.com


[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 252 bytes --]

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

* Re: [devel] Strange rpm errors
  2008-10-16 12:02 [devel] Strange rpm errors Vitaly Ostanin
@ 2008-10-16 13:09 ` Alexey Tourbin
  2008-10-16 19:03   ` Vitaly Ostanin
  0 siblings, 1 reply; 5+ messages in thread
From: Alexey Tourbin @ 2008-10-16 13:09 UTC (permalink / raw)
  To: ALT Devel discussion list

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

On Thu, Oct 16, 2008 at 04:02:00PM +0400, Vitaly Ostanin wrote:
> Обнаружил, что при наличии в спеке в %files 
> такой строки
> %doc %_defaultdocdir/%name-%version
> 
> пакет не собирается со странными 
> сообщениями:
> 
> Wrote: /usr/src/RPM/SRPMS/heartbeat-2.1.3-alt1.src.rpm
> error: create archive failed on file 
> /usr/src/tmp/heartbeat-buildroot/usr/share/doc/heartbeat-2.1.3/AUTHORS: 
> cpio: open failed - Bad file descriptor
> 
> RPM build errors:
>     File listed twice: /etc/ha.d/resource.d/ldirectord
>     File listed twice: /usr/lib/ocf/resource.d/heartbeat/ldirectord
>     File listed twice: /usr/share/doc/heartbeat-2.1.3
> 
> Если эту строку удалить, то пакет 
> собирается нормально.

Нельзя одновременно использовать
%doc <абсолютный-путь-в-дефолтном-каталоге>
%doc <относительный-путь>

Это связано с тем, что, когда выполняется %doc второго вида,
то дефолтный каталог сначала удаляется, потом заново создаётся,
и в него копируются <относительные-пути>.

%build
touch Changes
%install
install -pD -m644 /dev/null %buildroot%_docdir/%name-%version/README
%files
%doc %_docdir/%name-%version
%doc Changes

Когда "%doc Changes" будет исполнен, то он "затрёт" README.

Executing(%doc): /bin/sh -e /tmp/.private/at/rpm-tmp.96021
+ umask 022
+ /bin/mkdir -p /tmp/.private/at/BUILD
+ cd /tmp/.private/at/BUILD
+ DOCDIR=/tmp/.private/at/test-buildroot/usr/share/doc/test-0
+ export DOCDIR
+ rm -rf /tmp/.private/at/test-buildroot/usr/share/doc/test-0
+ /bin/mkdir -p /tmp/.private/at/test-buildroot/usr/share/doc/test-0
+ cp -prL Changes /tmp/.private/at/test-buildroot/usr/share/doc/test-0
+ chmod -R go-w /tmp/.private/at/test-buildroot/usr/share/doc/test-0
+ chmod -R a+rX /tmp/.private/at/test-buildroot/usr/share/doc/test-0
+ exit 0

> Я понимаю, что сам 
> дурак и всё такое, но всё же rpm мог бы 
> выводить более понятное сообщение об 
> ошибке.

rpm сказал правильное сообщение об ошибке:
error: create archive failed on file /tmp/.private/at/test-buildroot/usr/share/doc/test-0/README: cpio: open failed - Bad file descriptor

Если посмотреть, то в билдруте файла README действительно больше нет.
Но он был.  А куда он делся rpm объяснить не может.

> Не собирающийся коммит:
> http://git.altlinux.org/people/vyt/packages/?p=heartbeat.git;a=commit;h=5f30983b0956d58906f39a8389a0d288ba3759e4
> Собирающийся:
> http://git.altlinux.org/people/vyt/packages/?p=heartbeat.git;a=commit;h=394bef3755c3ebfa30672854d9d403b9e46cd07b

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

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

* Re: [devel] Strange rpm errors
  2008-10-16 13:09 ` Alexey Tourbin
@ 2008-10-16 19:03   ` Vitaly Ostanin
  2008-10-19 11:52     ` Vitaly Ostanin
  0 siblings, 1 reply; 5+ messages in thread
From: Vitaly Ostanin @ 2008-10-16 19:03 UTC (permalink / raw)
  To: ALT Linux Team development discussions

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

Alexey Tourbin пишет:
> On Thu, Oct 16, 2008 at 04:02:00PM +0400, Vitaly Ostanin wrote:
>> Обнаружил, что при наличии в спеке в %files 
>> такой строки
>> %doc %_defaultdocdir/%name-%version
>>
>> пакет не собирается со странными 
>> сообщениями:
>>
>> Wrote: /usr/src/RPM/SRPMS/heartbeat-2.1.3-alt1.src.rpm
>> error: create archive failed on file 
>> /usr/src/tmp/heartbeat-buildroot/usr/share/doc/heartbeat-2.1.3/AUTHORS: 
>> cpio: open failed - Bad file descriptor
>>
>> RPM build errors:
>>     File listed twice: /etc/ha.d/resource.d/ldirectord
>>     File listed twice: /usr/lib/ocf/resource.d/heartbeat/ldirectord
>>     File listed twice: /usr/share/doc/heartbeat-2.1.3
>>
>> Если эту строку удалить, то пакет 
>> собирается нормально.
> 
> Нельзя одновременно использовать
> %doc <абсолютный-путь-в-дефолтном-каталоге>
> %doc <относительный-путь>

Я уже догадался :)

> Это связано с тем, что, когда выполняется %doc второго вида,
> то дефолтный каталог сначала удаляется, потом заново создаётся,

Зачем это делается? При повторном %doc второго вида этого не 
происходит.

Хорошо бы в этом месте говорить WARNING: причина удаления. А то 
создаётся впечатение, что это штатное поведение при сборке, вроде 
удаления buildroot.

<skipped/>

> А куда он делся rpm объяснить не может.

Зато может явно сказать, что файл был и теперь нету. Впрочем, об 
этом я нашёл в гугле, но там ссылались на fs corruption, про 
тонкости %doc ничего не нашёл.

<skipped/>

-- 
Regards, Vyt
mailto:  vyt@altlinux.org
JID:     vitaly.ostanin@gmail.com


[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 252 bytes --]

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

* Re: [devel] Strange rpm errors
  2008-10-16 19:03   ` Vitaly Ostanin
@ 2008-10-19 11:52     ` Vitaly Ostanin
  2008-10-19 13:01       ` Alexey Tourbin
  0 siblings, 1 reply; 5+ messages in thread
From: Vitaly Ostanin @ 2008-10-19 11:52 UTC (permalink / raw)
  To: ALT Linux Team development discussions

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

Vitaly Ostanin пишет:

<skipped/>

>> Нельзя одновременно использовать
>> %doc <абсолютный-путь-в-дефолтном-каталоге>
>> %doc <относительный-путь>
> 
> Я уже догадался :)
> 
>> Это связано с тем, что, когда выполняется %doc второго вида,
>> то дефолтный каталог сначала удаляется, потом заново создаётся,
> 
> Зачем это делается? При повторном %doc второго вида этого не 
> происходит.

И это наводит на предположение, что %_docdir удаляется не при 
выполнении %doc второго вида, а при обработке %doc первого вида.

<skipped/>

-- 
Regards, Vyt
mailto:  vyt@altlinux.org
JID:     vitaly.ostanin@gmail.com


[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 252 bytes --]

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

* Re: [devel] Strange rpm errors
  2008-10-19 11:52     ` Vitaly Ostanin
@ 2008-10-19 13:01       ` Alexey Tourbin
  0 siblings, 0 replies; 5+ messages in thread
From: Alexey Tourbin @ 2008-10-19 13:01 UTC (permalink / raw)
  To: ALT Linux Team development discussions

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

On Sun, Oct 19, 2008 at 03:52:50PM +0400, Vitaly Ostanin wrote:
> Vitaly Ostanin пишет:
> 
> <skipped/>
> 
> >>Нельзя одновременно использовать
> >>%doc 
> >><абсолютный-путь-в-дефолтном-каталоге>
> >>%doc <относительный-путь>
> >
> >Я уже догадался :)
> >
> >>Это связано с тем, что, когда 
> >>выполняется %doc второго вида,
> >>то дефолтный каталог сначала удаляется, 
> >>потом заново создаётся,
> >
> >Зачем это делается? При повторном %doc 
> >второго вида этого не происходит.
> 
> И это наводит на предположение, что %_docdir 
> удаляется не при выполнении %doc второго 
> вида, а при обработке %doc первого вида.

%doc с абсолютным путём работает только как маркер (типа %config,
но не %config, а %doc).

%doc с относительным путём запускает скрипт копирования из каталога
сборки в каталог с документацией (всё содержимое которого отмечается
маркером %doc).

Несколько %doc с относительными путями группируются в один скрипт (но
раздельные команды "cp").

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

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

end of thread, other threads:[~2008-10-19 13:01 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2008-10-16 12:02 [devel] Strange rpm errors Vitaly Ostanin
2008-10-16 13:09 ` Alexey Tourbin
2008-10-16 19:03   ` Vitaly Ostanin
2008-10-19 11:52     ` Vitaly Ostanin
2008-10-19 13:01       ` Alexey Tourbin

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