Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/eyalamirmusic/JUCECmakeRepoPrototype
A prototype to model a way to create an entire repo using JUCE6 and CMake.
https://github.com/eyalamirmusic/JUCECmakeRepoPrototype
Last synced: 2 months ago
JSON representation
A prototype to model a way to create an entire repo using JUCE6 and CMake.
- Host: GitHub
- URL: https://github.com/eyalamirmusic/JUCECmakeRepoPrototype
- Owner: eyalamirmusic
- Created: 2020-02-09T06:24:22.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2024-11-01T21:24:09.000Z (3 months ago)
- Last Synced: 2024-11-01T22:24:11.980Z (3 months ago)
- Language: CMake
- Homepage:
- Size: 301 KB
- Stars: 248
- Watchers: 15
- Forks: 31
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-juce - JUCECmakeRepoPrototype
- awesome-musicdsp - JUCECmakeRepoPrototype - Eyal Amir also has one which looks good! (Audio plug-in templates)
README
# JUCE CMake Repo Prototype
A prototype to model a way to create an entire repo using JUCE 8 and CMake.This is inspired by a desire to keep the environment setting of my projects to minimum,
making sure the environment is identical for every developer/machine.The main concept is to set all the different variables (where JUCE is, custom modules, etc)
in the top CMakeLists.txt, then add all your projects with very little setup time.Another important concept is to share all 'related' projects under the same configuration,
which I prefer, since it encourages code-sharing and build system settings sharing.
In some of the examples I added minimal usages of juce-style modules to illustrate how that
can be done.To build, all you have to do is load this project in your favorite IDE
(CLion/Visual Studio/VSCode/etc)
and click 'build' for one of the targets (templates, JUCE examples, Projucer, etc).You can also generate a project for an IDE by using (Mac):
```
cmake -G Xcode -B build
```
Windows:
```
cmake -G "Visual Studio 17 2022" -B build
```For package management, I'm using the amazing CPM.cmake:
#https://github.com/TheLartians/CPM.cmake
It automatically fetches JUCE from git, but you can also set the variable:
CPM_JUCE_SOURCE to point it to a local folder, by using:
``-DCPM_JUCE_SOURCE="Path_To_JUCE"``
when invoking CMakeJUCE can be found here:
#https://github.com/juce-framework/JUCELicense:
Anything from me in this repo is completely free to use for any purpose.
However, please check the licenses for CPM and JUCE as described in their repo.