Scroll to navigation

PO4A-RUNTIME(7) Po4a Tools PO4A-RUNTIME(7)

名前

po4a-runtime - po4a と Autotools を使用しないランタイム gettext 翻訳

概要

po4a-build を併用することにより po4a は gettext を用いたランタイム出力メッセージの翻訳もサポートしますが、Autotools および標準的な ./configure プロセスを採用する場合には po4a-build パッケージは必要ありません。

サンプルの Makefile コードを用いると、最小限の労力でパッケージから intltool を利用できます。

レイアウト

ドキュメントの翻訳は、ランタイム翻訳と同じ po/ ディレクトリを使用するべきではありません。ランタイム翻訳は po/ と異なるディレクトリを使用できますが、通常この慣習に従っておくのが一番簡単です。

複数の言語

これは、複数のプログラム言語のスクリプトを用いたパッケージという意味です。よくあるのが Perl とシェルの混在です。注意: ファイルの拡張子がほとんど問題のないものである場合を除き、gettext は混乱してしまい、どちらかの言語を取り除いてしまうでしょう。

複数の言語を使用する際、POT ファイルに必要な文字列がすべて取得できるまで、po/Makevars で各種設定を実験してください。

具体的には、po/Makevars に二つの言語を指定すると、問題となる可能性があります。こうしないでください:

 # このようにしてはいけません:
 XGETTEXT_OPTIONS = -L Perl -L Shell --from-code=iso-8859-1

翻訳の対象となる言語の一つについて、その言語の全ファイルの名前を変える (またはシンボリックリンクを作成する) ことか、-L オプション による明示の省略を検討してください。ファイルの拡張子は po/POTFILES.in が処理されている間のみ存在する必要があります。

--keywords オプションも便利です - xgettext(1) のドキュメントをご覧ください。

po/ への移行

つまり、トップレベルの po/ ディレクトリを作成し、/usr/share/doc/po4a/examples/ にあるサンプルファイルを、移動してください。
LINGUAS
空だったとしても存在しなければなりません。翻訳のリストでできており、'#' で始まらない各行は、存在する PO ファイルに一致しなければなりません。例えば、LINGUAS に 'fr' とだけ書かれていれば、fr.po ファイルが LINGUAS ファイルと同じディレクトリになければなりません。

 $ cat po/LINGUAS
 cs
 de
 fr
 $
    

慣例により、LINGUAS ファイルはアルファベット順にソートされていますが、それ手作業です。

POTFILES.in
ランタイム (つまりスクリプト内) で翻訳される必要があるメッセージを持つファイルリストです。トップレベル po/ ディレクトリを使用する場合、パスは po/ ディレクトリそのものではなく、トップレベルディレクトリからの相対パスにしてください。

 $ ls -l
 myscript.pl
 another.pl
 foo/support.pl
 po/
 po/POTFILES.in
 $ cat po/POTFILES.in
 myscript.pl
 another.pl
 foo/support.pl
 $
    

ランタイムの翻訳とドキュメントの翻訳の両方を含むスクリプト (例: ランタイムに gettext を使用し、ドキュメントに埋め込み POD 内容を含む) は、明らかにサポートされるということに注意してください。そのため、po/POTFILES.indoc/po4a-build.conf に、同じファイルがリストされていても問題ありません。

Makevars-perl.example
スクリプトが Perl の場合、このサンプルファイルを po/Makevars としてコピーし、適合するように編集してください。
Makevars-shell.example
スクリプトがシェルの場合、このサンプルファイルを po/Makevars としてコピーし、適合するように編集してください。
po4a-build.make
Copy this example file as po/Makefile - it shouldn't need editing but you may want to keep it updated against /usr/share/doc/po4a/examples/po4a-build.make as it may need to be updated within po4a releases as the underlying intltool support changes (the file itself was generated from another project using Autotools and intltool).

ビルド

これらのスニペットは、最上位の Makefile、または配付のためのソースを準備するために使用する方法のどこかに組み込む必要があります。

 clean:
        $(MAKE) -C po/ clean

 install:
        $(MAKE) -C po/ install DESTDIR=$(DESTDIR)

 dist:
        $(MAKE) -C po/ pot

(Autotools プロジェクトでは、Makefile.am"SUBDIRS"po を追加するだけで、自動的にこうなります)

保守

新しい翻訳を加える際には、po/LINGUAS の編集が必要なので、ランタイムの翻訳は po4a-build とまったく同じように簡単とは言えません。しかしそれは別にして、翻訳の更新は PO ファイルを新しいバージョンに置き換えるだけに過ぎません。

ソースアーカイブを準備する方法に応じて、MANIFEST ファイルに新しい PO ファイルをリストしたり、アーカイブを準備するスクリプトに追加したりする必要があるでしょう。(これは po4a-build にも適用されます)。

po/ にある *.mo*.gmo はすべて削除されます。

著作権

サンプルファイルは po4a プロジェクトの一部ですが、Automake 自体のようなほかのビルドツールと同様に、著作権表示で po4a を参照したり、po4a チームを列挙したりせずに、あなたのプロジェクトで自由に使用、変更、頒布できます。po4a に言及してくださるなら、それもまたすばらしいと思います。

著者

 Neil Williams <linux@codehelp.co.uk>

訳者

 倉澤 望 <nabetaro@debian.or.jp>
 Debian JP Documentation ML <debian-doc@debian.or.jp>
2018-06-02 Po4a Tools