-
-
Notifications
You must be signed in to change notification settings - Fork 131
Translation
As of October 2020 the LXQt Project uses again an Weblate instance for translations. We are working on a solution that include desktop files too on the same platform. Potential translators should choose Weblate as the preferred translation tool.
Local translations using QtLinguist are possible downloading and uploading *.ts files using the Weblate platform.
Direct Pull Requests to Github for *.ts files are still possible but not recommended as they can lead to merge conflicts.
Create an account on translate.lxqt-project.org or login with your existing Github, Ubuntu, Fedora or OpenSuse account. It is also possible to add suggestions for strings without having any account. The LXQt Project is split up in 3 groups:
- LXQt-Desktop: Contains applications and main components.
- LXQt-Configuration: Groups all configuration settings.
- LXQt-Panel: Translations for the panel and its plugins.
There can be selected watched projects, preferred languages, email notifications and else in the account's profile settings. Please note that for adding language files that are not already present contacting administrators is needed.
Those are comprised in distinct components' repositories like the one of PCManFM-Qt where they reside in a folder "translations". Translations are handled by snippets like pcmanfm-qt_de.desktop.yaml comprising nothing but the respective translation.
All of the *.desktop.yaml
files are now handled in LXQt Weblate ("Menu Entry").
-
Name=
: Name displayed in the menu, runner and pcmanfm-qt/applications -
GenericName
: Tooltip in the menu, explanation in runner -
Comment
: is used as tooltip only ifGenericName=
andGenericName[xy]=
are both absent in/usr/share/applications/foo.desktop
.
It is still possible to edit desktop entry files forking the repository, using an text editor and making a Pull Request but it is not recommended.
The names and descriptions of the panel plugins are *.desktop.yaml files in /lxqt/lxqt-panel/plugin-foo/translations/
.
Translations for two menu categories are *.directory.yaml files in /lxqt-panel/menu/translations/
.
Credits for translations (displayed in LXQt-About) can be inserted in lxqt/lxqt-about/tree/master/translatorsinfo/translators_XY.info by forking the and making a PR.
The Qt translation framework allows for distinguishing language from country specific translations which does have some implications that should get considered by translators.
Language specific translations are meant to cover a language independently from a particular country. Corresponding files feature a single double-digit lower-case code referring to the language only like "pt" in lxqt-panel_pt.ts
for Portuguese.
Country specific translations are meant to address a language variant that's spoken in a particular country only. Corresponding files feature an additional double-digit code in capital letters referring to a particular country like "BR" in lxqt-panel_pt_BR.ts
for Brazil.
Either way the code(s) have to be reflected in the TS files' headers as well like
<TS version="2.1" language="pt">
.
or
<TS version="2.1" language="pt_BR">
This can get handled by Qt Linguist, too (menu Edit
- Translation File Settings
).
Frequently these aren't needed at all. E. g. German gets spoken in several countries and plenty of differences exist. But these do not affect the technical terms used by LXQt in any way.
In Portuguese many of the technical terms used by LXQt are different in Brazil or Portugal, though. Corresponding country specific variants are hence needed.
So first of all a translator should think about the need of country specific translations. Questions can be asked in [Discussions[(https://github.com/lxqt/lxqt/discussions) and so be discussed with other native speakers.
If country specific translations aren't needed a single language specific translation like de
will do (and the next paragraph doesn't matter any longer).
The locale used by a running system as indicated by the output of $ locale
on Linux will be country specific most of the time like in this example
$ locale
LANG=de_DE.UTF-8
LC_CTYPE="de_DE.UTF-8"
LC_NUMERIC="de_DE.UTF-8"
[...]
Note the string de_*DE*
. The encoding, usually UTF-8
nowadays, frequently ISO-8859-1
earlier, doesn't matter in this context.
It is important to note that country specific translations are only used when a system's locale is set to the same country.
E. g. a Portuguese translation pt_BR
is only used when a running system's locale is pt_BR
, too. This translation does not get used if the system's locale is pt_PT
(Portugal).
This means that no Portuguese translation is used at all should a system's locale be set to pt_PT
and pt_BR
be the only Portuguese translation that's available.
Language specific files will always be used as fallback.
E. g. if two translations pt_BR
and pt
are available and a system's locale is set to pt_PT
translation pt
will be used.
As a consequence a country agnostic translation like pt
should be provided even if country specific translations are basically needed as long as not all of them are available yet.
This should be done in order to have a fallback as depicted above. It's still better to use a translation that eventually doesn't fit the country of a running system's locale than no translation at all resulting in an English GUI.
For most LXQt repositories on GitHub, a webhook is configured so that the Weblate server receives notifications about new commits of a repository from GitHub. Weblate will rebase local commits on top of the latest upstream (GitHub) commit.
However, from time to time, rebase failed for various reasons.
Rebase failures can be fixed by logging onto the server via SSH and fix commits with the git
command.
The Weblate documentation also mentions the wlc
command line tool, but I haven't not tried it out yet.
Here are steps about fixing failures via SSH:
-
ssh [email protected]
(ask stefonarch or yan12125 for SSH access) -
cd data/vcs/<git path>
. Here the git path can be checked from the Repository containing Weblate translations field on the Repository Maintenance page on the Weblate website. For example, on https://translate.lxqt-project.org/projects/lxqt-configuration/lxqt-admin-user-menu-entry/#repository, it is shown that the git path islxqt-configuration/lxqt-admin-user
. Note that for linked components, the git path can be different from the URL. - Resolve rebase failures (needs more explanation)
- Hit the Rebase button on the Repository Maintenance page, and the Weblate component (as long as linked ones) will be unlocked.
- Login to LXQtBot GitHub account and regenerate a token
- Update
GITHUB_TOKEN =
line in~/settings.py
andoauth_token:
line in~/.config/hub
- Restart the Weblate service by
sudo systemctl reload celery-weblate.service
Installation Introduction
Binary packages
Building from source
Third party apps
General
Launching LXQt sessions
Window Managers
Wayland Session
Screensavers/Lockers
Setting Locale
Miscellaneous
Theming
PCManFm-Qt
Reporting bugs
Translation
Contributing code
Admin tools
Maintaining a good new dev experience
Tarballs
TODO for Wayland
Infrastructure Fellows