2016-01-25 22:44:23 +00:00
|
|
|
RnsUtils
|
|
|
|
========
|
|
|
|
|
|
|
|
RnsUtils is Renoise related library and companion utility.
|
|
|
|
It is meant for developers aiming to use generate renoise
|
2016-02-02 11:29:05 +00:00
|
|
|
file or renoise users wanting to convert SoundFont 2 or SFZ to
|
|
|
|
renoise instruments, reencode instruments to .flac or .ogg,
|
|
|
|
manipulate tags and comments in instuments.
|
2016-01-25 22:44:23 +00:00
|
|
|
|
|
|
|
Installation
|
|
|
|
------------
|
|
|
|
|
|
|
|
RnsUtils is installable from PyPI with a single pip command::
|
|
|
|
|
|
|
|
pip install rnsutils
|
|
|
|
|
|
|
|
Alternatively, RnsUtils can be run directly from sources after a git pull::
|
|
|
|
|
|
|
|
git clone https://gitlab.com/zeograd/rnsutils.git
|
|
|
|
cd rnsutils && python setup.py install
|
|
|
|
|
|
|
|
|
2016-01-31 23:03:45 +00:00
|
|
|
sf2toxrni
|
2016-01-25 22:44:23 +00:00
|
|
|
---------
|
|
|
|
|
2016-01-27 22:52:41 +00:00
|
|
|
**sf2toxrni** is a command line utility which convert SoundFont 2 instruments into renoise instruments (.xrni).
|
|
|
|
It parses a SoundFont 2 file instrument list and generate one .xnri file for each instrument using as much information
|
|
|
|
from the SoundFont 2 instrument properties (generators) as possible. All read properties will be injected in a template
|
|
|
|
renoise instrument.
|
|
|
|
|
|
|
|
::
|
|
|
|
|
|
|
|
usage: sf2toxrni [-h] [-d] [-q] [-u] [--no-unused] [-o OUTPUT_DIR]
|
|
|
|
[-t TEMPLATE]
|
|
|
|
sf2_filename
|
|
|
|
|
|
|
|
GPL v3+ 2016 Olivier Jolly
|
|
|
|
|
|
|
|
positional arguments:
|
|
|
|
sf2_filename input file in SoundFont2 format
|
|
|
|
|
|
|
|
optional arguments:
|
|
|
|
-h, --help show this help message and exit
|
|
|
|
-d, --debug debug parsing [default: False]
|
|
|
|
-q, --quiet quiet operation [default: False]
|
|
|
|
-u, --unused show unused generators [default: True]
|
|
|
|
--no-unused
|
|
|
|
-o OUTPUT_DIR, --ouput-dir OUTPUT_DIR
|
|
|
|
output directory [default: current directory]
|
|
|
|
-t TEMPLATE template filename [default: empty-31.xrni]
|
|
|
|
|
|
|
|
Convert sf2 file into renoise instrument
|
|
|
|
|
|
|
|
|
|
|
|
Use the *-o* option to specify a destination directory and *--no-unused* if you don't want to see the list of generators
|
|
|
|
which are present in the SoundFont 2 file but were not used in generating the .xnri.
|
|
|
|
|
|
|
|
*-t* allows to change the template .xnri, one is provided by default and works with renoise 3.1 at least. If you want
|
|
|
|
different default settings or generate instruments for a different version, you can provide a template of your own
|
|
|
|
and specify its filename. If the filename is not found on the filesystem, it will be looked up in the default
|
|
|
|
data patch for the python package.
|
|
|
|
If you want to provide your own template, it must follow the recommendations of the following section.
|
|
|
|
|
|
|
|
template
|
|
|
|
........
|
|
|
|
|
|
|
|
A template .xnri file will be used to have Soundfont 2 properties injected to produce a final, customized .xnri file.
|
|
|
|
It must contains at least one sample. The first sample will be used as template for all samples, others will be discarded.
|
|
|
|
The first sample must have an ADHSR modulation on volume and the filter set to a Low pass filter.
|
|
|
|
SoundFont 2 reverb and chorus effects will be mapped respectively on macro 1 and macro 2, so you may want to map those macros
|
|
|
|
on input of DSP chains to control the dry/wet amount of those effects.
|
|
|
|
You may use macro 3 and up to your liking.
|
|
|
|
|
|
|
|
compliance and limitations
|
|
|
|
..........................
|
|
|
|
|
|
|
|
The set of features found in a SoundFont 2 and .xnri doesn't fully overlap, hence this converter won't produce
|
|
|
|
a bit wise exact instrument.
|
|
|
|
First, SoundFont 2 files contains presets, which are mapped to one or more instruments. Those presets might alter how
|
|
|
|
the instruments sound, but it's a bad practice and usually only map keys range to instruments. This converter works
|
|
|
|
from SoundFont 2 instruments only.
|
|
|
|
|
|
|
|
**sf2toxrni** supports :
|
|
|
|
* envelope volume release
|
|
|
|
* sample panning
|
|
|
|
* sample looping
|
|
|
|
* sample tuning (base note, fine and coarse tuning)
|
|
|
|
* key mapping
|
|
|
|
* velocity mapping
|
|
|
|
* low pass filter cutoff
|
|
|
|
* chorus amount
|
|
|
|
* reverb amount
|
|
|
|
|
|
|
|
**sf2toxrni** does not support :
|
|
|
|
* vibrato
|
|
|
|
* initial volume attenuation (always minus infinite in result, it seems like it'd be a pita to support otherwise)
|
2016-01-25 22:44:23 +00:00
|
|
|
|
2016-01-31 23:03:45 +00:00
|
|
|
sfztoxrni
|
|
|
|
---------
|
|
|
|
|
|
|
|
Similarly to the **sf2toxrni** converter, **sfztoxrni** convert SFZ files into renoise instruments (.xrni).
|
|
|
|
Renoise supporting now natively SFZ files, this converter is only useful on SFZ instruments needing
|
|
|
|
more than one modulation set (different ADHSR settings depending on the velocity/key mapping) or
|
|
|
|
a more aggressive sample filename search (like for SFZ built under case insensitive filesystem and read in
|
|
|
|
case sensitive filesystem). As SFZ support in Renoise will progress, this converter will be deprecated.
|
|
|
|
|
|
|
|
::
|
|
|
|
|
|
|
|
usage: sfztoxrni [-h] [-d] [-e {none,flac,ogg}] [-q] [-o OUTPUT_DIR]
|
|
|
|
[-t TEMPLATE] [-u] [--no-unused]
|
|
|
|
sfz_filename [sfz_filename ...]
|
|
|
|
|
|
|
|
GPL v3+ 2016 Olivier Jolly
|
|
|
|
|
|
|
|
positional arguments:
|
|
|
|
sfz_filename input file in SFZ format
|
|
|
|
|
|
|
|
optional arguments:
|
|
|
|
-h, --help show this help message and exit
|
|
|
|
-d, --debug debug parsing [default: False]
|
|
|
|
-e {none,flac,ogg}, --encode {none,flac,ogg}
|
|
|
|
encode samples into given format [default: none]
|
|
|
|
-q, --quiet quiet operation [default: False]
|
|
|
|
-o OUTPUT_DIR, --ouput-dir OUTPUT_DIR
|
|
|
|
output directory [default: current directory]
|
|
|
|
-t TEMPLATE template filename [default: empty-31.xrni]
|
|
|
|
-u, --unused show unused generators [default: True]
|
|
|
|
--no-unused
|
|
|
|
|
|
|
|
Convert SFZ file into renoise instrument
|
|
|
|
|
|
|
|
|
|
|
|
xrnireencode
|
|
|
|
------------
|
|
|
|
|
|
|
|
**Xrnireencode** is a command line utility to reencode samples in renoise instrument (.xrni).
|
|
|
|
It can convert to **flac** or **ogg** one or more instruments given on command line.
|
|
|
|
|
|
|
|
::
|
|
|
|
|
|
|
|
usage: xrnireencode [-h] [-d] [-e {flac,ogg}] [-q] [-o OUTPUT_DIR]
|
|
|
|
xrni_filename [xrni_filename ...]
|
|
|
|
|
|
|
|
GPL v3+ 2016 Olivier Jolly
|
|
|
|
|
|
|
|
positional arguments:
|
|
|
|
xrni_filename input file in XRNI format
|
|
|
|
|
|
|
|
optional arguments:
|
|
|
|
-h, --help show this help message and exit
|
|
|
|
-d, --debug debug parsing [default: False]
|
|
|
|
-e {flac,ogg}, --encode {flac,ogg}
|
|
|
|
encode samples into given format [default: flac]
|
|
|
|
-q, --quiet quiet operation [default: False]
|
|
|
|
-o OUTPUT_DIR, --ouput-dir OUTPUT_DIR
|
|
|
|
output directory [default: current directory]
|
|
|
|
|
|
|
|
Reencode samples in renoise instrument
|
|
|
|
|
2016-02-02 11:29:05 +00:00
|
|
|
xrnicomment
|
|
|
|
-----------
|
|
|
|
|
|
|
|
**xrnicomment** is a command line utility to manipulate comments in renoise instruments (.xrni).
|
|
|
|
It can read, clear, replace and append content to the comment in one or more xrni files.
|
|
|
|
|
|
|
|
::
|
|
|
|
|
|
|
|
usage: xrnicomment [-h] [-d] [-a] [-e] [-m MESSAGE] [-r] [-v]
|
|
|
|
xrni_filename [xrni_filename ...]
|
|
|
|
|
|
|
|
GPL v3+ 2016 Olivier Jolly
|
|
|
|
|
|
|
|
positional arguments:
|
|
|
|
xrni_filename input file in XRNI format
|
|
|
|
|
|
|
|
optional arguments:
|
|
|
|
-h, --help show this help message and exit
|
|
|
|
-d, --debug debug parsing [default: False]
|
|
|
|
-a, --append append to comment
|
|
|
|
-e, --edit edit comment
|
|
|
|
-m MESSAGE, --message MESSAGE
|
|
|
|
edit message content [default reads from standard
|
|
|
|
input]
|
|
|
|
-r, --remove remove comment
|
|
|
|
-v, --view view comment [default action]
|
|
|
|
|
|
|
|
Display or change XRNI comments
|
|
|
|
|
|
|
|
xrnitag
|
|
|
|
-------
|
|
|
|
|
|
|
|
**xrnitag** is a command line utility to manipulate tags in renoise instruments (.xrni).
|
|
|
|
It can read, clear, remove or add tag to the tag list in one or more xrni files.
|
|
|
|
If you want to edit a tag, you can remove it and then add the new one.
|
|
|
|
|
|
|
|
::
|
|
|
|
|
|
|
|
usage: xrnitag [-h] [-d] [-a] [-c] [-r] [-v] [-t TAG]
|
|
|
|
xrni_filename [xrni_filename ...]
|
|
|
|
|
|
|
|
GPL v3+ 2016 Olivier Jolly
|
|
|
|
|
|
|
|
positional arguments:
|
|
|
|
xrni_filename input file in XRNI format
|
|
|
|
|
|
|
|
optional arguments:
|
|
|
|
-h, --help show this help message and exit
|
|
|
|
-d, --debug debug parsing [default: False]
|
|
|
|
-a, --add add a tag
|
|
|
|
-c, --clear clear all tags
|
|
|
|
-r, --remove remove a tag
|
|
|
|
-v, --view view all tags [default action]
|
|
|
|
-t TAG, --tag TAG tag name [default reads from standard input]
|
|
|
|
|
|
|
|
Display or change XRNI tags
|
|
|
|
|
2016-01-31 23:03:45 +00:00
|
|
|
|
2016-01-25 22:44:23 +00:00
|
|
|
Library use
|
|
|
|
-----------
|
|
|
|
|
2016-01-27 22:52:41 +00:00
|
|
|
Current, only renoise instrument API is available.
|
|
|
|
A renoise instrument is represented by the **RenoiseInstrument** class and can be loaded that way::
|
|
|
|
|
|
|
|
from rnsutils.instrument import RenoiseInstrument
|
|
|
|
# load an instrument from an existing xnri
|
|
|
|
inst = RenoiseInstrument('existing.xrni')
|
|
|
|
# now, inst.root is an objectified xml tree you can access and alter
|
|
|
|
# inst.sample_data is a mutable list of audio files content
|
|
|
|
inst.save('new.xrni')
|