DISTRHO Plugin Framework
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
falkTX 55a1e21ebb
Fix LTO build if vst2 MIDI stuff is properly defined elsewhere
2 years ago
.github Skip standalones on example-plugins CI artifacts for windows 2 years ago
cmake Fix previous commit, only use 1 audio port in clap for now 2 years ago
dgl Implement reusing nanovg context across parent/children widgets 2 years ago
distrho Fix LTO build if vst2 MIDI stuff is properly defined elsewhere 2 years ago
examples Implement CLAP latency, cleanup 2 years ago
lac Update pres 11 years ago
tests wasm and egl/gles related things 2 years ago
utils Add CLAP to macOS packaging 2 years ago
.gitignore Update .gitignore 3 years ago
.gitmodules Start adding some actual implementation to Window class 4 years ago
CMakeLists.txt cmake: generate the macOS namespace for pugl 4 years ago
FEATURES.md Add feature text on both sides 3 years ago
LICENSE Remove project name from license file 3 years ago
LICENSING.md Replace vestige with a more liberally-licensed version 2 years ago
Makefile Add makefile extra rules for MOD Audio stuff 2 years ago
Makefile.base.mk Use the updated toolchains for modduo and modduox builds 2 years ago
Makefile.plugins.mk Fix build 2 years ago
README.md Initialize self-test buffer; Mention CLAP in README 2 years ago
dpf.doxygen Skip doxygen timestamps for online docs 2 years ago
dpf.kdev4 Fix typo 11 years ago

README.md

DPF - DISTRHO Plugin Framework

makefile cmake example-plugins

DPF is designed to make development of new plugins an easy and enjoyable task.
It allows developers to create plugins with custom UIs using a simple C++ API.
The framework facilitates exporting various different plugin formats from the same code-base.

DPF can build for LADSPA, DSSI, LV2, VST2, VST3 and CLAP formats.
All current plugin format implementations are complete.
A JACK/Standalone mode is also available, allowing you to quickly test plugins.

Plugin DSP and UI communication is done via key-value string pairs.
You send messages from the UI to the DSP side, which is automatically saved in the host when required.
(You can also store state internally if needed, but this breaks DSSI compatibility).

Getting time information from the host is possible.
It uses the same format as the JACK Transport API, making porting some code easier.

Licensing

DPF is released under ISC, which basically means you can do whatever you want as long as you credit the original authors.
Some plugin formats may have additional restrictions, see LICENSING.md for details.

Help and documentation

Bug reports happen on the DPF github project.

Online documentation is available at https://distrho.github.io/DPF/.

Online help and discussion about DPF happens in the kx.studio chat, DPF room.

List of plugins made with DPF:

Work in progress

Checking the github “DPF” tag can potentially bring up other DPF-made plugins.

Plugin examples are available in the example/ folder inside this repo.