A classical music player and organizer. https://musicus.org
Find a file
2025-08-10 12:13:00 +02:00
.github/workflows Fix release-flatpak.yaml 2025-05-02 16:07:30 +02:00
data Remove unused SearchTag 2025-08-10 12:13:00 +02:00
flatpak flatpak: Use LLVM 20 2025-08-09 10:43:53 +02:00
migrations Support metadata updates 2025-04-27 16:52:08 +02:00
po window: Inhibit system suspend during playback 2025-05-30 15:31:25 +02:00
src Remove unused SearchTag 2025-08-10 12:13:00 +02:00
.gitignore Add config.rs to .gitignore 2025-02-09 10:08:17 +01:00
Cargo.lock Use LazyLock instead of lazy_static 2025-05-09 13:25:14 +02:00
Cargo.toml Use LazyLock instead of lazy_static 2025-05-09 13:25:14 +02:00
COPYING Initial commit 2025-02-09 10:05:00 +01:00
diesel.toml Add original database code 2025-02-09 10:07:53 +01:00
meson.build Support metadata updates 2025-04-27 16:52:08 +02:00
meson_options.txt Update build system and Flatpak manifest 2025-02-09 10:08:21 +01:00
README.md Update README 2025-05-02 15:51:01 +02:00

Musicus Logo

Musicus

Introduction

Musicus is a classical music player and organizer designed for the GNOME platform. It helps you manage your personal collection of classical music recordings. Musicus also comes with a pre-made sample library of public domain recordings, which you can use as a starting point or to test the application.

The following features make Musicus special:

  • Combination of library management, search and playback
  • Metadata handling optimized for classical music
  • Intelligent random playback with customizable programs
  • Built-in sample library for just listening to music right-away
  • Local-first, no cloud or account required

Please note that Musicus will not be ready for everyone until version 1.0 is released. Before then, the format of the music library may change, which could result in permanent data loss. Do not use the Musicus library as your primary music collection!

Screenshot

Hacking

ORM

This program uses Diesel as its ORM. After installing the Diesel command line utility, you will be able to create a new schema migration using the following command:

$ diesel migration generate [change_description]

To update the src/db/schema.rs file, you should use the following command:

$ diesel migration run --database-url test.sqlite

This file should never be edited manually.

Internationalization

Execute the following commands from the project root directory to update translation files whenever translatable strings have been changed.

  1. Update po/POTFILES

    cat <<EOF > po/POTFILES
    data/de.johrpan.Musicus.desktop.in.in
    data/de.johrpan.Musicus.gschema.xml.in
    EOF
    
    find data/ui -name "*.blp" >> po/POTFILES
    find src -name "*.rs" -a ! -name "config.rs" >> po/POTFILES
    
  2. Update po/template.pot

    xgettext \
        --from-code=UTF-8 \
        --add-comments \
        --keyword=_ \
        --keyword=C_:1c,2 \
        --files-from=po/POTFILES \
        --output=po/template.pot
    
  3. Update translation files

    msgmerge \
        --update \
        --backup=off \
        --no-fuzzy-matching \
        po/de.po \
        po/template.pot