Fluajho

For program version 1.3

“Fluajho” (with jh as in pleasure) means fluid in Esperanto. It is a simple sf2 soundfont host/player for Linux. Behind the scenes the Fluidsynth library is at work, hence the name.

Why does Fluajho exist? There are many soundfont players for Linux, most of them even based on Fluidsynth. Fluajho was written for a clearly defined use case: Load an .sf2 in the Non Session Manager and save the soundfont in the session directory. This makes it possible to archive the session, for example as a backup or to share it.

Workflow summary: Load an .sf2 file by the file menu or drag and drop. You can then choose one instrument for each of the 16 MIDI-channels by using the GUI or via midi signals. Connect external sequencers or midi devices to play the instruments.

This README is just a short introduction. Consult the manual (see below) for more information.

Contact and Information

Installation and Starting

Download

Release Version

If the latest release is not available through your package manger you can build it yourself: Download the latest code release on https://www.laborejo.org/downloads and extract it.

Git Version

It is possible to clone a git repository.

git clone --recurse-submodules https://laborejo.org/fluajho.git

If you want to update at a later date you must use

git pull --recurse-submodules

Dependencies

Build Dependencies

Environment:

Build

./configure --prefix=/usr/local
make
sudo make install

Starting

There are multiple ways to run Fluajho which should give you the flexibility to configure your system as you want.

We make no distinction if you installed Fluajho yourself or through the distributions package-manager.

The differences are: With or without NSM, with or without sound, installed or from the source dir.

Installed with Non Session Manager (recommended)

Starting Fluajho through the Non Session Manager after you installed fluajho system-wide is the recommended and only supported way. Start non-session-manager and load or create a new session. Then use the button “Add Client to Session” and type in fluajho. It should appear with an icon in the list and open its GUI.

Installed without NSM

If you start fluajho directly it will present you with a dialog to choose your session directory.

You can also start fluajho from a terminal (or create a starter script).

fluajho --save DIRECTORY

Uses the given directory to save. The dir will be created or loaded from if already present. Use the applications file menu to save (Ctrl+s).

You can use this to load and save the files from an existing NSM session. If you create a new directory you can copy it manually to an NSM session directory, but that requires renaming the directory to append the unique ID provided by NSM.

Sending SIGUSR1 to the program in this mode will trigger a save.

Closing through your window manager in this mode will actually quit the application without a prompt to save changes.

From source directory

You can run Fluajho after extracting the release archive or cloning from git, without installation.

Calfbox

“Calfbox” is the name of our internal realtime midi/audio python module.

From source directory with NSM

The developer uses this way to develop and use the software, so it will always be as stable as the compiled version. But it is a bit less performant than building and installing it.

After extracting the release archive create a symlink from fluajho into your PATH. e.g. /usr/bin or ~/bin, if that exists on your system.

If you compiled without installing you can also symlink to ./fluajho.bin

From source dir without NSM

Use ./fluajho --save (see above). If you compiled without installing you can also run ./fluajho.bin

No NSM, no Make, No Sound

Combining the above options you can start the program directly after unpacking or cloning from git:

./fluajho --save /tmp --mute

Or even shorter:

./fluajho -s /tmp -m

This is the minimal run mode which is only useful for testing and development. But if you only want to look at the GUI and are not in the mood to install anything -including dependencies-, go ahead.