This github repository was made by developers who had seen that the project on sourceforge was no longer being maintained. The founder of Tuxguitar had not answered any questions and his website containing developer information and download links was offline.
With some effort, we were able to build tuxguitar for different operating systems and now (beginning of 2024) we can tell how to setup the SWT project in Eclipse in a Linux environment. The information shown here is subject to change as development progresses. This is a starting point.
-
General: To contribute, you need nothing more than to enjoy opensource and do the community a favor.
-
Developer: As a developer, there may be features you wish the software had and want to add them yourself. Or you have discovered a bug and know how to fix it.
-
Writer: It's always good to have people around who can express themselves well and are able to write easy-to-read documentation. A warm welcome.
-
Translator: You speak a language other than English, or several of them? There's always something to be done in this area.
-
Commentator: Do you enjoy communicating with others? Liven up our discussions and collect answers to frequently asked questions. Make first contact with participants of our discussions and keep them happy.
In order to get in contact with other contributors just use the github discussion functionality.
You do no need to have any development skills to contribute - below are a few examples of what you can provide to the community.
Work-in-progress snapshots are published quite frequently, see releases. Try to always use the most recent snapshot, and create an issue if you find a bug. Before creating a new issue, take care that it does not already exist. Make sure to include the following information in issue's description:
- the version of the app, e.g. "2024-01-01-snapshot"
- the operating system and its version, e.g. "Windows 11", or "Ubuntu 22.04"
- the variant of the app: SWT or JFX for desktop app
- the detailed sequence of actions leading to the bug
- a description of both the observed behavior and the behavior you expected.
Don't hesitate to include screenshots or short videos to help understanding. If the bug occurs for one specific tablature file, please attach it as a zipped file in the issue's description.
Basically: all information enabling us to reproduce the issue is welcome.
Your work is not over once you have created an issue: stay tuned and check the issue's status regularly, we may have questions for you that need answered before a fix can be implemented.
TuxGuitar is available in many languages, but yours may be missing. We also regularly add new features and, therefore, new text strings to translate. Finally, not all translations are exhaustive. There's always work to do.
Translation files are available:
- here for main application (desktop and Android)
- there for plugins: tuner, batch file converter, jack and pdf export
Other translation files specific to Android are present, these are derived from the files above.
The easiest way to update one translation is probably to open the English "messages.properties" file and the corresponding file for your language side by side. Those files can be edited with any standard text editor. Every line starting with a "#" character will be ignored and corresponding message will be displayed in English. To translate a string: add the translated text after the "=" sign, remove the leading "# " and you're done.
You do not need to follow all steps described in this document to submit an updated translation. Just use the standard github process.
A feature you would really love is currently missing? You can create a dedicated issue. In this case, use "Feature request" in the issue's description, and try to provide a precise description of your desired feature. Stay tuned, we might have questions for you before trying to implement something.
Please remember that this project is maintained by volunteers only, so some requests may not be implemented and most will take time. Be patient and polite when making or responding to requests.
TuxGuitar provides Android and desktop applications.
- files specific to Android application are located in android folder
- files specific to desktop applications are located in desktop folder
- files common to Android and desktop applications are located in common folder.
TODO: this section needs to be completed. Android project can be opened with Android studio. It is located here: android/build-scripts/tuxguitar-android.
TuxGuitar is available in different flavors:
- platform: FreeBSD, Linux (.tar.gz), Linux (.deb), MacOS, Windows (standalone version), Windows (installable version)
- ui framework: SWT, JavaFX
Note: only the SWT variants are included in the official releases, JavaFX variants support is not guaranteed.
Application is essentially developed in Java, however some native modules can also include parts developed in another language (e.g. C). Application is built using Maven. For detailed build instructions please refer to install.md file.
For each {platform, ui framework} couple, one Maven project is defined in a pom.xml
file. All Maven projects are located in desktop/build-scripts folder. Each pom file defines all the successive build steps.
Note: It should be possible to build TuxGuitar also on some other architectures, but only x86_64 architecture is supported in this repo.
If you want to implement one feature request or to fix an issue, mention it explicitly in issue's discussion, so that others do not try to address it in parallel.
To submit a contribution, follow the github guidelines and create a pull request. Take care to squash
your commits before submitting a pull request, except if there is a good reason not to do so (intermediate development commits have a low added value in master's history). If your pull request implements or fixes an issue, make this explicit in pull request's description (e.g. "should fix issue #xxx").
We will now focus on the developer role and show our suggested method to easily clone the repository, install necessary tooling, import the project and finally import, build and run the Linux/SWT configuration. Normally, you will not need more than 30 minutes.
This walkthrough assumes that you will be using the Eclipse Development Environment and a Unix based system. You're welcome to use another environment or OS, but instructions will not be provided.
Eclipse supports many processes around software projects, even writing documentation in markdown. For information about downloading and installing it see https://eclipse.org. Our examples and screenshots here are from Eclipse Version 2023-12.
Important note: this section still needs to be completed. Known limitations:
- this procedure does not enable to build the native modules in Eclipse. Therefore, before sending a pull request it is highly recommended to build the application as defined in install.md, that is with
-P native-modules
option active. - this procedure does not enable to include the native modules and associated plugins in debug configuration
Because you do not have rights to push to this repository directly, you must first fork this repo to create a space for you to make your edits, then create a pull request once your changes are complete. If your pull request is accepted, it will be merged in a future version of the software. See the instructions on forking a repository from GitHub.
We assume, that you have started Eclipse and setup an Eclipse workspace. Open the git perspective and click on "Clone a git repository". In the next dialog select "Clone URI" and click next. Fill in the form with the data of your repository. Here you can see an example setup.
In the next step you will probably only see the master branch. It has to been checked. Click next.
As a last step you have to choose where on your local drive the repo should be placed. In my case, I created a folder named "git" in my Eclipse workspace.
After you finished you will see a percent value showing the progress of the local copy. Once this background job has finished, you will see the structure of your local repository. Something like this:
In order to build the SWT variant of TuxGuitar, you have to import the maven project in question. To do so, open the Java perspective and go to File->Import and choose Maven->Existing Maven Projects. You have to import the swt project you will find in your local git repository, e.g. "..../eclipse-workspace/git/tuxguitar/desktop/build-scripts/tuxguitar-linux-swt"
Once finished, you'll see the package explorer containing all the packages needed for a build.
To have all foreign packages in your Eclipse workspace, create a folder named "externals" and download/install the SWT package. The process is the same for installing, but here, it's all done in the Eclipse workspace. If you don't already have Maven installed, open the Eclipse workspace terminal.
eclipse-workspace$ sudo apt install maven
eclipse-workspace$ mkdir externals
eclipse-workspace$ cd externals
eclipse-workspace$ wget https://archive.eclipse.org/eclipse/downloads/drops4/R-4.21-202109060500/swt-4.21-gtk-linux-x86_64.zip
eclipse-workspace/externals$ mkdir swt-4.21-gtk-linux-x86_64
eclipse-workspace/externals$ cd swt-4.21-gtk-linux-x86_64
eclipse-workspace/externals$ unzip ../swt-4.21-gtk-linux-x86_64.zip
eclipse-workspace/externals$ mvn install:install-file -Dfile=swt.jar -DgroupId=org.eclipse.swt -DartifactId=org.eclipse.swt.gtk.linux -Dpackaging=jar -Dversion=4.21
Go to Menu Run->Run Configurations..., right-click on "Maven Build", select "New Configuration" and give your configuration a name.
In Main tab, Base Directory section, click on "Workspace" and browse to "tuxguitar-linux-swt".
In Goals field, type clean verify
:
Then, at the bottom-right click Apply, then Run. After a short delay (a few tens of seconds) you should see "BUILD SUCCESS".
Note: this section is still work-in-progress. Its objective is to re-create a debug environment as close as possible to the real application.
In real application, all dependencies are stored in different folders during the build process, as defined by the pom.xml
file:
.jar
files for the different modules - except plugins - are stored inlib
folder.jar
files for plugins are stored inshare/plugins
folder- other dependencies (help files, translations, skins, configuration files, etc.) are stored in subfolders of
share
folder
Path to lib
folder is provided to the Java environment by a classpath
argument in the command line. Path to share
folder is provided to TuxGuitar by a -Dtuxguitar.share.path
argument in the command line. Installation folder is also provided by a command line argument: -Dtuxguitar.home.path
.
Procedure described in this section aims at recreating a similar environment for the debug configuration.
Go to Menu Run->Debug Configurations..., right-click on "Java Application", select "New Configuration" and give your configuration a name. In Main tab, Project section, click on "Browse..." and select "tuxguitar". In Main class section, click on "Search..." and select "TGMainSingleton - org.herac.tuxguitar.app":
In "Arguments" tab, "VM arguments" section, type:
-Dtuxguitar.share.path="(path to your tuxguitar source folder)/desktop/build-scripts/tuxguitar-linux-swt/target/tuxguitar-9.99-SNAPSHOT-linux-swt/share/"
-Dtuxguitar.home.path=="(path to your tuxguitar source folder)/desktop/build-scripts/tuxguitar-linux-swt/target/tuxguitar-9.99-SNAPSHOT-linux-swt/"
Take care to customize these field considering your path to tuxguitar source folder. Example:
Note: take care, in screenshot above the full content of "VM arguments" field is not visible (need to scroll down to see -Dtuxguitar.home.path
parameter).
In Dependencies tab, Classpath Entries, delete both "tuxguitar" and "Maven Dependencies" items.
Then, click on "Add External JARs...", browse to folder tuxguitar/desktop/build-scripts/tuxguitar-linux-swt/target/tuxguitar-9.99-SNAPSHOT-linux-swt/lib/
, and select all files. Screenshot below does not show the complete list of jar files (truncated).
Then, at the bottom-right click Apply, then Debug.
Congratulations. You can now build, run and debug Tuxguitar SWT.