brickworks/examples
2024-03-19 13:54:26 +01:00
..
common/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_ap1/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_ap2/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_balance/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_bitcrush/src add gate param to bw_bd_reduce and examples + fix fxpp_bitcrush 2024-03-13 12:28:35 +01:00
fx_cab/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_chorus/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_clip/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_comb/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_comp/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_delay/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_dist/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_drive/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_eq_3band/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_flanger/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_fuzz/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_hp1/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_hs1/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_lp1/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_ls1/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_mm1/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_mm2/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_noise_gate/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_notch/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_one_pole/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_pan/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_phaser/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_reverb/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_ring_mod/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_satur/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_slew_lim/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_svf/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_trem/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_vibrato/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fx_wah/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_ap1/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_ap2/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_balance/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_bitcrush/src add gate param to bw_bd_reduce and examples + fix fxpp_bitcrush 2024-03-13 12:28:35 +01:00
fxpp_cab/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_chorus/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_clip/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_comb/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_comp/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_delay/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_dist/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_drive/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_eq_3band/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_flanger/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_fuzz/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_hp1/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_hs1/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_lp1/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_ls1/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_mm1/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_mm2/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_noise_gate/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_notch/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_one_pole/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_pan/src fix process() invokation in fxpp_pan 2024-03-19 13:54:26 +01:00
fxpp_phaser/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_reverb/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_ring_mod/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_satur/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_slew_lim/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_svf/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_trem/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_vibrato/src copyright notices in examples 2024-02-23 14:17:01 +01:00
fxpp_wah/src copyright notices in examples 2024-02-23 14:17:01 +01:00
synth_mono/src avoid bw_minf() to compute samples in synth* 2024-03-07 16:57:50 +01:00
synth_poly/src avoid bw_minf() to compute samples in synth* 2024-03-07 16:57:50 +01:00
synth_simple/src avoid bw_minf() to compute samples in synth* 2024-03-07 16:57:50 +01:00
synthpp_mono/src avoid bw_minf() to compute samples in synth* 2024-03-07 16:57:50 +01:00
synthpp_poly/src avoid bw_minf() to compute samples in synth* 2024-03-07 16:57:50 +01:00
synthpp_simple/src avoid bw_minf() to compute samples in synth* 2024-03-07 16:57:50 +01:00
README.md example instructions remove leftovers 2024-02-23 12:05:01 +01:00
tibia_clean.sh fx(pp)_svf + no more tibia_{clean,gen}.sh juggling 2024-02-16 09:43:18 +01:00
tibia_gen.sh fx(pp)_svf + no more tibia_{clean,gen}.sh juggling 2024-02-16 09:43:18 +01:00

Examples

Premise

Each of these examples consists of a common part of code, shared by all examples, which contains all necessary boilerplate code and is not Brickworks-related, and a specific part which actually implements the audio engine. The common code is copied/generated by an external tool called Tibia. If you downloaded an official Brickworks release you don't need to care about any of this - all needed files will already be present -, otherwise you first need to run Tibia as outlined below. You might also want to do that if you need to edit the location of third-party dependencies (this is better explained in the following platform-specific instructions).

Each subfolder contains an example, except the common folder, which contains a good deal of common code and common Tibia metadata. In order to build an example just cd to example/platform and use the following platform-specific instructions. Building for any platform requires a recent enough version of GNU Make installed.

VST3

Prerequisites

Windows (via MSYS2/Mingw-w64), macOS, and Linux OSes are supported. Building tested with GCC, probably also works with Clang.

You also need to download or clone the VST3 C API and place it in the same folder as the Brickworks folder, or otherwise edit common/src/vst3-make.json and change cflags to point to the correct directory then finally run Tibia, or invoke make with appropriate CFLAGS straight from the command line.

Build

In order to build just type make. You'll find the resulting VST3 directory in build/bw_example_example.vst3.

Installation

If all went fine, you can install for the current user (i.e., into the user VST3 folder) by invoking make install-user or for all users (i.e., into the system VST3 folder) by make install.

LV2

Prerequisites

Windows (via MSYS2/Mingw-w64), macOS, and Linux OSes are supported. Building tested with GCC, probably also works with Clang.

You also need to download/install LV2, so that either header files are found by the compiler in its default include path, or otherwise you could add an appropriate cflags value to common/src/lv2-make.json and run Tibia, or invoke make with appropriate CFLAGS straight from the command line.

Build

In order to build just type make. You'll find the resulting LV2 bundle in build/bw_example_example.lv2.

Installation

If all went fine, you can install for the current user (i.e., into the user VST3 folder) by invoking make install-user or for all users (i.e., into the system VST3 folder) by make install.

Web

Prerequisites

You need Clang with WebAssembly target support and OpenSSL installed.

Build

In order to build just type make. You'll find the resulting output directory in build/web.

Running

The output files need to be served over HTTPS. A self-signed certificate is generated in the output directory (hence the OpenSSL requirement) to make it possible to run an HTTPS-enabled web server, e.g. http-server -S, directly on/from the output folder.

Daisy Seed

Prerequisites

Building and firmware upload was only tested on Linux. You need arm-none-eabi-gcc (for building) and dfu-util (for firmware upload) installed.

You also need to clone/download libDaisy (beware that since version 7.0.0 you also need to clone submodules, see the release notes), cd to it, and run make. You should either place it in the same folder as the Brickworks folder, or otherwise edit common/src/daisy-seed-make.json and change libdaisyDir to point to the correct directory then finally run Tibia.

Build

In order to build just type make. You'll find the resulting output files in build.

Firmware upload

To upload the firmware:

  1. branch the board to the uploading machine via USB;
  2. put the board in DFU mode by pressing BOOT, then RESET, then letting go of RESET and then of BOOT;
  3. type make program-dfu.

Effect examples report output parameter values and CPU usage statistics via USB serial. You can read the output by, e.g., screen /dev/ttyACM0.

Android

Prerequisites

Android examples are built without the help of Android Studio or Gradle. You'll however need to have a recent enough JDK (we need javac), as well as to download the latest stable:

Then you'll probably also need to adjust paths and values in common/src/android-make.json and run Tibia.

* You can install both the needed parts of the Android SDK and the NDK by downloading the so-called "command line tools" (https://developer.android.com/studio#command-line-tools-only) and using the included sdkmanager program. In such case you need to install the following packages: "platforms;android-latest", "build-tools;latest", "platform-tools", and "ndk;latest".

Build

In order to build just type make. You'll find the resulting .apk file in build.

Installation

If all went fine, you can branch your device and install using make install or otherwise install manually.

Usage and known issues

Effect examples process audio input signals, therefore they will require permission to use the capture device.

Synth examples use input MIDI and support hotplugging.

iOS

Prerequisites

iOS examples are not directly built by the supplied Makefiles. These rather generate the corresponding XCode projects and required files.

For this to work you need to have the latest Xcode and XcodeGen installed, as well as a copy of the latest miniaudio.h.

Finally, you might need to adjust header search path for miniaudio in common/src/ios-make.json, common/src/ios-make-cxx-fx.json, and common/src/io-make-cxx-synth.json, and run Tibia.

Build

Typing make will generate the required Xcode project in build/gen.

You'll need to open it and select a development team (click on the project root in the left side pane, then choose the "Signing & Capabilities" tab, and finally pick a "Team").

At this point you can build and run as with any other iOS app.

Usage

Effect examples process audio input signals, therefore they will require permission to use the capture device.

Synth examples use input MIDI and support hotplugging.

Command line program

Prerequisites

Windows (via MSYS2/Mingw-w64), macOS, and Linux OSes are supported. Building tested with GCC, probably also works with Clang.

Depending on the specific example, you might need to download or clone tinywav and/or midi-parser and place them in the same folder as the Brickworks folder, or otherwise edit common/src/cmd-make.json

Build

In order to build just type make. You'll find the resulting executable file in build.

Usage

Just run the executable without arguments to get usage instructions.

Tibia

Prerequisites

You need Node.js and npm to be installed.

Usage

Get Tibia 0.0.1, place it in the same directory as the Brickworks folder, and rename it as tibia. Then either cd to the Tibia folder and npm install dot, or install the dot npm package globally and make sure that the NODE_PATH environment variable is corretly set to find it.

Now you can cd to the examples folder and run ./tibia_gen.sh to copy/generate files for all examples, or otherwise run ./tibia_gen.sh common to only copy/generate files in examples/common or ./tibia_gen.sh example to do the same for files in examples/example.

If you want to remove all files copied/generated by Tibia, and thus restore the examples directory as it would appear in the official repository, run ./tibia_clean.sh from the examples directory.