Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update unsupported languages in Weblate #6156

Closed
eloquence opened this issue Oct 28, 2021 · 8 comments · Fixed by #6646
Closed

Update unsupported languages in Weblate #6156

eloquence opened this issue Oct 28, 2021 · 8 comments · Fixed by #6646
Assignees
Labels
i18n Anything related to translation or internationalization of SecureDrop

Comments

@eloquence
Copy link
Member

Compare:

It looks like the unsupported languages haven't been updated in a while, which means that translators will see outdated information, and won't see new strings at all. That in turn seems to make it impossible for an unsupported language to become supported by achieving 100% translation.

@cfm
Copy link
Member

cfm commented Oct 28, 2021

@eloquence and I discussed this as a candidate for a future sprint, to determine whether this is a bug, a process glitch in the internationalization procedures, or merely an unintended behavior of the i18n_tool.py translate-messages command used to generate the .po[t]s pushed to Weblate. (Note that freedomofpress/securedrop-client#1317 will investigate deferring the .pot.po update to Weblate itself, which might relieve i18n_tool.py of having to limit this operation to SUPPORTED_LANGUAGES only.)

@cfm cfm added the i18n Anything related to translation or internationalization of SecureDrop label Oct 28, 2021
@cfm
Copy link
Member

cfm commented Mar 24, 2022

@deeplow reports that this is blocking translation of PT_pt, now that we've disambiguated it from PT. PT_br is a supported_language; PT_pt is not. I'll nominate this for attention in the next sprint, to give it plenty of lead time before the next translation cycle for v2.4.0.

@cfm cfm self-assigned this Mar 31, 2022
@cfm
Copy link
Member

cfm commented Apr 6, 2022

Tl;dr: We need to, and unless I'm missing something we do not, distinguish between:

  1. languages open for translation in Weblate; and
  2. languages supported for selection in securedrop-admin sdconfig.

Findings: We have three kinds of "supported" "languages" for four different stages of the localization process:

  1. i18n_tool.I18NTool.supported_languages are those for which i18n_tool.py update-from-weblate will fetch translations from Weblate.
  2. securedrop/translations/$LANG are those that i18n_tool.py translate-messages will:
    1. --extract-update from .py.pot.po; and
    2. --compile from .po to .mo.
  3. securedrop/translations/$LANG are also those that securedrop-admin sdconfig will allow admins to configure as...
  4. SUPPORTED_LOCALES are those that the Source and Journalist interfaces will allow users to select.

(2)(1) is what keeps a language in sync in Weblate. In our current workflow and tooling, we can't enable (2) without first doing (1). Doing (2) also enables (3). Therefore, adding a new $LANG via i18n_tool.py must be completed within a single release cycle, so that $LANG can be fully supported at least to (3), if not all the way to (4).

If we want to add or update $LANG outside of a release cycle, we can cheat by manually:

  1. running i18n_tool.py update-from-weblate --supported-languages $LANG to get its current messages.po;
  2. running i18n_tool.py translate --extract-update to update $LANG's messages.po against the current branch;
  3. importing that messages.po into Weblate to allow up-to-date translation (select Replace existing translation file); and then
  4. exporting that messages.po from Weblate, committing it to securedrop, and adding $LANG to i18n_tool.I18NTool.supported_languages as part of the string-freeze procedure for the next release cycle.

From then on it's available for translation, configuration, and selection like any other language.

Since there's been a specific request for pt_PT, tomorrow I'll use it as a test case for extra- (non-) release process. Weblate will commit its changes only to securedrop-i18n, so they will be safely reverted at the next string freeze if we don't affirmatively choose to keep them via this (or some other, better!) process. :-)

@cfm
Copy link
Member

cfm commented Apr 6, 2022

This procedure worked well enough to sync pt_PT in weblate-sandbox and then in weblate. I've updated #6156 (comment) to reflect that the Replace existing translation file option is the way to get Weblate to accept the new strings merged in (via i18n_too.py translate-messages) with the old (from i18n_tool.py update-from-weblate).

I'm adding this ticket to the v2.4.0 milestone just for visibility to that release's Localization Manager, who can evaluate translation coverage for pt_PT and decide whether to include it as a supported language. (Likewise for any other languages we might choose to sync up this way.)

Now: this is cumbersome. If we plan to move securedrop to continuous localization anytime soon, that will enable Weblate to pick up source-string changes for all translations automatically. Otherwise, we should consider adopting just a part of that workflow, the weblate.gettext.msgmerge add-on, to see if it can obsolete that portion of i18n_tool.py translate-messages.

I'll also file a companion ticket to freedomofpress/securedrop-client#1438, which is the complement to this problem. There, we have languages being translated that we don't yet want to support; here, we have languages that can't yet be translated because we don't support them.

@cfm cfm added this to the 2.4.0 milestone Apr 6, 2022
cfm added a commit that referenced this issue May 6, 2022
Per #6156, include pt_PT as a supported language during the v2.4.0
translation period.  Revert this commit before merging translations into
"develop" if this translation doesn't reach adequate coverage to be
included in this release.
@cfm
Copy link
Member

cfm commented May 24, 2022

This did the trick to include pt_PT in v2.4.0. Now that we've proven the hypothesis with a specific real-world case, I'm bumping this ticket to v2.5.0, where together with #6387 it will let us solve the general "language lifecycle" story.

@cfm
Copy link
Member

cfm commented Sep 22, 2022

Dropping from the v2.5.0 milestone, since this will be completed during that release and localization cycle with #6557.

@Matthaiks
Copy link
Contributor

Could you add Polish as a supported language?

@cfm
Copy link
Member

cfm commented Nov 29, 2022

Thanks for the request, @Matthaiks! We're planning (#6592) to have a policy for adding new supported languages in our v2.6.0 release. Polish looks like a promising candidate for support, so I'll make sure we consider it specifically.

cfm added a commit that referenced this issue Jun 12, 2023
This is the result of "make translate"[1].  After #6156 and the v2.5.0
localization cycle, this updates ununsupported as well as supported
languages---thus the large diff.

[1]: https://developers.securedrop.org/en/latest/i18n.html#update-strings-to-be-translated
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
i18n Anything related to translation or internationalization of SecureDrop
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants