moOde audio player - package builder
January 28, 2025 ยท View on GitHub
by bitlab
Package repository hosting is graciously provided by Cloudsmith. Cloudsmith is the only fully hosted, cloud-native, universal package management solution, that enables your organization to create, store and share packages in any format, to any place, with total confidence.
Disclaimer
The software and other materials in this repository are distributed under the GNU GENERAL PUBLIC LICENSE Version 3 which includes the following disclaimer:
- Disclaimer of Warranty.
THERE IS NO WARRANTY FOR THE PROGRAM, TO THE >EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
- Limitation of Liability.
IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
This means that the user of this software is responsible for any damage resulting from its use. It does not matter if the damage is caused by incorrect usage or a bug in the software.
Table of Contents
1. Introduction
This repository contains scripts to build the packages containing the software components used in moOde audio player.
1.1. Origin and build type
There are several ways in which packages are built and sources obtained.
| How | Description | Output |
|---|---|---|
| backport | Download source package | deb+src |
| cargo-deb | Git clone source, generate package from rust project with cargo-deb | deb |
| rebuild | Rebuild from stock package source | deb+src |
| fpm | Git clone source, generate package with FPM | deb |
| git | Clone source, contains debian directory | deb+src |
| git+debsrc | Clone source, use debian dir from older version | deb+src |
| git+dhmake | Clone source and create new package | deb+src |
| stdeb | Git clone source, generate package with stdeb | deb+src |
| stock | No need to build, use stock available | - |
All forms with src as output can be rebuilt from source packages (also present in the repo).
1.2. Overview of the packages that are used
Note: The versions represented in the table are only for example and may not represent the latest versions being used and the table may not contain all the packages in the repo.
| Package | Version | How | Patches* |
|---|---|---|---|
| alsa-cdsp | 1.2.0-1moode1 | git+dh_make | yes |
| alsacap | 1.0.1-1moode1 | git+dh_make | |
| ashuffle | 3.12.5-1moode1 | git+dh_make | |
| bluez | 5.55-3.1+rpt1 | stock | |
| bluez-alsa | 4.2.0-2moode1 | git+debscr | |
| camilladsp | 3.0.0-1moode1 | cargo-deb | |
| camillagui | 3.0.0-1moode3 | fpm | yes |
| camillagui-backend | 1.0.1-1moode1 | - | yes |
| caps | 0.9.26-1moode1 | rebuild | yes |
| libnpupnp2 | 6.2.0-1moode1 | git | |
| librespot | 0.6.0-1moode1 | cargo-deb | |
| libupnpp16 | 0.26.7-1moode1 | git | |
| log2ram | 1.7.2-1moode1 | git | |
| mediainfo | 20.09-1 | stock | |
| minidlna | 1.3.0+dfsg-2 | stock | |
| moode-player | 8.2.5-1moode1 | git+dh_make | |
| mpc | 0.33.1 | stock | |
| mpd | 0.23.12-1moode1 | backport | yes |
| mpd2cdspvolume | 2.0.0-1moode1 | fpm | no |
| nqptp | 1.1.0~git20220930.c71b49a-1moode1 | git+dh_make | |
| pleezer | 0.11-1moode1 | cargo-deb | |
| python3-camilladsp | 3.0.0-1moode1 | stdeb | |
| python3-camilladsp-plot | 3.0.0-1moode1 | stdeb | |
| python3-libupnpp | 0.21.0-1moode1 | git | |
| shairport-sync | 4.3.5-1moode1 | git+debsrc | |
| squeezelite | 1.9.9-1449+git20230814.8581aba-1moode1 | rebuild | yes |
| trx | 0.6-1moode1 | git+dh_make | |
| udisks | 1.0.5-1moode1 | upport | yes |
| udisks-glue | 1.3.5-1moode3 | git+debsrc | |
| upmpdcli | 1.9.0-1moode1 | git |
Patches* means patches required for the source code and excludes patches for the packing itself. Stock pacakges can be directly used, no need to rebuild.
Note: The camillagui-backend is bundled with the camillagui package.
1.3. Other packages in the repo for example drivers.
| Package | Version | How | Patches* | Descriptions |
|---|---|---|---|---|
| aloop | 5.15.84-1moode1 | fpm | yes | 384kHz patch for in tree module |
| ax88179 | 5.6.4.2-1moode1 | git | Patched ax88179_178a driver with Allo SIG suppport. | |
| boss2-oled-p3 | 1.0.0-1moode1 | fpm | Allo Boss2 OLED display service | |
| motu-avb | 1.0-2moode1 | fpm | motu usb driver for the avb (default not installed) | |
| pcm1794a | 5.15.84-1moode1 | fpm | yes | 384kHz patch for in tree module |
| rpi-source | 0.1-1moode1 | git | yes | Fixes to let it work with Python 3. Only needed with development. |
| rtl88xxau | 5.6.4.2-1moode1 | git | Required for SIG Wifi. | |
| runonce | 0.1.0-1moode1 | fpm | service for running scripts once during boot |
2. (Re)building packages
Requirements:
- Pi with Raspbian Lite Bullseye (or a moOde image) installed.
- Have at least a 32GB SD card (or have NFS mount to your NAS)
2.1. Prepare environment
2.1.1. Update the system
Update the system and install the minimal requirement git:
sudo apt update
sudo apt upgrade
sudo apt -y install git
sudo apt reboot
2.1.2. Clone the pkgbuild tree
In this example we use the moodedev directory to store al moode related project dirs.
Setup a build tree:
mkdir -p ~/moodedev/
cd ~.moodedev
git clone https://github.com/moode-player/pkgbuild.git
cd pkgbuild/scripts
2.1.3. Setup environment settings
- Copy the
scripts/setenv.sh.exampletosetenv.sh
cp setenv.sh.example setenv.sh
- Change the content to reflect your settings:
# The var MOODE_DIR refers to the location of the cloned moode source repo
# These commands should be added to ~/.bashrc
export DEBFULLNAME=John
export DEBEMAIL=john@noreply.com
export MOODE_DIR=~/home/pi/mooddev.moode
The latest is the location with the moode player main project it self.
Activate the environment by:
cd ..
. ./scripts/setenv.sh
2.2. Build dependencies
And image below give an overview of most packages. Some packages depends on build and install of others (including dev packages):

2.3. Building a package
Go to a package dir in the subdir packages and run the build.sh script
For test try to build alsacap and aloop.
cd packages/alsacap
./build.sh
The output will be in the dist/binary subdirectory.
All dependencies are automatically installed. The first time this will take a while. Especially the kernel packages.
The kernel packages are build for the current active running kernel and expect an offical released kernel for Raspberry Pi OS.
The only exception to the build process is the moOde player it self. It expect that the moode source tree is checkout out in separate directory and the location is set in the setenv.sh script, before it can be packed by the build script from packages/moode-player/build.sh.
See the build documentation from moode.
2.4. Deploy package and source
There is a helper script that deploys packages to a Cloudsmith package repository. This requires a Cloudsmith account with access to the moOde repository.
2.4.1. Install Cloudsmith tooling
sudo apt install python3-pip
pip install --upgrade cloudsmith-cli
This will ask your credentials(you need to have permission to upload to the moOde CS repo) to generate an API key.
Logout now and start the ssh session again.
2.4.2. Upload the package
After a package has been built run the deploy command.
cd packages/alsacap
../../scripts/deploy.sh alsacap_1.0.1