Skip to content

dmotte/ui24rsc

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ย 

History

38 Commits
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 

Repository files navigation

ui24rsc

device

GitHub main workflow PyPI

๐Ÿ Ui24R Snapshot Converter.

The official Soundcraft Ui24R JSON snapshot export format is very hard to understand and work with; thus, manually editing mixer snapshots from code can be extremely uncomfortable. This Python script lets you convert snapshots exported from the mixer Web UI to other more human-readable formats and vice versa. It can read/write both JSON and YAML documents.

Note: this project is specific for Soundcraft JSON snapshot format, a.k.a. "Offline Files". It does not handle .uisnapshot files.

Important: this has been tested with the firmware version 3.3.8293-ui24.

Installation

This utility is available as a Python package on PyPI:

python3 -mpip install ui24rsc

Usage

The first parameter of this command is ACTIONS, a comma-separated sequence of operations which will be used in order to process the input document and produce the output. See the code for more information on what each action does.

This is a basic example of how to convert from official Soundcraft JSON format to a custom tree-like, human-friendly, differential YAML format:

python3 -mui24rsc diff,tree original.json human-friendly.yml

And the opposite is:

python3 -mui24rsc dots,full human-friendly.yml official.json

For more details on how to use this command, you can also refer to its help message (--help).

Development

If you want to contribute to this project, you can install the package in editable mode:

python3 -mpip install -e . --user

This will just link the package to the original location, basically meaning any changes to the original package would reflect directly in your environment (source).

If you want to run the tests, you'll have to install the pytest package and then run:

python3 -mpytest test

Other useful stuff

The default-init.yml file was built by exporting the * Init * snapshot (from the Default show of the Soundcraft Ui24R), which should contain the mixer factory default settings, and then executing the following command:

python3 -mui24rsc tree,sort default-init.json default-init.yml

If you want to check that the two files are equivalent, you can install jq on your PC and then run:

diff <(jq --sort-keys < default-init.json) <(python3 -mui24rsc dots default-init.yml | jq --sort-keys)

In general, if you want to see the differences between two snapshot files in different formats, you can use the following command:

diff <(jq --sort-keys < snapshot01.json) <(python3 -mui24rsc dots,full snapshot01.yml | jq --sort-keys)