This guide is written to provide instructions from scratch for contributing to the translation of the Jamulus application to other languages.
The code for Jamulus is open source, and is managed and made available via the Github site.
For completeness, this document describes the use both of GitHub (using git
) and of Qt Linguist.
The translator must be able to do the following steps, which will each be explained further down:
- Create their own linked copy ("repository" or "repo") of Jamulus in GitHub. This is called Forking.
- Copy ("clone") their own repository to their computer, using either:
- Command line
git
, or - Github Desktop
- Command line
- Update their own local repo from the upstream master branch.
- Create a local branch to contain the update.
- Use the Qt Linguist tool to edit the appropriate translation (
.ts
) file. - Commit the updated
.ts
file to the branch their own local git repo. - Push the branch from their local repo to their own repo on Github.
- Raise a Pull Request (PR) for the merging of the updated file into the upstream repo by the developers.
This guide contains two main parts:
-
Instructions for getting set up, which only needs to be done once.
-
The workflow for updating and contributing translations as a part of the preparation for a release of Jamulus.
First of all, visit the Github website
If you don't yet have a Github account, click on Sign up to go to the Create Your Account page. Enter:
- Your chosen username. This is a simple word containing letters and, optionally, numbers, and will identify you in the Github world. It is not an email address. This name is represented in the examples below as
yourusername
. - Your email address. This will be used by Github to send you notifications by email, and to identify commits made by you.
- Your chosen password. Do not use the same password as for any other website.
- Solve the puzzle to prove you are human and click Create account.
If you do have a Github account, and are not yet logged in, click on Sign in, and enter your username and password, then Sign in.
Go to the Jamulus repository.
Create your own copy ("fork") of the Jamulus repository by clicking the Fork button at the top right of the page.
If your Github account is also part of an organisation, Github will ask you where to create the fork. Choose your personal Github account.
It will then display the message "Forking jamulussoftware/jamulus", and when finished will display the home page of your own Jamulus repo (yourusername/jamulus).
Linux and Mac machines come with command-line Git tools ready-installed or easily available.
- On Mac, the
git
command is available in/usr/bin/git
, as part of the Xcode package, or can be installed separately (see below). - On Linux, it may be necessary to install the
git
package using one of these commands:- On RedHat or CentOS,
yum install git
ordnf install git
- On Debian or Ubuntu:
apt install git
- On RedHat or CentOS,
- On Windows, Git can be obtained from Git for Windows
More information about installing Git on various systems can be found here
Make a local copy of your Jamulus repo by using git clone
:
- At the shell command-line, navigate to the directory that will be the parent of your
jamulus
development directory. - Give one of the following commands:
- For ssh access:
git clone [email protected]:yourusername/jamulus.git
- For https access:
git clone https://github.com/yourusername/jamulus.git
- For ssh access:
This will create a jamulus
directory. Change to that directory.
- Add the upstream repository:
git remote add upstream https://github.com/jamulussoftware/jamulus.git
- Check the remotes using
git remote -v
. The output should look like this:or this:origin [email protected]:yourusername/jamulus.git (fetch) origin [email protected]:yourusername/jamulus.git (push) upstream https://github.com/jamulussoftware/jamulus.git (fetch) upstream https://github.com/jamulussoftware/jamulus.git (push)
origin https://github.com/yourusername/jamulus.git (fetch) origin https://github.com/yourusername/jamulus.git (push) upstream https://github.com/jamulussoftware/jamulus.git (fetch) upstream https://github.com/jamulussoftware/jamulus.git (push)
Github Desktop is available for macOS 10.10 or later, and Windows 7 64-bit or later. It is not available for 32-bit Windows.
To install Github Desktop, visit the download page and follow the link for the appropriate Operating System.
When downloading for Mac, the instructions suggest opening GitHubDesktop.zip
, but in fact, what was downloaded was GitHubDesktop.app
. This should just be moved from Downloads
to Applications
.
Run Github Desktop, and do the following steps:
- On the Welcome Screen, click on Sign in to GitHub.com
- Sign in by following the instructions. These may vary depending on whether you have logged into Github via a web browser already. If necessary, click on Authorize Desktop.
- Confirm access by entering your Github password.
- for Mac, if the browser requests to open "Github Desktop.app", click Allow.
- In Configure Git, enter your name and email address. These will be used to identify commits you make to Git. Click Continue.
- Agree or decline to submit periodic usage stats, and click Finish.
- Either:
- Select Clone a Repository from the Internet and enter
yourusername/jamulus
, or - Select your own fork of Jamulus from the list (
yourusername/jamulus
) and click the Clone button.
- Select Clone a Repository from the Internet and enter
- Select the Local Path where the project should be stored, and click Clone.
- It will display the page Cloning jamulus with progress indication.
- On completion of cloning, it will ask "How are you planning to use this fork?". Answer "To contribute to the parent project".
Qt Linguist is a part of the Qt development suite, and may either be installed via your Operating System's packaging manager, or by downloading from the Qt Open Source download page. In the latter case you will need to create an account on the Qt website.
Under Linux
- On RedHat or CentOS:
yum install qt5-linguist
ordnf install qt5-linguist
- On Debian or Ubuntu:
apt install qttools5-dev-tools
Instructions for use are in the Qt Linguist Manual
The first step is to get the local repo up to date with the upstream master:
cd projectdir/jamulus
git fetch upstream
This fetches information about the current state of the upstream repo. It is now necessary to apply any upstream changes to the local repo.
As the user will not be updating the master
branch themselves, git rebase
can be used to fast-forward to the current state:
git checkout master
git rebase upstream/master
git push
Finally, create a new branch for the changes that will be done (do not just do them on master
).
The actual name of the branch is not critical, since the branch will be deleted after being merged,
but it's worth choosing a meaningful name:
git checkout -b translate-r3_7_0-german
(The branch name is chosen by the user; the above name translate-r3_7_0-german is an example for the German translation of V3.7.0)
The branch will be used later as the source of a Pull Request.
Select the current repository as jamulus
, and the current branch as master
.
Click on "Fetch origin" to get fully up to date with upstream.
Drop down the "Current Branch" menu and click on the New Branch button. Give the branch a meaningful name such as translate-r3_7_0-german
and click Create Branch.
Do not click on Publish branch just yet.
Open Qt Linguist, and navigate to the directory src/translation
within your project directory.
In this directory are translation source files for each language, each with a .ts
suffix. Don't worry about the .qm
files, as they are compiled when building the release code.
Open the .ts
file for the language being worked on.
Each context in the left-hand column represents a source file or graphical form containing translatable words and phrases ("strings"). The icon beside each shows a green tick if there is nothing further to be done, a yellow tick if a translation needs attention, and a question mark if there are untranslated strings.
After clicking on a Context, the list of strings needing translation is shown, with a green tick beside the ones that have been done. The right-hand pane will show either the source code or the form, so that the usage can be checked, in case this aids the translation.
Strings with a grey tick can be ignored. They are old strings that used to be used but are no longer. They are retained for reference in case they should be used again in the future.
Again, strings with a question mark require translation.
After some or all of the required strings have been translated, the file can be saved.
Once all translations have been done, the branch containing the changes must be commited to your own repo, pushed to Github (origin
) and then a Pull Request raised to the upstream repo.
First, check the current branch with git status
, to make sure it is correct, and then do a commit,
with a commit message describing the change, for example:
git commit -am 'Update German translations for v3.7.0'
Then do a git push
.
It will probably tell you to set the upstream repository for tracking, and conveniently gives the command for copying and pasting:
git push --set-upstream origin translate-r3_7_0-german
Finally, go to the Github website where it will most likely offer a banner saying there is a recent commit and offering to raise a Pull Request. Do so.
Select the current repository as jamulus
, and the branch that was created above, such as translate-r3_7_0-german
.
The changed file(s) should be listed in the left-hand column as src/translation/translation_xx_YY.ts
. When the file is selected, the differences will be displayed in the main panel.
Add a simple commit message in the first box below the file list, (e.g. change "Update filename" to something like "Update German translations for v3.7.0"), and add any extra description in the Description box (optional, probably not required).
Commit the changes to the local git repo by clicking on Commit to .
Click on Publish branch or Push origin. This will push the branch to your own repo on Github. (It will say Publish branch for a new branch, or Push origin if the branch has already been published).
There will now be a section offering Create Pull Request. Click on that to create the PR to the upstream repository.
Other contributors may have edited your files after you began your work, which can cause conflicts. If GitHub or git tells you about conflicts, or if you are requested to rebase your work, do so as follows:
git remote add upstream [email protected]:jamulussoftware/jamulus ;# add the main repo as upstream remote if you didn’t already as mentioned above
git fetch upstream ; # Get the latest changes from the main upstream repo you added before (if needed)
git checkout <theBranchYourWorkIsOn> ;# switch to (= checkout) the branch you want to rebase
git rebase upstream/master ;# replay (=rebase) your changes onto the latest code (and fix conflicts if needed)
git rebase --continue # to continue the rebasing progress after having fixed the conflicts
git push --force # Push the changes to your repo. Be aware that this will overwrite your remote branch!
Thank you for contributing!