ampli-Fe is a fully cross-platform VST2 plugin written in Rust. It works on Linux, macOS, Windows, without any conditionally compiled code.
It features a fully-customized editor UI with an interactive knob and corresponding numerical value readout.
ampli-Fe's code is well-documented and freely licensed - feel free to use it as a starting point for your next VST2 plugin!
ampli-Fe is a VST2 effect plugin. It can be added to tracks within a Digital Audio Workstation, or DAW.
ampli-Fe has a single knob, that can be "turned" by clicking and dragging up or down. Turning the knob will multiply the track's playback volume by a configurable amount between 0 and 2. The current value of the knob is displayed on the UI as a reference.
ampli-Fe was written to demonstrate usage of the vst_window
crate for custom, cross-platform plugin interfaces, along with the excellent vst
bindings for Rust.
The graphics for the editor interface are drawn using wgpu
.
For optimal thread-safety and performance, the plugin's functionality is split between three major components.
The plugin_state
module receives a subset of VST API events that can occur on both the UI thread and audio processing thread, and maintains the "ground-truth" representation of the plugin's customized parameters.
It's used to coordinate parameter changes across the host DAW, audio processing logic, and editor interface.
It uses thread-safe interior mutability to ensure that its managed memory is always consistent.
The dsp
module processes incoming audio and returns it to the host DAW.
It runs fully on the audio processing thread, and its parameters are updated from the plugin state via message passing to avoid performance-costly locking.
The editor
module displays the plugin state visually and allows interactive editing of the plugin's parameters.
It runs fully on the UI thread.
While open, the editor subscribes to receive update messages from the plugin state, but it also has direct access to the plugin state to allow it to "push" changes to the rest of the plugin in real time.
Running cargo build --release
will automatically compile the correct plugin for your current OS platform.
The resulting plugin binary can be found in the target/release
directory.
Once the plugin is compiled, you'll need to make it accessible to your DAW, which can vary by platform.
The shared object file target/release/libampli_fe.so
can be copied directly to the user or system VST plugin directory.
This directory may vary by distribution and host DAW, so be sure to check the documentation and settings for each.
macOS requires an extra step to "bundle" VST plugins.
After compiling, run the included bundle_macos.sh
script, which will generate and populate the ampli-Fe.vst
directory.
That directory can be copied directly to the user or system VST plugin directory, usually either ~/Library/Audio/Plug-Ins/VST/
or /Library/Audio/Plug-Ins/VST/
.
The dynamic-link library file target/release/ampli_fe.dll
can be copied directly to the dedicated VST plugin directory.
This directory may vary by host DAW, so be sure to check its documentation and settings.
ampli-Fe provides a volume adjustment knob, and is written in the Rust programming language. Its name is a contraction of "amplify" (to increase volume) and "Fe" (the chemical symbol for iron, a natural component of rust).