Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/xoofx/nplug
Develop VST3 audio native plugins with .NET
https://github.com/xoofx/nplug
dotnet nativeaot vst vst3 vst3-sdk
Last synced: 2 months ago
JSON representation
Develop VST3 audio native plugins with .NET
- Host: GitHub
- URL: https://github.com/xoofx/nplug
- Owner: xoofx
- License: other
- Created: 2022-11-23T09:12:35.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2024-04-29T20:40:22.000Z (8 months ago)
- Last Synced: 2024-06-07T14:52:19.960Z (7 months ago)
- Topics: dotnet, nativeaot, vst, vst3, vst3-sdk
- Language: C#
- Homepage:
- Size: 9.72 MB
- Stars: 86
- Watchers: 6
- Forks: 4
- Open Issues: 3
-
Metadata Files:
- Readme: readme.md
- License: license.txt
Awesome Lists containing this project
README
# NPlug [![Build Status](https://github.com/xoofx/NPlug/workflows/ci/badge.svg?branch=main)](https://github.com/xoofx/NPlug/actions) [![NuGet](https://img.shields.io/nuget/v/NPlug.svg)](https://www.nuget.org/packages/NPlug/)
NPlug is a library that allows to easily develop [VST3](https://steinbergmedia.github.io/vst3_dev_portal/pages/) audio native plugins in .NET using NET7+ NativeAOT.
> **What is VST?**
>
> _Virtual Studio Technology (VST) is an audio plug-in software interface that facilitates the integration of software synthesizers and effects in digital audio workstations (DAW)._## Features
- Purely managed, fast interop, no C++/CLI.
- Compatible with NET7+ NativeAOT
- Build a native VST3 plugin with NPlug with zero dependencies!
- Exposes the interfaces from VST3 version `3.7.7`.
- Provides builtin support for synchronizing automatically the data model between the `AudioProcessor` and `AudioController`.
- Supports multiple platforms: `win-x64`, `win-arm64`, `osx-x64`, `osx-arm64`, `linux-x64`, `linux-arm64`
- Please notice that `osx` full native supports will be only possible with .NET8+
- Provides the official VST3 Validator to unit test your plugin developed with NPlug via the package [NPlug.Validator](https://www.nuget.org/packages/NPlug.Validator/) → [![NuGet](https://img.shields.io/nuget/v/NPlug.Validator.svg)](https://www.nuget.org/packages/NPlug.Validator/)
- Usage documentation of NPlug.Validator is available [here](https://github.com/xoofx/NPlug/blob/main/doc/readme.md#validating-a-plugin-with-nplugvalidator).## User Guide
The official documentation for VST3 is https://steinbergmedia.github.io/vst3_dev_portal/pages/
For more details on how to use NPlug, please visit the [user guide](https://github.com/xoofx/NPlug/blob/main/doc/readme.md).
## Samples
You will find VST3 NPlug samples available in the [NPlug.Samples repository](https://github.com/xoofx/NPlug.Samples).
## License
The core part of this software is released under the [BSD-2-Clause license](https://opensource.org/licenses/BSD-2-Clause) but you have also to follow the following VST3 license:
> **NOTICE**
>
> When you are developing a plugin with NPlug, your plugin needs to comply with the [VST 3 Licensing](https://steinbergmedia.github.io/vst3_dev_portal/pages/VST+3+Licensing/Index.html). If your plugin is distributed, it needs to either be published under:
> - The [Proprietary Steinberg VST 3 license](https://steinbergmedia.github.io/vst3_dev_portal/pages/VST+3+Licensing/What+are+the+licensing+options.html#proprietary-steinberg-vst-3-license) if you want to keep your plugin closed source.
> - The [Open-source GPLv3 license](https://steinbergmedia.github.io/vst3_dev_portal/pages/VST+3+Licensing/What+are+the+licensing+options.html#open-source-gplv3-license) if you want to make your plugin OSS.What it means is that you are allowed to modify and redistribute NPlug (according to the `BSD-2-Clause` license) but you need to publish your plugin under the VST3 dual-license.
## Author
Alexandre Mutel aka [xoofx](https://xoofx.github.io).