Gtk Gnome Themes Policy
Упаковка тем GTK+ и GNOME
Этот документ определяет порядок упаковки GTK+ engines, GTK+ themes, Metacity themes и GNOME themes.
Определения
- GTK+ engine: файл %_libdir/gtk-2.0/*/engines/lib<engine_name>.so
- GTK+1 theme: каталог %_datadir/themes/<theme_name>/gtk и его содержимое
- GTK+2 theme: каталог %_datadir/themes/<theme_name>/gtk-2.0 и его содержимое
- Metacity theme: каталог %_datadir/themes/<theme_name>/metacity-* и его содержимое
- Icon theme: каталог %_iconsdir/<theme_name> и его содержимое
- GNOME theme: файл %_datadir/themes/<theme_name>/index.theme
Разбиение сущностей по пакетам
Этот раздел касается упаковки сущностей по бинарным пакетам (.rpm), а не по исходным (.src.rpm). Упаковка сущностей по исходным пакетам может быть произвольной. Помимо очевидного разбиения «пакет на сущность» рекомендуются к использованию следующие варианты:
- Bundled GTK+2 theme: GTK+ engine вместе с GTK+2 theme
- Bundled GNOME theme: Metacity theme вместе с GNOME theme
Не рекомендуется, но допускается в силу имеющейся практики:
- (Bundled) GTK+1/2 theme: GTK+1 theme вместе с GTK+2 theme и, опционально, GTK+ engine
- (Bundled) GTK+/GNOME theme: GTK+2 theme вместе с GNOME theme и, опционально, Metacity theme
Не допускается:
- KDE/XFCE/GTK+/GNOME theme, т.е. любая из тем GTK+ или GNOME, упакованная вместе с темами для других графических сред: такая упаковка делает невозможной простановку зависимостей на компоненты среды и с большой вероятностью приводит к установке ненужных пользователю файлов.
- Любая сущность вместе с Icon theme: Icon theme может использоваться с любой средой, поддерживающей спецификации freedesktop.org, и не связана ни с какой графической библиотекой.
- Другие сочетания, пересекающие границу между GTK+ и GNOME (например, GTK+ engine вместе с GNOME theme).
Каталог %_datadir/themes/<theme_name> может независимо использоваться любой из трёх сущностей: GTK+1 theme, GTK+2 theme и Metacity theme, поэтому должен упаковываться вместе с каждой из них. Возможны исключения, но должно выдерживаться общее правило: при любом сочетании (с учётом зависимостей) установленных пакетов каталог должен принадлежать хотя бы одному пакету.
Именование пакетов
Общее правило: рекомендуется называть пакеты полностью в нижнем регистре, разделяя слова дефисами. Префиксы в единственном числе используются при упаковке одной сущности одного типа (напр., GTK+ theme), во множественном — при упаковке нескольких сущностей одного типа. Примеры: gnome-theme-long-name, libgtk-engines-default.
Пакеты различных типов должны иметь следующие префиксы в названиях:
- GTK+ engine — libgtk-engine-;
- GTK+1 theme — gtk1-theme-;
- GTK+2 theme, Bundled GTK+2 theme — gtk2-theme-;
- GTK+1/2 theme — gtk-theme-;
- Metacity theme — metacity-theme-;
- Icon theme — icon-theme- (не gnome-icon-theme, поскольку те же темы можно использовать не только в GNOME, см. выше);
- GNOME theme, Bundled GNOME theme, (Bundled) GTK+/GNOME theme — gnome-theme-;
Зависимости пакетов
Общие правила:
- Рекомендуется указанные ниже Requires-зависимости всегда указывать. В некоторых случаях указанные зависимости могут этим же пакетом и предоставляться, тогда разрешается опускать Requires-зависимость.
- Указанные зависимости всегда должны корректно разрешаться apt'ом. Из этого следует, в частности, что если пакет, содержащий указанную сущность, не предоставляет требующиеся ей зависимости, он должен сам требовать их.
В соответствии с типом попадающих в пакет сущностей, должны быть проставлены следующие зависимости:
- GTK+ engine: Requires: libgtk+2 (проставляется автоматически как зависимость на соответствующую библиотеку в пакете; явным образом проставлять ничего не нужно);
- GTK+1 theme: Requires: gtk+;
- GTK+2 theme: Requires: libgtk-engine-<name> (возможно, не один; требуемые engines берутся из файла gtk-2.0/gtkrc поиском слова engine);
- Metacity theme: Requires: metacity (не metacity-gnome и не libmetacity), Provides: metacity-theme;
- Icon theme не имеет специальных зависимостей;
- GNOME theme: Requires: libgnome (не gnome-control-center);
Bundled темы должны содержать Provides тех компонент, которые в себя включают. Например, если в gnome-theme-myprecious содержится тема для Metacity, в этом пакете должны быть: Provides: metacity-theme-myprecious metacity-theme и Requires: metacity libgnome
При упаковке нескольких сущностей в один пакет зависимости объединяются.