Gtk Gnome Themes Policy: различия между версиями
(Import from freesource.info) |
((AlexeyRusakov) Обновил страницу после переноса с freesource.info. Можно предлагать в качестве полиси :)) |
||
Строка 1: | Строка 1: | ||
[[Category:Policy]] | [[Category:Policy]] | ||
== Упаковка тем GTK+ и GNOME == | == Упаковка тем GTK+ и GNOME == | ||
Строка 6: | Строка 5: | ||
=== Определения === | === Определения === | ||
#'''GTK+ engine''': файл <tt>%_libdir/gtk-2.0/*/engines/lib<engine_name>.so</tt></li> | |||
#'''GTK+1 theme''': каталог <tt>%_datadir/themes/<theme_name>/gtk</tt> и его содержимое</li> | |||
#'''GTK+2 theme''': каталог <tt>%_datadir/themes/<theme_name>/gtk-2.0</tt> и его содержимое</li><br /><br /> | |||
#'''Metacity theme''': каталог <tt>%_datadir/themes/<theme_name>/metacity-*</tt> и его содержимое</li> | |||
#'''Icon theme''': каталог <tt>%_iconsdir/<theme_name></tt> и его содержимое</li> | |||
#'''GNOME theme''': файл <tt>%_datadir/themes/<theme_name>/index.theme</tt></li> | |||
=== Разбиение сущностей по пакетам === | === Разбиение сущностей по пакетам === | ||
Этот раздел касается упаковки сущностей по бинарным пакетам (.rpm), а не по исходным (.src.rpm). Упаковка сущностей по исходным пакетам может быть произвольной. | Этот раздел касается упаковки сущностей по бинарным пакетам (.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''). | |||
Каталог <tt>%_datadir/themes/<theme_name></tt> может независимо использоваться любой из трёх сущностей: ''GTK+1 theme'', ''GTK+2 theme'' и ''Metacity theme'', поэтому должен упаковываться вместе с каждой из них. Возможны исключения, но должно выдерживаться общее правило: при любом сочетании (с учётом зависимостей) установленных пакетов каталог должен принадлежать хотя бы одному пакету. | Каталог <tt>%_datadir/themes/<theme_name></tt> может независимо использоваться любой из трёх сущностей: ''GTK+1 theme'', ''GTK+2 theme'' и ''Metacity theme'', поэтому должен упаковываться вместе с каждой из них. Возможны исключения, но должно выдерживаться общее правило: при любом сочетании (с учётом зависимостей) установленных пакетов каталог должен принадлежать хотя бы одному пакету. | ||
Строка 33: | Строка 31: | ||
Пакеты различных типов должны иметь следующие префиксы в названиях: | Пакеты различных типов должны иметь следующие префиксы в названиях: | ||
* ''GTK+ engine'' — <tt>libgtk-engine-</tt>; | |||
* ''GTK+1 theme'' — <tt>gtk1-theme-</tt>; | |||
* ''GTK+2 theme'', ''Bundled GTK+2 theme'' — <tt>gtk2-theme-</tt>; | |||
* ''GTK+1/2 theme'' — <tt>gtk-theme-</tt>; | |||
* ''Metacity theme'' — <tt>metacity-theme-</tt>; | |||
* ''Icon theme'' — <tt>icon-theme-</tt> (не <tt>gnome-icon-theme</tt>, поскольку те же темы можно использовать не только в GNOME, см. выше); | |||
* ''GNOME theme'', ''Bundled GNOME theme'', ''(Bundled) GTK+/GNOME theme'' — <tt>gnome-theme-</tt>; | |||
=== Зависимости пакетов === | === Зависимости пакетов === | ||
Строка 47: | Строка 45: | ||
В соответствии с типом попадающих в пакет ''сущностей'', должны быть проставлены следующие зависимости: | В соответствии с типом попадающих в пакет ''сущностей'', должны быть проставлены следующие зависимости: | ||
* ''GTK+ engine'': <tt>Requires: libgtk+2</tt> (проставляется автоматически как зависимость на соответствующую библиотеку в пакете; <u>явным образом проставлять ничего не нужно</u>); | |||
* ''GTK+1 theme'': <tt>Requires: gtk+</tt>; | |||
* ''GTK+2 theme'': <tt>Requires: libgtk-engine-<name></tt> (возможно, не один; требуемые engines берутся из файла <tt>gtk-2.0/gtkrc</tt> поиском слова <tt>engine</tt>); | |||
* ''Metacity theme'': <tt>Requires: metacity</tt> (не <tt>metacity-gnome</tt> и не <tt>libmetacity</tt>), <tt>Provides: metacity-theme = %version-%release</tt>; | |||
* ''Icon theme'' не имеет специальных зависимостей; | |||
* ''GNOME theme'': <tt>Requires: libgnome</tt> (не <tt>gnome-control-center</tt>); | |||
При упаковке нескольких сущностей в один пакет зависимости объединяются. | При упаковке нескольких сущностей в один пакет зависимости объединяются. |
Версия от 11:37, 11 августа 2008
Упаковка тем 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-;
Зависимости пакетов
Общие правила: 1. Рекомендуется указанные ниже Requires-зависимости всегда указывать. В некоторых случаях указанные зависимости могут этим же пакетом и предоставляться, тогда разрешается опускать Requires-зависимость. 2. Указанные зависимости всегда должны корректно разрешаться 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 = %version-%release;
- Icon theme не имеет специальных зависимостей;
- GNOME theme: Requires: libgnome (не gnome-control-center);
При упаковке нескольких сущностей в один пакет зависимости объединяются.