A PO editor is needed to edit translation files. This example uses editors/poedit.
# pkg install poedit
Chapter 9. PO Translations
Table of Contents
9.1. Introduction
The GNU gettext system offers translators an easy way to create and maintain translations of documents. Translatable strings are extracted from the original document into a PO (Portable Object) file. Translated versions of the strings are entered with a separate editor. The strings can be used directly or built into a complete translated version of the original document.
9.2. Quick Start
The procedure shown in Quick Start is assumed to have already been performed.
The TRANSLATOR
option is required and already enabled by default in the textproc/docproj port.
This example shows the creation of a Spanish translation of the short Leap Seconds article.
When a new translation is first created, the directory structure must be created or copied from the English original:
Create a directory for the new translation. The English article source is in ~/doc/documentation/content/en/articles/leap-seconds/. The Spanish translation will go in ~/doc/documentation/content/es/articles/leap-seconds/. The path is the same except for the name of the language directory. The English article source is in ~/doc/en/articles/leap-seconds/. The Spanish translation will go in ~/doc/es/articles/leap-seconds/. The path is the same except for the name of the language directory.
% mkdir ~/doc/documentation/content/es/articles/leap-seconds
Copy the _index.po from the original document into the translation directory:
% cp ~/doc/documentation/content/en/articles/leap-seconds/_index.po \ ~/doc/documentation/content/es/articles/leap-seconds/
Suppose the document or language is also being translated via Weblate.
In that case, it is good to get the .po
file from there and upload the translation document back into the platform, centralizing the translating efforts via Weblate to avoid rework.
See how to download the .po
files in the Translating Offline on Weblate chapter.
Use a PO editor to enter translations in the PO file. There are several different editors available. poedit from editors/poedit is shown here.
% poedit documentation/content/es/articles/leap-seconds/_index.po
Generate the translated document:
% cd ~/doc % ./tools/translate.sh documentation es articles/leap-seconds
The name of the generated document matches the name of the English original, usually _index.adoc.
Check the generated file by rendering it to HTML and viewing it with a web browser:
% cd ~/doc/documentation % make
9.3. Creating New Translations
The first step to creating a new translated document is locating or creating a directory to hold it. FreeBSD puts translated documents in a subdirectory named for their language and region in the format lang. lang is a two-character lowercase code.
Language | Region | Translated Directory Name |
---|---|---|
English | United States | en |
Bengali | Bangladesh | bn-bd |
Danish | Denmark | da |
German | Germany | de |
Greek | Greece | el |
Spanish | Spain | es |
French | France | fr |
Hungarian | Hungary | hu |
Italian | Italy | it |
Japanese | Japan | ja |
Korean | Korea | ko |
Mongolian | Mongolia | mn |
Dutch | Netherlands | nl |
Polish | Poland | pl |
Portuguese | Brazil | pt-br |
Russian | Russia | ru |
Turkish | Turkey | tr |
Chinese | China | zh-cn |
Chinese | Taiwan | zh-tw |
The translations are in subdirectories of the main documentation directory, here assumed to be ~/doc/documentation/ as shown in Quick Start. For example, German translations are located in ~/doc/documentation/content/de/, and French translations are in ~/doc/documentation/content/fr/.
Each language directory contains separate subdirectories named for the type of documents, usually articles/ and books/.
Combining these directory names gives the complete path to an article or book. For example, the French translation of the NanoBSD article is in ~/doc/documentation/content/fr/articles/nanobsd/, and the Mongolian translation of the Handbook is in ~/doc/documentation/content/mn/books/handbook/.
A new language directory must be created when translating a document to a new language. If the language directory already exists, only a subdirectory in the articles/ or books/ directory is needed.
Create a new Spanish translation of the Porter’s Handbook. The original is a book in ~/doc/documentation/content/en/books/porters-handbook/.
The Spanish language books directory ~/doc/documentation/content/es/books/ already exists, so only a new subdirectory for the Porter’s Handbook is needed:
% cd ~/doc/documentation/content/es/books % mkdir porters-handbook
Copy the content from the original book:
% cd porters-handbook % cp -R ~/doc/documentation/content/en/books/porters-handbook/* .
Now the document structure is ready for the translator to begin translating with
po4a
command.
9.4. Translating
The gettext system greatly reduces the number of things that must be tracked by a translator. Strings to be translated are extracted from the original document into a PO file. Then a PO editor is used to enter the translated versions of each string.
The FreeBSD PO translation system does not overwrite PO files, so the extraction step can be run at any time to update the PO file.
A PO editor is used to edit the file. editors/poedit is shown in these examples because it is simple and has minimal requirements. Other PO editors offer features to make the job of translating easier. The Ports Collection offers several of these editors, including devel/gtranslator.
It is important to preserve the PO file. It contains all of the work that translators have done.
Translating documents online proves to be the easiest method for document translation on FreeBSD, as it allows multiple users to collaborate on the same file, distributing the workload effectively. For more details, please refer to the next chapter, Weblate Translations. |
9.5. Tips for Translators
9.5.1. Preserving AsciiDoc macros
Preserve AsciiDoc macros that are shown in the English original.
English original:
msgid "" "This example shows the creation of a Spanish translation of the short " "extref:{leap-seconds}[Leap Seconds] article."
Spanish translation:
msgid "" "Este ejemplo muestra la creación de un artículo con poco contenido como el artículo " "extref:{leap-seconds}[Leap Seconds]."
9.6. Building a Translated Document
A translated version of the original document can be created at any time. Any untranslated portions of the original will be included in English in the resulting document. Most PO editors have an indicator that shows how much of the translation has been completed. This makes it easy for the translator to see when enough strings have been translated to make building the final document worthwhile.
The Weblate chapter provides a complete example of how to Build the Translated Document.
9.7. Submitting the New Translation
Prepare the new translation files for submission. This includes adding the files to the version control system, setting additional properties on them, then creating a diff for submission.
The diff files created by these examples can be attached to a documentation bug report or code review.
Create a diff of the new files from the ~/doc/ base directory so the full path is shown with the filenames. This helps committers identify the target language directory.
% cd ~/doc % git diff documentation/content/es/articles/nanobsd/ > /tmp/es_nanobsd.diff
The Weblate chapter provides a complete example of how to Submit the New Translation.
Last modified on: March 9, 2024 by Danilo G. Baio