Translation system

This document is a work in progress. There are many open questions remaining, but should serve as a roadmap for the direction we wish to take the translation system

Goals

  • Simple, flexible, open
  • Same workflow regardless of project; NVDA, add-ons, or other projects.

High level process

  • A registered project uses gettext tools to create a *.pot file.
    • The latest version of this file is hosted at a fixed URL.
  • On the translation repo, via a cron scheduled GitHub Action, the *.pot files get downloaded, merged, and committed (to the translation repo).
  • Translators use the translation repo to provide translations.
  • On the project repo, via a cron scheduled GitHub Action, the *.po files get downloaded, committed to the project repo.

Repositories

  • Should the "registration" data and the translation files live in the same repo?
  • All repositories will be hosted on GitHub under the NV Access account.

Project registration

Add the project information to a json file in this repository:

  • URL of the project. Typically, a GitHub URL. EG Github.com/nvaccess/nvda.
    • This is useful for communicating with the project. Translators can create issues / discussions to ask about strings used in the project.
  • POT file URL: This should always point to the most recent POT file. Ideas:
    • Have a l10n (localization) branch. GitHub actions will generate a POT file which will be committed back to this branch.
      • This allows the author to have ultimate control (by merging too/from this branch).
      • Control over when code should become translatable, or incorporate completed translations.
      • Control over which branches should be the source or destination for translations.
      • Docs and guides for this will be available.
      • Example URL: github.com/nvaccess/nvda/tree/l10n/source/locale/nvda.pot
    • Use gitHub actions, save pot file as a workflow artifact?
    • Upload as an artifact for a 'l10n' release?

POT file creation

The PO (Portable Object) Template file, containing the source strings to be translated must be created by the project. Projects will be responsible for building this POT file. A GitHub action created that can be used by add-ons to generate the POT file.

Translators

  • A 'translations' repo will host all the po / pot files.
  • Tools can be provided to
    • Understand what is new to translate for a particular language.
    • Handle the git commands, including creating the PR.
  • Translations contributed back via PR
    • It will run automated checks, auto merged on pass.
    • Feedback via GitHub's notification/email system if there are errors with the file format etc.

Notes

  • The current translation system has support for Txt2Tags (t2t) files. These are a source of complexity in the translation system. To simplify, all t2t files will be converted to a format that has support for the gettext system.
    • A strategy to keep old translations of the t2t files will need to be given careful consideration.