At present, you can translate the tutorial and the Qt GUI, only.
Translations for the tutorial are located in
etc/doc/tutorial
.
Translations for the Qt GUI are located in
app/gui/qt/lang/sonic-pi_<LANG>.ts
.
The i18n code is disabled right now. If you want to enable it to test
your translation, set the required constants in main.cpp
(ENABLE_I18N
) and qt-doc.rb
(enable_i18n
).
- Sign up with github
- Fork the Sonic Pi repo
to your own github repo,
git clone
it to your computer cd etc/doc/tutorial
- Want to add a new language to the tutorial? Then copy the
en/
folder and add the new files to your repo withgit add <NEWLANG>/*.md
- When you're happy,
git commit
,git push
to your github repo. - Send a pull request to the Sonic Pi repo.
- Sign up with github
- Fork the Sonic Pi repo
to your own github repo,
git clone
it to your computer - Build Sonic Pi, first the server extensions, then the Qt GUI.
cd app/gui/qt
- Want to add a new language to the Qt GUI? Then first add a reference
to the new language file to
SonicPi.Pro
andSonicPi.qrc
, then runlupdate -pro SonicPi.pro
to have the new .ts file created for you. - Edit the translation with Qt Linguist,
linguist lang/sonic-pi_<LANG>.ts
. - Build a new binary, test it.
- When you're happy,
git add
if you added a new language, thengit commit
,git push
to your github repo. - Send a pull request to the Sonic Pi repo.
Messages you want to have translated need to be marked with tr()
in the source.
If you added or changed a translation string during development,
don't forget to run lupdate -pro SonicPi.pro
afterwards to update
the .ts
files.
Then push them back to github and ask the translators to pull and translate them.
(The translation workflow will hopefully become much easier once Transifex is integrated.)
- Transifex integration