Lemons
                                
                                 Lemons copied to clipboard
                                
                                    Lemons copied to clipboard
                            
                            
                            
                        A library of utilities and building blocks for JUCE-based apps and plugins
Lemons
   
I used to work full time in live theatre. Then, COVID happened. I lost my career overnight, and I wasn't really sure what to do. I drifted for a while -- I made some angsty experimental electronic music, and then I made some calmer experimental electronic music -- and eventually, I started dabbling in creating my own electronic instruments in Max MSP. That eventually led me to the JUCE framework, which was my introduction to C++ more generally.
I quickly learned to love JUCE, but I also quickly learned that there was quite a lot of overhead involved in just getting a simple project up and running (reliably). I realized I needed to abstract that overhead into a single repo. Here it is.
Life handed me a bunch of lemons...
wait, damn it, perhaps I should've gone with Lemonade, now that I think about it... But, I've already changed all the variable names, and I don't want to step on Beyonce's toes, so, lemons it is.
Here are my lemons, go make lemonade of your own.
   
A library of utilities and building blocks for JUCE-based apps and plugins
This library is what I use to build my own projects, so hopefully you'll find it useful as well.
The online documentation can be found here; you can also build an offline copy by running make docs -- they'll be output to util/doxygen/doc.
Contributing is welcome and appreciated! (Or feel free to just make feature suggestions/requests.) You may fork this repo, file issues, make pull requests, send me hate mail -- whatever floats your git boat.
What's here
Here's a list of the juce modules in this repository:
- Audio
- lemons_audio_effects
- lemons_dsp
- lemons_midi
- lemons_psola
- lemons_synth
 
- Common
- lemons_core
- lemons_musicology
 
- Connectivity
- lemons_dmx
- lemons_osc
 
- GUI
- lemons_device
- lemons_gui
 
- Plugins
- lemons_plugin
- lemons_plugin_gui
 
Building
It's recommended to build with CMake. You could manually add the desired modules to a Projucer project, but CMake is a much better build system. Lemons contains several useful CMake scripts that should make getting things running fairly painless...
The full CMake API reference can be found here.
Adding with CPM.cmake
I recommend that within your CMake, you add Lemons by using CPM.cmake, which is a single-script CMake package manager that allows you lots of flexibility in project configuration. One particularly important feature is the ability to specify that a local directory contains the source code for a certain package -- so that not every project repository on your machine has to contain a copy of Lemons as a submodule. This makes your cmake perfectly modular: simply add the Lemons package with CPM.cmake in each project, and then if that project is cloned and built in isolation, CPM will download the Lemons package at configure time, but you also have the ability to tell CPM to reference a local copy of Lemons on your machine, so you can work on all your projects while only having one copy of Lemons on your machine.
Adding Lemons with CPM.cmake looks like this:
include (CPM.cmake)
CPMAddPackage (
 NAME Lemons
 GIT_REPOSITORY https://github.com/benthevining/Lemons.git
 GIT_TAG origin/main)
A note about adding JUCE
Internally, Lemons's cmake scripts add JUCE like this, using CPM.cmake. JUCE will automatically be fetched for you at configure time -- but, if you'd like to reference another local copy of JUCE, you can set this variable before adding the Lemons package:
set (CPM_JUCE_SOURCE /absolute/path/to/your/copy/of/juce)
Note that this is optional, and if you omit the above line, adding the Lemons package will automatically also add the latest copy of JUCE for you.
What I actually do in my projects' CMake
I noticed myself duplicating several lines of CMake code in every project, so I encapsulated the adding of Lemons into its own little repository.
What I usually do in my project repos is make my GetLemons repo a git submodule, then from the project's main CMakeLists.txt, simply
addSubdirectory (GetLemons)
What this will do is:
- Either fetch the CPM.cmake script from the github repository and cache it for future use; or include the previously-cached version if it can be found
- Include the Lemons repository using CPM.cmake
You can check out the GetLemons repo's ReadMe for more details.
For an example of a project repo that uses this configuration, see Imogen's CMakeLists.txt.
Licensing
This repository is licensed with the GNU General Public License. This means that any projects using this repository's code must also themselves be open-source and licensed under the GPL.
For inquiries about exemptions for commercial usage, please email me at [email protected].
Happy lemonade making!