Skip to content
Cameron White edited this page Nov 21, 2024 · 5 revisions

Pinta is available in around 60 languages, so it's important that user-visible strings can be translated. Pinta uses gettext and the NGettext C# implementation for internationalization.

Obtaining a Translated String

To obtain a translation of a string, call Translations.GetString (e.g. Translations.GetString ("My String")). It is important that this is also done for format strings (e.g. Translations.GetString ("My name is {0}", "Bob")) since grammar rules can be different in other languages. Note that string interpolation is not supported, so format strings must be used instead!

If you need to provide some additional information to translators about the meaning of the string or the context where it is used, add a comment in the preceding line that begins with Translators: . This will be auto-detected (see below) and made available to translators.

Where Are Translations Stored?

The translation template (po/messages.pot) contains a list of all of the translatable strings in Pinta. This is auto-generated by running make updatepotfiles and then make updatepot, which searches for calls to Translations.GetString ().

If you're submitting a pull request that involves adding new strings, you can run make updatepot first to update the translation template immediately. The translation template is also automatically updated every week.

The translation template is synced to Pinta's translation site, which provides an interface for translators to submit translations for those strings. Later, the updated translation files are automatically sent back to Pinta's repository via a pull request.