pandemonium_engine_docs/03_usage/12_i18n/localization_using_gettext.md

222 lines
7.8 KiB
Markdown
Raw Normal View History

2023-01-12 20:49:14 +01:00
Localization using gettext
==========================
2024-03-16 20:56:52 +01:00
In addition to `doc_importing_translations` in CSV format, Pandemonium
also supports loading translation files written in the GNU gettext
2024-03-16 20:56:52 +01:00
format (text-based `.po` and compiled `.mo` since Pandemonium 3.5).
2023-01-12 20:55:57 +01:00
Note:
For an introduction to gettext, check out
2023-01-12 20:57:31 +01:00
`A Quick Gettext Tutorial ( https://www.labri.fr/perso/fleury/posts/programming/a-quick-gettext-tutorial.html )`.
It's written with C projects in mind, but much of the advice
2024-03-16 20:56:52 +01:00
also applies to Pandemonium (with the exception of `xgettext`).
Advantages
----------
- gettext is a standard format, which can be edited using any text editor
2023-01-12 20:57:31 +01:00
or GUI editors such as `Poedit ( https://poedit.net/ )`.
- gettext is supported by translation platforms such as
2023-01-12 20:57:31 +01:00
`Transifex ( https://www.transifex.com/ )` and `Weblate ( https://weblate.org/ )`,
which makes it easier for people to collaborate to localization.
- Compared to CSV, gettext works better with version control systems like Git,
as each locale has its own messages file.
- Multiline strings are more convenient to edit in gettext files compared
to CSV files.
Disadvantages
-------------
- gettext is a more complex format than CSV and can be harder to grasp for
people new to software localization.
- People who maintain localization files will have to install gettext tools
2024-03-16 20:56:52 +01:00
on their system. However, as Pandemonium supports using text-based message files
2023-01-12 19:43:03 +01:00
(`.po`), translators can test their work without having to install gettext tools.
Caveats
-------
2024-03-16 20:56:52 +01:00
- As Pandemonium uses its own PO file parser behind the scenes
(which is more limited than the reference GNU gettext implementation),
some features such as pluralization aren't supported.
Installing gettext tools
------------------------
The command line gettext tools are required to perform maintenance operations,
such as updating message files. Therefore, it's strongly recommended to
install them.
- **Windows:** Download an installer from
2023-01-12 20:57:31 +01:00
`this page ( https://mlocati.github.io/articles/gettext-iconv-windows.html )`.
Any architecture and binary type (shared or static) works;
if in doubt, choose the 64-bit static installer.
2023-01-12 20:57:31 +01:00
- **macOS:** Install gettext either using `Homebrew ( https://brew.sh/ )`
2023-01-12 19:43:03 +01:00
with the `brew install gettext` command, or using
2023-01-12 20:57:31 +01:00
`MacPorts ( https://www.macports.org/ )` with the
2023-01-12 19:43:03 +01:00
`sudo port install gettext` command.
- **Linux:** On most distributions, install the `gettext` package from
your distribution's package manager.
Creating the PO template (POT) manually
---------------------------------------
2024-03-16 20:56:52 +01:00
Pandemonium currently doesn't support extracting source strings using `xgettext`,
2023-01-12 19:43:03 +01:00
so the `.pot` file must be created manually. This file can be placed anywhere
in the project directory, but it's recommended to keep it in a subdirectory, as
each locale will be defined in its own file.
Create a directory named `locale` in the project directory. In this directory,
2023-01-12 19:43:03 +01:00
save a file named `messages.pot` with the following contents:
2023-01-12 22:00:14 +01:00
```
# Don't remove the two lines below, they're required for gettext to work correctly.
msgid ""
msgstr ""
msgid "Hello world!"
msgstr ""
2023-01-12 22:00:14 +01:00
```
2023-01-12 19:43:03 +01:00
Messages in gettext are made of `msgid` and `msgstr` pairs.
`msgid` is the source string (usually in English), `msgstr` will be
the translated string.
2023-01-12 19:43:03 +01:00
The `msgstr` value in PO template files (`.pot`) should **always** be empty.
Localization will be done in the generated `.po` files instead.
Creating the PO template (POT) using pybabel
--------------------------------------------
2024-03-16 20:56:52 +01:00
The Python tool pybabel has support for Pandemonium and can be used to automatically
create and update the POT file from your scene files and scripts.
2024-03-16 20:56:52 +01:00
After installing `babel` and `babel-pandemonium`, for example using pip:
2023-01-12 22:00:14 +01:00
```
2024-03-16 20:56:52 +01:00
pip3 install babel babel-pandemonium
2023-01-12 22:00:14 +01:00
```
2023-01-12 19:43:03 +01:00
Write a mapping file (for example `babelrc`) which will indicate which files
pybabel needs to process (note that we process GDScript as Python, which is
generally sufficient):
2023-01-12 22:00:14 +01:00
```
[python: **.gd]
encoding = utf-8
2024-03-16 20:56:52 +01:00
[pandemonium_scene: **.tscn]
encoding = utf-8
2023-01-12 22:00:14 +01:00
```
You can then run pybabel like so:
2023-01-12 22:00:14 +01:00
```
2024-03-16 20:56:52 +01:00
pybabel extract -F babelrc -k text -k LineEdit/placeholder_text -k tr -o pandemonium-l10n.pot .
2023-01-12 22:00:14 +01:00
```
2023-01-12 19:43:03 +01:00
Use the `-k` option to specify what needs to be extracted. In this case,
2023-01-12 19:30:47 +01:00
arguments to `tr()` will be translated, as well
as properties named "text" (commonly used by Control nodes) and LineEdit's
"placeholder_text" property.
Creating a messages file from a PO template
-------------------------------------------
2023-01-12 19:43:03 +01:00
The `msginit` command is used to turn a PO template into a messages file.
For instance, to create a French localization file, use the following command
2023-01-12 19:43:03 +01:00
while in the `locale` directory:
2023-01-12 22:00:14 +01:00
```
msginit --no-translator --input=messages.pot --locale=fr
2023-01-12 22:00:14 +01:00
```
2023-01-12 19:43:03 +01:00
The command above will create a file named `fr.po` in the same directory
as the PO template.
Alternatively, you can do that graphically using Poedit, or by uploading the
POT file to your web platform of choice.
2024-03-16 20:56:52 +01:00
Loading a messages file in Pandemonium
--------------------------------
To register a messages file as a translation in a project, open the
**Project Settings**, then go to the **Localization** tab.
2023-01-12 19:43:03 +01:00
In **Translations**, click **Add…** then choose the `.po` or `.mo` file
in the file dialog. The locale will be inferred from the
2023-01-12 20:47:54 +01:00
`"Language: ( code>\n"` property in the messages file.
2023-01-12 20:55:57 +01:00
Note:
See `doc_internationalizing_games` for more information on
2024-03-16 20:56:52 +01:00
importing and testing translations in Pandemonium.
Updating message files to follow the PO template
------------------------------------------------
After updating the PO template, you will have to update message files so
that they contain new strings, while removing strings that are no longer
present in the PO template. This can be done automatically using the
2023-01-12 19:43:03 +01:00
`msgmerge` tool:
2023-01-12 22:00:14 +01:00
```
# The order matters: specify the message file *then* the PO template!
msgmerge --update --backup=none fr.po messages.pot
2023-01-12 22:00:14 +01:00
```
If you want to keep a backup of the original message file (which would be
2023-01-12 19:43:03 +01:00
saved as `fr.po~` in this example), remove the `--backup=none` argument.
2023-01-12 20:55:57 +01:00
Note:
2023-01-12 19:43:03 +01:00
After running `msgmerge`, strings which were modified in the source language
will have a "fuzzy" comment added before them in the `.po` file. This comment
denotes that the translation should be updated to match the new source string,
as the translation will most likely be inaccurate until it's updated.
2024-03-16 20:56:52 +01:00
Strings with "fuzzy" comments will **not** be read by Pandemonium until the
translation is updated and the "fuzzy" comment is removed.
Checking the validity of a PO file or template
----------------------------------------------
It is possible to check whether a gettext file's syntax is valid by running
the command below:
2023-01-12 22:00:14 +01:00
```
msgfmt fr.po --check
2023-01-12 22:00:14 +01:00
```
If there are syntax errors or warnings, they will be displayed in the console.
2023-01-12 19:43:03 +01:00
Otherwise, `msgfmt` won't output anything.
Using binary MO files (useful for large projects only)
------------------------------------------------------
For large projects with several thousands of strings to translate or more,
it can be worth it to use binary (compiled) MO message files instead of text-based
PO files. Binary MO files are smaller and faster to read than the equivalent
PO files.
You can generate a MO file with the command below:
2023-01-12 22:00:14 +01:00
```
msgfmt fr.po --no-hash -o fr.mo
2023-01-12 22:00:14 +01:00
```
2023-01-12 19:43:03 +01:00
If the PO file is valid, this command will create a `fr.mo` file besides
2024-03-16 20:56:52 +01:00
the PO file. This MO file can then be loaded in Pandemonium as described below.
The original PO file should be kept in version control so you can update
your translation in the future. In case you lose the original PO file and
wish to decompile a MO file into a text-based PO file, you can do so with:
2023-01-12 22:00:14 +01:00
```
msgunfmt fr.mo > fr.po
2023-01-12 22:00:14 +01:00
```
The decompiled file will not include comments or fuzzy strings, as these are
never compiled in the MO file in the first place.