* [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