Skip to main content

Package manager for csound

Project description

risset

risset: a package manager for csound

This is the repository of risset, a package manager for csound external plugins and user-defined-opcodes. The index aggregating all available packages is kept at risset-data.

Installation

risset depends only on git and python3 (>= 3.9) being installed.

pip install risset

This will install the script "risset" into your path

In certain systems it is not allowed to install packages to the system python. In that case the recommended way is to install risset within its own virtual environment

MacOS / linux

curl -LsSf https://astral.sh/uv/install.sh | sh
uv tool install --upgrade risset

Windows

powershell -ExecutionPolicy ByPass -c "irm https://astral.sh/uv/install.ps1 | iex"
uv tool install --upgrade risset

Quick start

List all defined packages

$ risset list

- else /2.0.0          | Miscellaneous plugins
- pathtools /2.0.0     | Cross-platform path handling and string opcodes
- klib /2.0.0          | A hashtable for csound
- beosc /2.0.0         | Band-enhanced oscillators implementing the sine+noise synthesis model
- jsfx /2.0.0          | jsfx support for csound
- poly /2.0.0          | Multiple (parallel or sequential) instances of an opcode
- sndmeta /2.0.0       | opcodes using libsndfile
- risset /2.0.0        | Opcodes to access risset package metadata
- poodle /2.0.0        | Faust plugins ported to csound
- vst3 /1.1.0          | Host vst3 plugins in csound
                       |    -- No binaries for linux-x86_64/7000
                       |       Available binaries: linux-x86_64/csound>=6.18<7.0, windows-x86_64/csound>=6.18<7.0, macos-x86_64/csound>=6.18<7.0, macos-arm64/csound>=6.18<7.0
- chua /0.1.0          | Implementation of a Chua oscillator
                       |    -- No binaries for linux-x86_64/7000
                       |       Available binaries: linux-x86_64/csound>=6.18<7.0, macos-x86_64/csound>=6.18<7.0, macos-arm64/csound>=6.18<7.0
- hdf5 /0.1.0          | Read/Write signals and arrays to/from an hdf5 file
                       |    -- No binaries for linux-x86_64/7000
                       |       Available binaries: linux-x86_64/csound>=6.18<7.0, macos-x86_64/csound>=6.18<7.0, macos-arm64/csound>=6.18<7.0
- python /0.1.0        | Opcodes to interact with an embedded python interpreter
                       |    -- No binaries for linux-x86_64/7000
                       |       Available binaries: linux-x86_64/csound>=6.18<7.0, macos-x86_64/csound>=6.18<7.0, macos-arm64/csound>=6.18<7.0

Install some packages

$ risset install else jsfx

Show information about a specific package

$ risset show poly

Plugin        : poly
Author        : Eduardo Moguillansky (eduardo.moguillansky@gmail.com)
URL           : https://github.com/csound-plugins/csound-plugins.git
Version       : 1.18.2

Installed     : Unknown (path: /home/xx/.local/lib/csound/6.0/plugins64/libpoly.so)
Manifest      : No manifest (installed manually)
Abstract      : Multiple (parallel or sequential) instances of an opcode
Description:
    Multiple (parallel or sequential) instances of an opcode
Opcodes:
    defer, poly, poly0, polyseq
Binaries:
    * linux/csound>=6.17<7.0
    * linux/csound>=7.0
    * macos/csound>=6.17<7.0
    * macos/csound>=7.0
    * macos-arm64/csound>=6.17<7.0
    * macos-arm64/csound>=7.0
    * windows/csound>=6.17<7.0
    * windows/csound>=7.0

Remove a plugin

$ risset remove poly

See manual page for an opcode (installed or not)

$ risset man poly
# mtro

## Abstract

an accurate version of metro


## Description

`mtro` is a drop-in replacement of `metro` without the
drifting over time. `metro` is implemented by adding a phase
each cycle, which results in drifting over time due to rounding errors.
`mtro` avoids this problem by keeping a counter and doing multiplication
so that the error is limited.

Following metro's implementation by default `mtro` is triggered at time=0. This
is because `i_initphase` is set to 1 by default. It is possible to make `mtro` skip the
0 trigger by setting `i_initphase` to 0.

## Syntax


    kout mtro kfreq, i_initphase=1


## Arguments

* **kfreq**: the frequency of the trigger
* **i_initphase**: the initial phase (a value between 0 and 1). If set to 0, there is no trigger at time 0.
        If set to 1, `mtro` triggers at time=0, similar to `metro`

## Output

* **kout**: 1 if the mtro has triggered, 0 otherwise

## Execution Time

* Performance

Risset commands

update

Update the local index to the latest state.

$ risset update

list

List all available plugins for your platform

$ risset list [options]
Options
  • --nameonly: Output just the name of each plugin
  • --installed: List only installed plugins
  • --upgradeable: List only installed packages which can be upgraded
  • --notinstalled: List only plugins which are not installed
  • -1, --oneline: List each plugin in one line

show

Show information about a plugin

$ risset show <plugin>

install

Install one or multiple plugins

$ risset install [--force] <plugin> [<plugin2>, ...]

Install a given plugin for the current platform. Plugins are installed into the user folder (no administrator requirements are needed). Look at the info command to query information about the system.

Options
  • --force: Installs a plugin even if the plugin with the same version is already installed

the system folder where all other builtin plugins are installed (this requires administrator rights in some platforms). Admin rights are needed for this.

remove

Remove an installed plugin

$ risset remove <plugin>


#### documentation

Open man page as markdown in the command line

$ risset man [options] <opcode>
Options
  • -s, --simplepath: Print just the path of the manual page
  • -m, --markdown: Use the .md page instead of the .html version
  • -e, --external: Open the man page in the default app. This is only used when opening the markdown man page.
  • --html: Opens the .html version of the manpage in the default browser (or outputs the path with the --path option)
  • --theme {dark,light,gruvbox-dark,gruvbox-light,material,fruity,native}: Style used when displaying markdown files (default=dark)

Open the html man page in the default browser:

$ risset man --html <opcode>

Generate/update documentation:

$ risset makedocs

Build the documentation for all defined plugins. This depends on mkdocs being installed

upgrade

$ risset upgrade

Upgrade any installed plugin to the latest version

listopcodes

$ risset listopcodes

List installed opcodes

Options
  • -l, --long: Long format
$ risset listopcodes -l

accum               else        Simple accumulator of scalar values
atstop              else        Schedule an instrument at the end of the current instrument
beadsynt            beosc       Band-Enhanced Oscillator-Bank
beosc               beosc       Band-Enhanced Oscillator
bisect              else        Returns the fractional index of a value within a sorted ar…ay / tab
chuap               chua        Simulates Chua's oscillator
crackle             else        generates noise based on a chaotic equation
defer               poly        Run an opcode at the end of current event
deref               else        Dereference a previously created reference to a variable
detectsilence       else        Detect when input falls below an amplitude threshold
dict_del            klib        Remove a key:value pair from a hashtable
dict_dump           klib        Dumps the contents of this dict as a string
dict_exists         klib        Returns 1 if the dict exists, 0 otherwise
dict_free           klib        Free a hashtable
...

download

$ risset download <plugin>

Download a plugin

Options
  • --path PATH: Directory to download the plugin to (default: current directory)
  • --platform: The platform of the plugin to download (default: current platform). One of linux, macos, window, macos-arm64, linux-arm64

info

$ risset info [options]

Outputs information about the environment as json in order to be integrated by other systems. For example, CsoundQT uses this command to read the installed plugins and their opcodes and documentation

Options
  • --outfile OUTFILE: Save output to this path
  • --full: Include all available information

Plugin Documentation

Documentation for all plugins can be found here: https://csound-plugins.github.io/risset-docs/


Upgrading risset

If installed via pip, do:

pip install risset -U

If installed via git, go to the repository and do:

git pull
python setup.py install

Contributing

In order to add/modify a plugin, clone risset-data

At the root of the repository there is an index file rissetindex.json, with the form:

{
    "version": "1.0.0",
    "plugins": {
        "else": {
            "url": "https://github.com/csound-plugins/csound-plugins.git",
            "path": "src/else"
        },
        "pathtools": {
            "url": "https://github.com/csound-plugins/csound-plugins.git",
            "path": "src/pathtools"
        },
        "klib": {
            "url": "https://github.com/csound-plugins/csound-plugins.git",
            "path": "src/klib"
        },
        "beosc": {
            "url": "https://github.com/csound-plugins/csound-plugins.git",
            "path": "src/beosc"
        },
        "vst3": {
            "url": "https://github.com/csound-plugins/vst3-risset.git"
        }
    }
}

To add a plugin to the index, just extend the plugins dict. The url should point to a valid git repository, the path attribute can be used to indicate where risset.json manifest is within this repository. This allows to define multiple plugins within one repository.

Manifest

Each plugin has an accompanying manifest in the .json format. The name of this file is always risset.json See one of the examples in https://github.com/csound-plugins/csound-plugins/tree/master/src for more information about the manifest

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

risset-3.2.2.tar.gz (124.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

risset-3.2.2-py3-none-any.whl (38.6 kB view details)

Uploaded Python 3

File details

Details for the file risset-3.2.2.tar.gz.

File metadata

  • Download URL: risset-3.2.2.tar.gz
  • Upload date:
  • Size: 124.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.5.21

File hashes

Hashes for risset-3.2.2.tar.gz
Algorithm Hash digest
SHA256 226cda32a3dada4276022f8db14584bfe75ff10a2f4aa944ce9251a2e4d7ecf7
MD5 5218a2bd4f4f3f15cd1f839cbd49c414
BLAKE2b-256 5e32eb1229c9aa6330daf1d0e473d4741d318440abfffeab099fafadaf9a5d60

See more details on using hashes here.

File details

Details for the file risset-3.2.2-py3-none-any.whl.

File metadata

  • Download URL: risset-3.2.2-py3-none-any.whl
  • Upload date:
  • Size: 38.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.5.21

File hashes

Hashes for risset-3.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 7ee1a79bd20b168c3c2f59b4e17b23ce45e0b022e2647af30aba967d21b0a041
MD5 0194682a15e9db9c0bab845428c3a6c9
BLAKE2b-256 a7e318ff3e9700d76329f5974a0c45eab6162cb7e92619b7ea1e0f46f6bb4610

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page