2022-02-05 17:13:07 +01:00
|
|
|
# NIH-plug
|
|
|
|
|
|
|
|
[![Tests](https://github.com/robbert-vdh/nih-plugs/actions/workflows/test.yml/badge.svg)](https://github.com/robbert-vdh/nih-plugs/actions/workflows/test.yml)
|
2022-01-24 17:32:27 +01:00
|
|
|
|
2022-01-26 12:07:37 +01:00
|
|
|
Because of course we need to remake everything from scratch!
|
|
|
|
|
|
|
|
This is a work in progress JUCE-lite-lite written in Rust to do some experiments
|
2022-02-04 02:57:29 +01:00
|
|
|
with. The idea is to have a statefull but simple plugin API that gets rid of as
|
|
|
|
much unnecessary ceremony wherever possible, while also keeping the amount of
|
|
|
|
magic to minimum. Since this is not quite meant for general use just yet, the
|
|
|
|
plugin API is limited to the functionality I needed and I'll expose more
|
|
|
|
functionality as I need it. See the documentation comment in the `Plugin` trait
|
|
|
|
for an incomplete list of missing functionality.
|
2022-01-28 15:02:55 +01:00
|
|
|
|
2022-01-29 18:38:09 +01:00
|
|
|
## Building
|
|
|
|
|
2022-02-05 17:14:28 +01:00
|
|
|
NIH-plug doesn't use any unstable features, and works with the latest stable
|
|
|
|
Rust compiler.
|
|
|
|
|
2022-02-01 03:25:26 +01:00
|
|
|
After installing [Rust](https://rustup.rs/) you can compile any of the plugins
|
2022-01-29 18:38:09 +01:00
|
|
|
in the `plugins` directory in the following way, replacing `gain` with the name
|
|
|
|
of the plugin:
|
|
|
|
|
|
|
|
```shell
|
|
|
|
cargo xtask bundle gain --release --bundle-vst3
|
|
|
|
```
|
|
|
|
|
2022-02-04 02:57:29 +01:00
|
|
|
## Example plugins
|
|
|
|
|
|
|
|
The best way to get an idea for what the API looks like is to look at the
|
|
|
|
examples.
|
|
|
|
|
|
|
|
- **gain** is a simple smoothed gain plugin that shows off a couple other parts
|
|
|
|
of the API, like support for storing arbitrary serializable state.
|
|
|
|
- **sine** is a simple test tone generator plugin with frequency smoothing that
|
|
|
|
can also make use of MIDI input instead of generating a static signal based on
|
|
|
|
the plugin's parameters.
|
|
|
|
|
2022-01-28 15:02:55 +01:00
|
|
|
## Licensing
|
|
|
|
|
|
|
|
Right now everything is licensed under the GPLv3+ license, partly because the
|
|
|
|
VST3 bindings used are also GPL licensed. I may split off the VST3 wrapper into
|
|
|
|
its own crate and relicense the core library under a more permissive license
|
|
|
|
later.
|