RPM5 — различия между версиями

Материал из Rosalab Wiki
Перейти к: навигация, поиск
(Статьи)
(Формат spec-файлов)
Строка 78: Строка 78:
  
 
=== Формат spec-файлов ===
 
=== Формат spec-файлов ===
Форматы spec-файлов для сборки пакетов RPM4 и RPM5, в целом, не совместим. Изменения в формате spec-файлов частично описаны в [http://docs.unity-linux.org/Talk:Packaging_Guide:Introduction/packaging_tricks_and_tips этом документе], написанном разработчиками Unity Linux при переходе на RPM5. Несмотря на то, что все старые теги поддерживаются, семантика и синтаксис некоторых из них поменялись.
+
Форматы spec-файлов для сборки пакетов RPM4 и RPM5, в целом, не совместим. Изменения в формате spec-файлов частично описаны в [http://docs.unity-linux.org/Talk:Packaging_Guide:Introduction/packaging_tricks_and_tips этом документе], написанном разработчиками Unity Linux при переходе на RPM5. Несмотря на то, что все старые теги поддерживаются, семантика и синтаксис некоторых из них поменялись. Изменения претерпели следующие конструкции.
 +
 
 +
==== Способ отключения макросов ====
 +
 
 +
RPM4:
 +
<pre>
 +
#%post -n foo
 +
</pre>
 +
RPM5:
 +
<pre>
 +
#%%post -n foo
 +
</pre>
 +
 
 +
Т.е. чтобы закомментировать макрос надо использовать <code>#%</code> вместо <code>#</code>.
 +
 
 +
==== Ключевые слова в именах макросов ====
 +
 
 +
RPM4:
 +
<pre>
 +
%define dirname %{version}-%{release}
 +
...
 +
%prep
 +
%setup -qn %{dirname}
 +
</pre>
 +
 
 +
RPM5:
 +
<pre>
 +
error: Bad %setup option -qn: missing argument
 +
</pre>
 +
Т.е. нельзя использовать имена системных команд для именования макросов, так как <code>rpmbuild</code> сначала попытается выполнить соответствующую команду.
 +
 
 +
==== Макрос %exclude изменил значение ====
 +
Макрос <code>%exclude</code> не влияет на список установленных файлов в секции <code>%install</code>. Т.е. теперь надо вручную удалять ненужные файлы в секции <code>%install</code>.
 +
 
 +
RPM4:
 +
<pre>
 +
%exclude %_kde_iconsdir/hicolor/index.theme
 +
...
 +
%install
 +
rm -fr %buildroot
 +
 
 +
%makeinstall_std -C build
 +
</pre>
 +
 
 +
RPM5:
 +
<pre>
 +
#%%exclude %_kde_iconsdir/hicolor/index.theme
 +
...
 +
%install
 +
rm -fr %buildroot
 +
 
 +
%makeinstall_std -C build
 +
rm -f %buildroot%{_kde_iconsdir}/hicolor/index.theme
 +
</pre>
  
 
=== API и ABI ===
 
=== API и ABI ===

Версия 12:53, 25 ноября 2011

Целью данного документа является сравнение двух веток развития формата RPM (Redhat Package Manager): RPM версии 4 и RPM версии 5.

История появления RPM5

Краткие сведения по истории возникновения RPM5 можно прочитать в этой статье.

Сравнительный обзор RPM4 и RPM5

Таблица 1. Сравнение RPM4 и RPM5
RPM 4 RPM 5
Версия 4.9.1.2 5.4.4
Опции 73 182
Строки кода 59,432 285,821
Языки С (90.6%)
Perl (4.3%)
Shell (4.3%)
Others (0.8%)
C (77.5%)
Perl (14.3%)
Shell (2.7%)
Others (5.5%)
Коммиты 11347 16352
Баги 851 68
Разработчики 3-5 3-5
Пользователи RHEL
Fedora
CentOS
openSUSE
ALT Linux
Mageia
Mandriva Linux
Unity Linux
Wind River Linux
CAOS Linux
Ark Linux
OpenPKG
LSB Совместим Несовместим (не
поддерживает RPM3)
Сжатие Gzip
Bzip2
Gzip
Bzip2
LZMA
Поддержка
компиляторов
GCC GCC
Sun Studio
Intel C/C++
Поддержка
платформ
Linux Linux
BSD
Solaris
Mac OS X
Cygwin

Информация по RPM4 и RPM5

Таблица 2. Информация по RPM4 и RPM5
RPM 4 RPM 5
Сайт Сайт
Репозиторий Репозиторий
Релизы Релизы
Баги Баги
Коммиты Коммиты
Документация Документация
API API

Анализ совместимости

Формат RPM-пакетов

Форматы бинарных пакетов RPM4 и RPM5 обратно и прямо совместимы, т.е. пакеты, собранные с помощью RPM4, могут быть установлены при помощи RPM5 и наоборот. Стоит заметить, что RPM5 не поддерживает RPM3, который, однако, поддерживается RPM4. Из пресс-релиза RPM5:

Finally, support for the old RPMv3 (LSB) package format was removed to cleanup and simplify the code base. RPM 5, with respect to RPM format packages, now supports RPMv4 format only.

Формат spec-файлов

Форматы spec-файлов для сборки пакетов RPM4 и RPM5, в целом, не совместим. Изменения в формате spec-файлов частично описаны в этом документе, написанном разработчиками Unity Linux при переходе на RPM5. Несмотря на то, что все старые теги поддерживаются, семантика и синтаксис некоторых из них поменялись. Изменения претерпели следующие конструкции.

Способ отключения макросов

RPM4:

#%post -n foo

RPM5:

#%%post -n foo

Т.е. чтобы закомментировать макрос надо использовать #% вместо #.

Ключевые слова в именах макросов

RPM4:

%define dirname %{version}-%{release}
...
%prep
%setup -qn %{dirname}

RPM5:

error: Bad %setup option -qn: missing argument

Т.е. нельзя использовать имена системных команд для именования макросов, так как rpmbuild сначала попытается выполнить соответствующую команду.

Макрос %exclude изменил значение

Макрос %exclude не влияет на список установленных файлов в секции %install. Т.е. теперь надо вручную удалять ненужные файлы в секции %install.

RPM4:

%exclude %_kde_iconsdir/hicolor/index.theme
...
%install
rm -fr %buildroot
  
%makeinstall_std -C build

RPM5:

#%%exclude %_kde_iconsdir/hicolor/index.theme
...
%install
rm -fr %buildroot

%makeinstall_std -C build
rm -f %buildroot%{_kde_iconsdir}/hicolor/index.theme

API и ABI

Согласно этой таблице, API на языке Си (библиотека librpm) претерпел серьезные изменения. ABI также изменился. Таким образом, все приложения, использующие librpm, должны быть пересобраны, а некоторые - и с модификацией исходного кода.

Статьи