No edit summary |
(describe most common find_lang options & rework the example) |
||
(One intermediate revision by one other user not shown) | |||
Line 1: | Line 1: | ||
== Handling Locale Files == | == Handling Locale Files == | ||
Translation files may be handled by different programs for different frameworks. Make sure you BuildRequire the correct package or else your package could fail to generate translation files in the buildroot. | |||
If the package uses gettext for translations, add | If the package uses gettext for translations, add | ||
Line 5: | Line 7: | ||
BuildRequires: gettext | BuildRequires: gettext | ||
</pre> | </pre> | ||
For Qt-based packages | For Qt-based packages that use the Linguist tool chain, for the localisation utilities add | ||
<pre> | |||
BuildRequires: qt-devel | |||
</pre> | |||
Fedora includes an rpm macro called <code>%find_lang</code>. This macro will locate all of the locale files that belong to your package (by name), and put this list in a file. You can then use that file to include all of the locales. <code>%find_lang</code> should be run in the %install section of your spec file, after all of the files have been installed into the buildroot. The correct syntax for <code>%find_lang</code> is usually: | Fedora includes an rpm macro called <code>%find_lang</code>. This macro will locate all of the locale files that belong to your package (by name), and put this list in a file. You can then use that file to include all of the locales. <code>%find_lang</code> should be run in the %install section of your spec file, after all of the files have been installed into the buildroot. The correct syntax for <code>%find_lang</code> is usually: | ||
Line 13: | Line 17: | ||
%find_lang %{name} | %find_lang %{name} | ||
</pre> | </pre> | ||
In some cases, the application may use a different "name" for its locales. You may have to look at the locale files and see what they are named. If they are named <code>myapp.mo</code>, then you will need to pass <code>myapp</code> to <code>%find_lang</code> instead of <code>%{name</code> | In some cases, the application may use a different "name" for its locales. You may have to look at the locale files and see what they are named. If they are named <code>myapp.mo</code>, then you will need to pass <code>myapp</code> to <code>%find_lang</code> instead of <code>%{name}</code>. | ||
After <code>%find_lang</code> is run, it will generate a file in the active directory (by default, the top level of the source dir). This file will be named based on what you passed as the option to the <code>%find_lang</code> macro. Usually, it will be named <code>%{name}.lang</code>. You should then use this file in the <code>%files</code> list to include the locales detected by <code>%find_lang</code>. To do this, you should include it with the -f parameter to <code>%files</code>. | After <code>%find_lang</code> is run, it will generate a file in the active directory (by default, the top level of the source dir). This file will be named based on what you passed as the option to the <code>%find_lang</code> macro. Usually, it will be named <code>%{name}.lang</code>. You should then use this file in the <code>%files</code> list to include the locales detected by <code>%find_lang</code>. To do this, you should include it with the -f parameter to <code>%files</code>. | ||
<pre> | <pre> | ||
Line 20: | Line 24: | ||
... | ... | ||
</pre> | </pre> | ||
Note that <code>%find_lang</code> by default searches for gettext locales, but it can also handle Qt translations, localised manpages and help files. | |||
To process GNOME help files put into <code>/usr/share/gnome/help/</code> use | |||
<pre> | |||
%find_lang %{name} --with-gnome | |||
</pre> | |||
To process KDE help files put into <code>/usr/share/doc/HTML/</code> use | |||
<pre> | |||
%find_lang %{name} --with-kde | |||
</pre> | |||
To process Qt's <code>.qm</code> binary translation files use | |||
<pre> | |||
%find_lang %{name} --with-qt | |||
</pre> | |||
To process localised manpages (doesn't include the default, non-localised one), use | |||
<pre> | <pre> | ||
%find_lang %{name} --with-man | |||
</pre> | |||
To see all the options, run <code>/usr/lib/rpm/find-lang.sh</code> in the terminal. | |||
Names different from <code>%{name}</code> (e.g. multiple manpages) must be handled via separate calls to <code>%find_lang</code>. | |||
Here is an example of proper usage of <code>%find_lang</code>, in <code>foo.spec</code> with the "foo" application localised using gettext and man pages named "bar" instead of "foo": | |||
<pre> | |||
Name: foo | |||
... | ... | ||
%prep | %prep | ||
Line 36: | Line 66: | ||
make DESTDIR=%{buildroot} install | make DESTDIR=%{buildroot} install | ||
%find_lang %{name} | %find_lang %{name} | ||
%find_lang bar --with-man | |||
%files -f %{name}.lang | %files -f %{name}.lang -f bar.lang | ||
%doc LICENSE README | %doc LICENSE README | ||
%{_bindir}/ | %{_bindir}/%{name} | ||
%{_mandir}/man1/bar.1.gz | |||
%changelog | %changelog | ||
* Fri Jan 13 2012 Karel Volny <kvolny@redhat.com> 0.1-2 | |||
- add man pages example | |||
* Thu May 4 2006 Tom "spot" Callaway <tcallawa@redhat.com> 0.1-1 | * Thu May 4 2006 Tom "spot" Callaway <tcallawa@redhat.com> 0.1-1 | ||
- sample spec that uses %%find_lang | - sample spec that uses %%find_lang | ||
</pre> | </pre> | ||
[[Category:Packaging guidelines drafts]] | [[Category:Packaging guidelines drafts]] |
Latest revision as of 11:56, 13 January 2012
Handling Locale Files
Translation files may be handled by different programs for different frameworks. Make sure you BuildRequire the correct package or else your package could fail to generate translation files in the buildroot.
If the package uses gettext for translations, add
BuildRequires: gettext
For Qt-based packages that use the Linguist tool chain, for the localisation utilities add
BuildRequires: qt-devel
Fedora includes an rpm macro called %find_lang
. This macro will locate all of the locale files that belong to your package (by name), and put this list in a file. You can then use that file to include all of the locales. %find_lang
should be run in the %install section of your spec file, after all of the files have been installed into the buildroot. The correct syntax for %find_lang
is usually:
%find_lang %{name}
In some cases, the application may use a different "name" for its locales. You may have to look at the locale files and see what they are named. If they are named myapp.mo
, then you will need to pass myapp
to %find_lang
instead of %{name}
.
After %find_lang
is run, it will generate a file in the active directory (by default, the top level of the source dir). This file will be named based on what you passed as the option to the %find_lang
macro. Usually, it will be named %{name}.lang
. You should then use this file in the %files
list to include the locales detected by %find_lang
. To do this, you should include it with the -f parameter to %files
.
%files -f %{name}.lang %{_bindir}/foobar ...
Note that %find_lang
by default searches for gettext locales, but it can also handle Qt translations, localised manpages and help files.
To process GNOME help files put into /usr/share/gnome/help/
use
%find_lang %{name} --with-gnome
To process KDE help files put into /usr/share/doc/HTML/
use
%find_lang %{name} --with-kde
To process Qt's .qm
binary translation files use
%find_lang %{name} --with-qt
To process localised manpages (doesn't include the default, non-localised one), use
%find_lang %{name} --with-man
To see all the options, run /usr/lib/rpm/find-lang.sh
in the terminal.
Names different from %{name}
(e.g. multiple manpages) must be handled via separate calls to %find_lang
.
Here is an example of proper usage of %find_lang
, in foo.spec
with the "foo" application localised using gettext and man pages named "bar" instead of "foo":
Name: foo ... %prep %setup -q %build %configure --with-cheese make %{?_smp_mflags} %install make DESTDIR=%{buildroot} install %find_lang %{name} %find_lang bar --with-man %files -f %{name}.lang -f bar.lang %doc LICENSE README %{_bindir}/%{name} %{_mandir}/man1/bar.1.gz %changelog * Fri Jan 13 2012 Karel Volny <kvolny@redhat.com> 0.1-2 - add man pages example * Thu May 4 2006 Tom "spot" Callaway <tcallawa@redhat.com> 0.1-1 - sample spec that uses %%find_lang