A classical music player and organizer. https://musicus.org
Find a file
2020-05-13 18:22:39 +02:00
client client: Allow changing email and password seperately 2020-05-13 16:01:04 +02:00
common Tracks editor: Leave parts empty if not set 2020-05-13 18:13:13 +02:00
database database: Adapt to moor 3.0.0 2020-05-03 22:18:41 +02:00
mobile mobile: Don't update position if not playing 2020-05-13 18:22:39 +02:00
player Rename top level directories 2020-04-24 21:55:17 +02:00
server server: Add README.md with API documentation draft 2020-05-13 16:57:27 +02:00
COPYING Initial commit 2019-12-02 21:05:49 +01:00
README.md Move reusable code from mobile to common 2020-05-04 21:49:44 +02:00

Musicus

The classical music player and organizer.

https://musicus.org

Project structure

The top level directories contain the main Musicus packages, of which some depend on other ones. All packages are written in Dart.

database A Database of classical music. This package will be used by all standalone Musicus applications for storing classical music metadata.

server A simple http server hosting a Musicus database. The server is developed using the Aqueduct framework.

client A client library for the Musicus server.

common Common building blocks for Musicus client apps. This includes shared UI and backend code for the mobile app and the (future) desktop app.

mobile The Musicus mobile app. It is being developed using Flutter toolkit and only runs on Android for now.

player The simplest possible audio player plugin. This is used by the mobile app for playback.

Hacking

Picking up Dart as a programming language and Flutter as an UI toolkit should be relatively straight forward. You can visit this page to get started with Flutter. After cloning the Musicus repository, it works best to work at its subcomponents one at a time. I recommend VS Code for editing. Please contact me via e-mail (see my profile), if you have any questions or need help. I'm also open to ideas for the future of Musicus! Please use the issue tracker for them.

You can use the following command to automatically update generated code while working on Musicus:

flutter pub run build_runner watch

License

Musicus is free and open source software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

Musicus is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details.

You should have received a copy of the GNU Affero General Public License along with this program. If not, see https://www.gnu.org/licenses/.