Localization

From den4b Wiki
Revision as of 13:27, 25 August 2014 by Den4b (talk | contribs) (→‎Create new translations: X-Language-Name for conflicting situations)
Jump to navigation Jump to search

This article describes localization (translation) of applications into different languages. Please study this material carefully before attempting to contribute.

Products which currently support this new method for localization are:

Note: Previous versions of localization articles are available for reference, but they should no longer be used: Localization Old 2013, Localization Old 2014.

Translation files

Translations are stored in PO files (as produced by gettext) are are distributed together with the application, inside Languages folder:

  • Languages\Application.poTemplate file.
  • Languages\Application.ru.poRussian (RU) translation file.
  • Languages\Application.es.poSpanish (ES) translation file.
  • Languages\Application.fr.poFrench (FR) translation file.
  • ...

Template file (Application.po) is used for creating translations for new languages and normally should not be edited.

Translation files (Application.XX.po) contain translated text. A two-letter language code in the file extension identifies a particular language.

Create new translations

To create a translation file for a new language:

  1. Create a copy of Application.po (template file)
  2. Rename it to Application.XX.po (translation file), where XX is a two-letter language code.
  3. Translate entries to the new langauge using instructions below.
  4. Populate PO file headers, copy from any other translation file and modify appropriately.

Example of relevant entries in PO file headers for a new translation file:

msgid ""
msgstr ""
...
"Language: ru\n"
"X-Country: ru\n"
"X-Country-Name: Russia\n"
"X-Language-Name: Russian\n"
"X-Language-Name-Native: Русский\n"
"X-Translators: Your Name\n"
...
  • Language codes are defined in ISO 639-1
  • Country codes are defined in ISO 3166-1 alpha-2.
  • In conflicting and ambiguous situations:
    1. Name the translation file using Application.XX_YY.po format, where XX is a language code and YY is a country code.
    2. Set X-Language-Name header to highlight the difference between translations.
    For example: "en_US" code for English (United States), "en_GB" code for English (United Kingdom).

Editing translation file

The process involves translation of individual textual messages to create a mapping from original text to a different language.

Translation files (*.po) should be edited with specifically designed translation tools:

Notes for advanced users:

  • Translation files could also be edited manually using a text editor, but this is highly discouraged as tiny mistakes can result in corruption of the entire file.
  • Poedit forcefully wraps long entries causing "noise" in diffs, so PO files need to be cleaned via msgcat --no-wrap before committing. [1].

Guidelines for translators

Guidelines for translators:

  • Try not the exceed the length of the translated text, comparing to the length of the original text.
    Some components may not fit longer text, so it is better to make it shorter rather than longer.
  • Beware of the special formatting, symbols and placeholders, e.g. "\n", "%s", "%d".
    Make sure to maintain such formatting, translate only actual words.
  • If you don't have a good translation for some text, just leave those blank.
    Other people may be able to fill in the blanks later.

Attribution to the translator:

  • Add your name to "X-Translators:" field in PO file headers.
  • Please keep names of other translators (separate multiple names with a comma).

Loading specific language

All available language files are automatically added to the "Languages" menu on startup. Select a desired language and restart the application.

When selected language is set to "Autodetect" mode:

  • Application automatically tries to recognize system language and loads appropriate translation file.
  • It is also possible to load a specific language file, by either:
    1. Adding "--lang XX" command line parameters to the application, where XX is a two-letter language code.
    2. Setting "LANG" environmental variable to a two-letter language code.

Publishing your translation

Please send new and updated translation files via email, as attachments.

The email address can be found in the About dialog of every application.