Initial setup for Cardinal plugin variants
This commit is contained in:
parent
1b17b08da3
commit
991ed6c8a7
25 changed files with 398 additions and 163 deletions
1
src/Cardinal/CardinalPlugin.cpp
Symbolic link
1
src/Cardinal/CardinalPlugin.cpp
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
../CardinalPlugin.cpp
|
1
src/Cardinal/CardinalUI.cpp
Symbolic link
1
src/Cardinal/CardinalUI.cpp
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
../CardinalUI.cpp
|
8
src/Cardinal/Makefile
Normal file
8
src/Cardinal/Makefile
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
#!/usr/bin/make -f
|
||||||
|
# Makefile for DISTRHO Plugins #
|
||||||
|
# ---------------------------- #
|
||||||
|
# Created by falkTX
|
||||||
|
#
|
||||||
|
|
||||||
|
NAME = Cardinal
|
||||||
|
include ../Makefile.cardinal.mk
|
1
src/Cardinal/MenuBar.cpp
Symbolic link
1
src/Cardinal/MenuBar.cpp
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
../override/MenuBar.cpp
|
1
src/Cardinal/RemoteNanoVG.cpp
Symbolic link
1
src/Cardinal/RemoteNanoVG.cpp
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
../override/RemoteNanoVG.cpp
|
1
src/Cardinal/RemoteWindow.cpp
Symbolic link
1
src/Cardinal/RemoteWindow.cpp
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
../override/RemoteWindow.cpp
|
1
src/Cardinal/Window.cpp
Symbolic link
1
src/Cardinal/Window.cpp
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
../override/Window.cpp
|
1
src/Cardinal/common.cpp
Symbolic link
1
src/Cardinal/common.cpp
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
../override/common.cpp
|
|
@ -307,7 +307,9 @@ class CardinalPlugin : public CardinalBasePlugin
|
||||||
{
|
{
|
||||||
SharedResourcePointer<Initializer> fInitializer;
|
SharedResourcePointer<Initializer> fInitializer;
|
||||||
|
|
||||||
|
#if DISTRHO_PLUGIN_NUM_INPUTS != 0
|
||||||
float* fAudioBufferIn;
|
float* fAudioBufferIn;
|
||||||
|
#endif
|
||||||
float* fAudioBufferOut;
|
float* fAudioBufferOut;
|
||||||
std::string fAutosavePath;
|
std::string fAutosavePath;
|
||||||
String fWindowSize;
|
String fWindowSize;
|
||||||
|
@ -326,7 +328,9 @@ public:
|
||||||
CardinalPlugin()
|
CardinalPlugin()
|
||||||
: CardinalBasePlugin(kModuleParameters + kWindowParameterCount, 0, 2),
|
: CardinalBasePlugin(kModuleParameters + kWindowParameterCount, 0, 2),
|
||||||
fInitializer(this),
|
fInitializer(this),
|
||||||
|
#if DISTRHO_PLUGIN_NUM_INPUTS != 0
|
||||||
fAudioBufferIn(nullptr),
|
fAudioBufferIn(nullptr),
|
||||||
|
#endif
|
||||||
fAudioBufferOut(nullptr),
|
fAudioBufferOut(nullptr),
|
||||||
fIsActive(false),
|
fIsActive(false),
|
||||||
fCurrentAudioDevice(nullptr),
|
fCurrentAudioDevice(nullptr),
|
||||||
|
@ -497,7 +501,11 @@ protected:
|
||||||
|
|
||||||
const char* getLabel() const override
|
const char* getLabel() const override
|
||||||
{
|
{
|
||||||
|
#if DISTRHO_PLUGIN_IS_SYNTH
|
||||||
|
return "CardinalSynth";
|
||||||
|
#else
|
||||||
return "Cardinal";
|
return "Cardinal";
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
const char* getDescription() const override
|
const char* getDescription() const override
|
||||||
|
@ -529,7 +537,11 @@ protected:
|
||||||
|
|
||||||
int64_t getUniqueId() const override
|
int64_t getUniqueId() const override
|
||||||
{
|
{
|
||||||
|
#if DISTRHO_PLUGIN_IS_SYNTH
|
||||||
|
return d_cconst('d', 'C', 'n', 'S');
|
||||||
|
#else
|
||||||
return d_cconst('d', 'C', 'd', 'n');
|
return d_cconst('d', 'C', 'd', 'n');
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/* --------------------------------------------------------------------------------------------------------
|
/* --------------------------------------------------------------------------------------------------------
|
||||||
|
@ -746,9 +758,11 @@ protected:
|
||||||
void activate() override
|
void activate() override
|
||||||
{
|
{
|
||||||
const uint32_t bufferSize = getBufferSize() * DISTRHO_PLUGIN_NUM_OUTPUTS;
|
const uint32_t bufferSize = getBufferSize() * DISTRHO_PLUGIN_NUM_OUTPUTS;
|
||||||
fAudioBufferIn = new float[bufferSize];
|
|
||||||
fAudioBufferOut = new float[bufferSize];
|
fAudioBufferOut = new float[bufferSize];
|
||||||
|
#if DISTRHO_PLUGIN_NUM_INPUTS != 0
|
||||||
|
fAudioBufferIn = new float[bufferSize];
|
||||||
std::memset(fAudioBufferIn, 0, sizeof(float)*bufferSize);
|
std::memset(fAudioBufferIn, 0, sizeof(float)*bufferSize);
|
||||||
|
#endif
|
||||||
|
|
||||||
{
|
{
|
||||||
const MutexLocker cml(fDeviceMutex);
|
const MutexLocker cml(fDeviceMutex);
|
||||||
|
@ -767,9 +781,12 @@ protected:
|
||||||
fCurrentAudioDevice->onStopStream();
|
fCurrentAudioDevice->onStopStream();
|
||||||
}
|
}
|
||||||
|
|
||||||
delete[] fAudioBufferIn;
|
|
||||||
delete[] fAudioBufferOut;
|
delete[] fAudioBufferOut;
|
||||||
fAudioBufferIn = fAudioBufferOut = nullptr;
|
fAudioBufferOut = nullptr;
|
||||||
|
#if DISTRHO_PLUGIN_NUM_INPUTS != 0
|
||||||
|
delete[] fAudioBufferIn;
|
||||||
|
fAudioBufferIn = nullptr;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void run(const float** const inputs, float** const outputs, const uint32_t frames,
|
void run(const float** const inputs, float** const outputs, const uint32_t frames,
|
||||||
|
@ -784,11 +801,13 @@ protected:
|
||||||
|
|
||||||
if (fCurrentAudioDevice != nullptr)
|
if (fCurrentAudioDevice != nullptr)
|
||||||
{
|
{
|
||||||
|
#if DISTRHO_PLUGIN_NUM_INPUTS != 0
|
||||||
for (uint32_t i=0, j=0; i<frames; ++i)
|
for (uint32_t i=0, j=0; i<frames; ++i)
|
||||||
{
|
{
|
||||||
fAudioBufferIn[j++] = inputs[0][i];
|
fAudioBufferIn[j++] = inputs[0][i];
|
||||||
fAudioBufferIn[j++] = inputs[1][i];
|
fAudioBufferIn[j++] = inputs[1][i];
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -802,8 +821,15 @@ protected:
|
||||||
dev->handleMessagesFromHost(midiEvents, midiEventCount);
|
dev->handleMessagesFromHost(midiEvents, midiEventCount);
|
||||||
|
|
||||||
if (fCurrentAudioDevice != nullptr)
|
if (fCurrentAudioDevice != nullptr)
|
||||||
fCurrentAudioDevice->processBuffer(fAudioBufferIn, DISTRHO_PLUGIN_NUM_INPUTS,
|
{
|
||||||
|
#if DISTRHO_PLUGIN_NUM_INPUTS == 0
|
||||||
|
const float* const insPtr = nullptr;
|
||||||
|
#else
|
||||||
|
const float* const insPtr = fAudioBufferIn;
|
||||||
|
#endif
|
||||||
|
fCurrentAudioDevice->processBuffer(insPtr, DISTRHO_PLUGIN_NUM_INPUTS,
|
||||||
fAudioBufferOut, DISTRHO_PLUGIN_NUM_OUTPUTS, frames);
|
fAudioBufferOut, DISTRHO_PLUGIN_NUM_OUTPUTS, frames);
|
||||||
|
}
|
||||||
|
|
||||||
if (fCurrentMidiOutput != nullptr)
|
if (fCurrentMidiOutput != nullptr)
|
||||||
fCurrentMidiOutput->processMessages();
|
fCurrentMidiOutput->processMessages();
|
||||||
|
|
1
src/CardinalSynth/CardinalPlugin.cpp
Symbolic link
1
src/CardinalSynth/CardinalPlugin.cpp
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
../CardinalPlugin.cpp
|
1
src/CardinalSynth/CardinalUI.cpp
Symbolic link
1
src/CardinalSynth/CardinalUI.cpp
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
../CardinalUI.cpp
|
42
src/CardinalSynth/DistrhoPluginInfo.h
Normal file
42
src/CardinalSynth/DistrhoPluginInfo.h
Normal file
|
@ -0,0 +1,42 @@
|
||||||
|
/*
|
||||||
|
* DISTRHO Cardinal Plugin
|
||||||
|
* Copyright (C) 2021 Filipe Coelho <falktx@falktx.com>
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation; either version 3 of
|
||||||
|
* the License, or any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* For a full copy of the GNU General Public License see the LICENSE file.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef DISTRHO_PLUGIN_INFO_H_INCLUDED
|
||||||
|
#define DISTRHO_PLUGIN_INFO_H_INCLUDED
|
||||||
|
|
||||||
|
#define DISTRHO_PLUGIN_BRAND "DISTRHO"
|
||||||
|
#define DISTRHO_PLUGIN_NAME "Cardinal"
|
||||||
|
#define DISTRHO_PLUGIN_URI "https://distrho.kx.studio/plugins/cardinal#synth"
|
||||||
|
|
||||||
|
#ifdef HEADLESS
|
||||||
|
#define DISTRHO_PLUGIN_HAS_UI 0
|
||||||
|
#else
|
||||||
|
#define DISTRHO_PLUGIN_HAS_UI 1
|
||||||
|
#define DISTRHO_PLUGIN_WANT_DIRECT_ACCESS 1
|
||||||
|
#define DISTRHO_UI_USE_NANOVG 1
|
||||||
|
#define DISTRHO_UI_USER_RESIZABLE 1
|
||||||
|
#endif
|
||||||
|
#define DISTRHO_PLUGIN_IS_SYNTH 1
|
||||||
|
#define DISTRHO_PLUGIN_NUM_INPUTS 0
|
||||||
|
#define DISTRHO_PLUGIN_NUM_OUTPUTS 2
|
||||||
|
#define DISTRHO_PLUGIN_WANT_MIDI_INPUT 1
|
||||||
|
#define DISTRHO_PLUGIN_WANT_MIDI_OUTPUT 1
|
||||||
|
#define DISTRHO_PLUGIN_WANT_FULL_STATE 1
|
||||||
|
#define DISTRHO_PLUGIN_WANT_STATE 1
|
||||||
|
#define DISTRHO_PLUGIN_WANT_TIMEPOS 1
|
||||||
|
|
||||||
|
#endif // DISTRHO_PLUGIN_INFO_H_INCLUDED
|
8
src/CardinalSynth/Makefile
Normal file
8
src/CardinalSynth/Makefile
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
#!/usr/bin/make -f
|
||||||
|
# Makefile for DISTRHO Plugins #
|
||||||
|
# ---------------------------- #
|
||||||
|
# Created by falkTX
|
||||||
|
#
|
||||||
|
|
||||||
|
NAME = CardinalSynth
|
||||||
|
include ../Makefile.cardinal.mk
|
1
src/CardinalSynth/MenuBar.cpp
Symbolic link
1
src/CardinalSynth/MenuBar.cpp
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
../override/MenuBar.cpp
|
1
src/CardinalSynth/RemoteNanoVG.cpp
Symbolic link
1
src/CardinalSynth/RemoteNanoVG.cpp
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
../override/RemoteNanoVG.cpp
|
1
src/CardinalSynth/RemoteWindow.cpp
Symbolic link
1
src/CardinalSynth/RemoteWindow.cpp
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
../override/RemoteWindow.cpp
|
1
src/CardinalSynth/Window.cpp
Symbolic link
1
src/CardinalSynth/Window.cpp
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
../override/Window.cpp
|
1
src/CardinalSynth/common.cpp
Symbolic link
1
src/CardinalSynth/common.cpp
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
../override/common.cpp
|
222
src/Makefile
222
src/Makefile
|
@ -11,36 +11,6 @@ PREFIX ?= /usr/local
|
||||||
DESTDIR ?=
|
DESTDIR ?=
|
||||||
SYSDEPS ?= false
|
SYSDEPS ?= false
|
||||||
|
|
||||||
# --------------------------------------------------------------
|
|
||||||
# Project name, used for binaries
|
|
||||||
|
|
||||||
NAME = Cardinal
|
|
||||||
|
|
||||||
# --------------------------------------------------------------
|
|
||||||
# Files to build (DPF stuff)
|
|
||||||
|
|
||||||
FILES_DSP = \
|
|
||||||
CardinalPlugin.cpp \
|
|
||||||
override/asset.cpp \
|
|
||||||
override/common.cpp \
|
|
||||||
override/context.cpp \
|
|
||||||
override/dep.cpp \
|
|
||||||
override/library.cpp \
|
|
||||||
override/network.cpp \
|
|
||||||
override/osdialog.cpp
|
|
||||||
|
|
||||||
ifeq ($(HEADLESS),true)
|
|
||||||
FILES_DSP += \
|
|
||||||
override/RemoteNanoVG.cpp \
|
|
||||||
override/RemoteWindow.cpp
|
|
||||||
else
|
|
||||||
FILES_UI = \
|
|
||||||
CardinalUI.cpp \
|
|
||||||
AsyncDialog.cpp \
|
|
||||||
override/MenuBar.cpp \
|
|
||||||
override/Window.cpp
|
|
||||||
endif
|
|
||||||
|
|
||||||
# --------------------------------------------------------------
|
# --------------------------------------------------------------
|
||||||
# Import base definitions
|
# Import base definitions
|
||||||
|
|
||||||
|
@ -48,61 +18,9 @@ USE_NANOVG_FBO = true
|
||||||
include ../dpf/Makefile.base.mk
|
include ../dpf/Makefile.base.mk
|
||||||
|
|
||||||
# --------------------------------------------------------------
|
# --------------------------------------------------------------
|
||||||
# Files to build (VCV stuff)
|
# Build setup
|
||||||
|
|
||||||
FILES_DSP += Rack/dep/pffft/pffft.c
|
BUILD_DIR = ../build/rack
|
||||||
FILES_DSP += Rack/dep/pffft/fftpack.c
|
|
||||||
FILES_DSP += Rack/dep/osdialog/osdialog.c
|
|
||||||
FILES_DSP += Rack/dep/oui-blendish/blendish.c
|
|
||||||
|
|
||||||
IGNORED_FILES = Rack/src/asset.cpp
|
|
||||||
IGNORED_FILES += Rack/src/common.cpp
|
|
||||||
IGNORED_FILES += Rack/src/context.cpp
|
|
||||||
IGNORED_FILES += Rack/src/dep.cpp
|
|
||||||
IGNORED_FILES += Rack/src/discord.cpp
|
|
||||||
IGNORED_FILES += Rack/src/gamepad.cpp
|
|
||||||
IGNORED_FILES += Rack/src/keyboard.cpp
|
|
||||||
IGNORED_FILES += Rack/src/library.cpp
|
|
||||||
IGNORED_FILES += Rack/src/network.cpp
|
|
||||||
IGNORED_FILES += Rack/src/rtaudio.cpp
|
|
||||||
IGNORED_FILES += Rack/src/rtmidi.cpp
|
|
||||||
IGNORED_FILES += Rack/src/app/MenuBar.cpp
|
|
||||||
IGNORED_FILES += Rack/src/window/Window.cpp
|
|
||||||
|
|
||||||
FILES_DSP += $(wildcard Rack/src/*.c)
|
|
||||||
FILES_DSP += $(wildcard Rack/src/*/*.c)
|
|
||||||
FILES_DSP += $(filter-out $(IGNORED_FILES),$(wildcard Rack/src/*.cpp))
|
|
||||||
FILES_DSP += $(filter-out $(IGNORED_FILES), $(wildcard Rack/src/*/*.cpp))
|
|
||||||
|
|
||||||
# --------------------------------------------------------------
|
|
||||||
# Extra libraries to link against
|
|
||||||
|
|
||||||
ifneq ($(SYSDEPS),true)
|
|
||||||
EXTRA_LIBS = ../plugins/plugins.a
|
|
||||||
EXTRA_LIBS += Rack/dep/lib/libjansson.a
|
|
||||||
EXTRA_LIBS += Rack/dep/lib/libsamplerate.a
|
|
||||||
EXTRA_LIBS += Rack/dep/lib/libspeexdsp.a
|
|
||||||
ifeq ($(WINDOWS),true)
|
|
||||||
EXTRA_LIBS += Rack/dep/lib/libarchive_static.a
|
|
||||||
else
|
|
||||||
EXTRA_LIBS += Rack/dep/lib/libarchive.a
|
|
||||||
endif
|
|
||||||
EXTRA_LIBS += Rack/dep/lib/libzstd.a
|
|
||||||
|
|
||||||
EXTRA_DEPENDENCIES = $(EXTRA_LIBS)
|
|
||||||
endif
|
|
||||||
|
|
||||||
# --------------------------------------------------------------
|
|
||||||
# Do some magic
|
|
||||||
|
|
||||||
DPF_PATH = ../dpf
|
|
||||||
DPF_BUILD_DIR = ../build
|
|
||||||
DPF_TARGET_DIR = ../bin
|
|
||||||
USE_VST2_BUNDLE = true
|
|
||||||
include ../dpf/Makefile.plugins.mk
|
|
||||||
|
|
||||||
# --------------------------------------------------------------
|
|
||||||
# Extra flags for VCV stuff
|
|
||||||
|
|
||||||
ifeq ($(MACOS),true)
|
ifeq ($(MACOS),true)
|
||||||
BASE_FLAGS += -DARCH_MAC
|
BASE_FLAGS += -DARCH_MAC
|
||||||
|
@ -114,6 +32,7 @@ endif
|
||||||
|
|
||||||
BASE_FLAGS += -fno-finite-math-only
|
BASE_FLAGS += -fno-finite-math-only
|
||||||
BASE_FLAGS += -I../dpf/dgl/src/nanovg
|
BASE_FLAGS += -I../dpf/dgl/src/nanovg
|
||||||
|
BASE_FLAGS += -I../dpf/distrho
|
||||||
BASE_FLAGS += -I../include
|
BASE_FLAGS += -I../include
|
||||||
BASE_FLAGS += -I../include/neon-compat
|
BASE_FLAGS += -I../include/neon-compat
|
||||||
BASE_FLAGS += -IRack/include
|
BASE_FLAGS += -IRack/include
|
||||||
|
@ -148,6 +67,41 @@ endif
|
||||||
|
|
||||||
BUILD_C_FLAGS += -std=gnu11
|
BUILD_C_FLAGS += -std=gnu11
|
||||||
|
|
||||||
|
# --------------------------------------------------------------
|
||||||
|
# Rack files to build
|
||||||
|
|
||||||
|
RACK_FILES += AsyncDialog.cpp
|
||||||
|
RACK_FILES += override/asset.cpp
|
||||||
|
RACK_FILES += override/context.cpp
|
||||||
|
RACK_FILES += override/dep.cpp
|
||||||
|
RACK_FILES += override/library.cpp
|
||||||
|
RACK_FILES += override/network.cpp
|
||||||
|
RACK_FILES += override/osdialog.cpp
|
||||||
|
|
||||||
|
RACK_FILES += Rack/dep/pffft/pffft.c
|
||||||
|
RACK_FILES += Rack/dep/pffft/fftpack.c
|
||||||
|
RACK_FILES += Rack/dep/osdialog/osdialog.c
|
||||||
|
RACK_FILES += Rack/dep/oui-blendish/blendish.c
|
||||||
|
|
||||||
|
IGNORED_FILES = Rack/src/asset.cpp
|
||||||
|
IGNORED_FILES += Rack/src/common.cpp
|
||||||
|
IGNORED_FILES += Rack/src/context.cpp
|
||||||
|
IGNORED_FILES += Rack/src/dep.cpp
|
||||||
|
IGNORED_FILES += Rack/src/discord.cpp
|
||||||
|
IGNORED_FILES += Rack/src/gamepad.cpp
|
||||||
|
IGNORED_FILES += Rack/src/keyboard.cpp
|
||||||
|
IGNORED_FILES += Rack/src/library.cpp
|
||||||
|
IGNORED_FILES += Rack/src/network.cpp
|
||||||
|
IGNORED_FILES += Rack/src/rtaudio.cpp
|
||||||
|
IGNORED_FILES += Rack/src/rtmidi.cpp
|
||||||
|
IGNORED_FILES += Rack/src/app/MenuBar.cpp
|
||||||
|
IGNORED_FILES += Rack/src/window/Window.cpp
|
||||||
|
|
||||||
|
RACK_FILES += $(wildcard Rack/src/*.c)
|
||||||
|
RACK_FILES += $(wildcard Rack/src/*/*.c)
|
||||||
|
RACK_FILES += $(filter-out $(IGNORED_FILES),$(wildcard Rack/src/*.cpp))
|
||||||
|
RACK_FILES += $(filter-out $(IGNORED_FILES), $(wildcard Rack/src/*/*.cpp))
|
||||||
|
|
||||||
# --------------------------------------------------------------
|
# --------------------------------------------------------------
|
||||||
# FIXME lots of warnings from VCV side
|
# FIXME lots of warnings from VCV side
|
||||||
|
|
||||||
|
@ -155,90 +109,46 @@ BASE_FLAGS += -Wno-unused-parameter
|
||||||
BASE_FLAGS += -Wno-unused-variable
|
BASE_FLAGS += -Wno-unused-variable
|
||||||
|
|
||||||
# --------------------------------------------------------------
|
# --------------------------------------------------------------
|
||||||
# extra linker flags
|
# Build targets
|
||||||
|
|
||||||
LINK_FLAGS += -pthread
|
TARGET = rack.a
|
||||||
|
|
||||||
ifneq ($(HAIKU_OR_MACOS_OR_WINDOWS),true)
|
all: $(TARGET)
|
||||||
LINK_FLAGS += -ldl
|
$(MAKE) -C Cardinal
|
||||||
endif
|
$(MAKE) -C CardinalSynth
|
||||||
|
|
||||||
ifeq ($(MACOS),true)
|
resources:
|
||||||
LINK_FLAGS += -framework IOKit
|
$(MAKE) resources -C Cardinal
|
||||||
else ifeq ($(WINDOWS),true)
|
$(MAKE) resources -C CardinalSynth
|
||||||
LINK_FLAGS += -ldbghelp -lshlwapi
|
|
||||||
# needed by JW-Modules
|
|
||||||
EXTRA_LIBS += -lws2_32 -lwinmm
|
|
||||||
endif
|
|
||||||
|
|
||||||
ifeq ($(SYSDEPS),true)
|
clean:
|
||||||
LINK_FLAGS += $(shell pkg-config --libs jansson libarchive samplerate speexdsp)
|
rm -f $(TARGET)
|
||||||
endif
|
rm -rf $(BUILD_DIR)
|
||||||
|
$(MAKE) clean -C Cardinal
|
||||||
ifeq ($(WITH_LTO),true)
|
$(MAKE) clean -C CardinalSynth
|
||||||
LINK_FLAGS += -fno-strict-aliasing -flto -Werror=odr -Werror=lto-type-mismatch
|
|
||||||
endif
|
|
||||||
|
|
||||||
# --------------------------------------------------------------
|
# --------------------------------------------------------------
|
||||||
# optional liblo
|
# Build commands
|
||||||
|
|
||||||
ifeq ($(HAVE_LIBLO),true)
|
RACK_OBJS = $(RACK_FILES:%=$(BUILD_DIR)/%.o)
|
||||||
BASE_FLAGS += $(LIBLO_FLAGS)
|
|
||||||
LINK_FLAGS += $(LIBLO_LIBS)
|
|
||||||
endif
|
|
||||||
|
|
||||||
# --------------------------------------------------------------
|
$(TARGET): $(RACK_OBJS)
|
||||||
# fallback path to resource files
|
@echo "Creating $@"
|
||||||
|
$(SILENT)rm -f $@
|
||||||
|
$(SILENT)$(AR) crs $@ $^
|
||||||
|
|
||||||
ifeq ($(EXE_WRAPPER),wine)
|
$(BUILD_DIR)/%.c.o: %.c
|
||||||
SOURCE_DIR = Z:$(subst /,\\,$(CURDIR))
|
-@mkdir -p "$(shell dirname $(BUILD_DIR)/$<)"
|
||||||
else
|
@echo "Compiling $<"
|
||||||
SOURCE_DIR = $(CURDIR)
|
$(SILENT)$(CC) $< $(BUILD_C_FLAGS) -c -o $@
|
||||||
endif
|
|
||||||
|
|
||||||
ifneq ($(SYSDEPS),true)
|
$(BUILD_DIR)/%.cpp.o: %.cpp
|
||||||
BUILD_CXX_FLAGS += -DCARDINAL_PLUGIN_SOURCE_DIR='"$(SOURCE_DIR)"'
|
-@mkdir -p "$(shell dirname $(BUILD_DIR)/$<)"
|
||||||
endif
|
@echo "Compiling $<"
|
||||||
|
$(SILENT)$(CXX) $< $(BUILD_CXX_FLAGS) -c -o $@
|
||||||
BUILD_CXX_FLAGS += -DCARDINAL_PLUGIN_PREFIX='"$(PREFIX)"'
|
|
||||||
|
|
||||||
# --------------------------------------------------------------
|
|
||||||
# Enable all possible plugin types
|
|
||||||
|
|
||||||
all: jack lv2 vst2 vst3 resources
|
|
||||||
|
|
||||||
# --------------------------------------------------------------
|
# --------------------------------------------------------------
|
||||||
|
|
||||||
CORE_RESOURCES = $(subst Rack/res/,,$(wildcard Rack/res/*)) template.vcv
|
-include $(RACK_OBJS:%.o=%.d)
|
||||||
|
|
||||||
PLUGIN_RESOURCES += $(CORE_RESOURCES:%=../bin/Cardinal.lv2/resources/%)
|
|
||||||
ifeq ($(MACOS),true)
|
|
||||||
PLUGIN_RESOURCES += $(CORE_RESOURCES:%=../bin/Cardinal.vst/Contents/Resources/%)
|
|
||||||
else
|
|
||||||
PLUGIN_RESOURCES += $(CORE_RESOURCES:%=../bin/Cardinal.vst/resources/%)
|
|
||||||
endif
|
|
||||||
PLUGIN_RESOURCES += $(CORE_RESOURCES:%=../bin/Cardinal.vst3/Contents/Resources/%)
|
|
||||||
|
|
||||||
resources: $(PLUGIN_RESOURCES)
|
|
||||||
|
|
||||||
../bin/Cardinal.%/template.vcv: template.vcv
|
|
||||||
-@mkdir -p "$(shell dirname $@)"
|
|
||||||
ln -sf $(abspath $<) $@
|
|
||||||
|
|
||||||
../bin/Cardinal.lv2/resources/%: Rack/res/%
|
|
||||||
-@mkdir -p "$(shell dirname $@)"
|
|
||||||
ln -sf $(abspath $<) $@
|
|
||||||
|
|
||||||
../bin/Cardinal.vst/resources/%: Rack/res/%
|
|
||||||
-@mkdir -p "$(shell dirname $@)"
|
|
||||||
ln -sf $(abspath $<) $@
|
|
||||||
|
|
||||||
../bin/Cardinal.vst/Contents/Resources/%: Rack/res/%
|
|
||||||
-@mkdir -p "$(shell dirname $@)"
|
|
||||||
ln -sf $(abspath $<) $@
|
|
||||||
|
|
||||||
../bin/Cardinal.vst3/Contents/Resources/%: Rack/res/%
|
|
||||||
-@mkdir -p "$(shell dirname $@)"
|
|
||||||
ln -sf $(abspath $<) $@
|
|
||||||
|
|
||||||
# --------------------------------------------------------------
|
# --------------------------------------------------------------
|
||||||
|
|
217
src/Makefile.cardinal.mk
Normal file
217
src/Makefile.cardinal.mk
Normal file
|
@ -0,0 +1,217 @@
|
||||||
|
#!/usr/bin/make -f
|
||||||
|
# Makefile for DISTRHO Plugins #
|
||||||
|
# ---------------------------- #
|
||||||
|
# Created by falkTX
|
||||||
|
#
|
||||||
|
|
||||||
|
# Must have NAME defined
|
||||||
|
|
||||||
|
# --------------------------------------------------------------
|
||||||
|
# Build config
|
||||||
|
|
||||||
|
PREFIX ?= /usr/local
|
||||||
|
DESTDIR ?=
|
||||||
|
SYSDEPS ?= false
|
||||||
|
|
||||||
|
# --------------------------------------------------------------
|
||||||
|
# Files to build (DPF stuff)
|
||||||
|
|
||||||
|
FILES_DSP = CardinalPlugin.cpp
|
||||||
|
FILES_DSP += common.cpp
|
||||||
|
|
||||||
|
ifeq ($(HEADLESS),true)
|
||||||
|
FILES_DSP += RemoteNanoVG.cpp
|
||||||
|
FILES_DSP += RemoteWindow.cpp
|
||||||
|
else
|
||||||
|
FILES_UI = CardinalUI.cpp
|
||||||
|
FILES_UI += MenuBar.cpp
|
||||||
|
FILES_UI += Window.cpp
|
||||||
|
endif
|
||||||
|
|
||||||
|
# --------------------------------------------------------------
|
||||||
|
# Extra libraries to link against
|
||||||
|
|
||||||
|
EXTRA_LIBS = ../../plugins/plugins.a
|
||||||
|
EXTRA_LIBS += ../rack.a
|
||||||
|
|
||||||
|
ifneq ($(SYSDEPS),true)
|
||||||
|
EXTRA_LIBS += ../Rack/dep/lib/libjansson.a
|
||||||
|
EXTRA_LIBS += ../Rack/dep/lib/libsamplerate.a
|
||||||
|
EXTRA_LIBS += ../Rack/dep/lib/libspeexdsp.a
|
||||||
|
ifeq ($(WINDOWS),true)
|
||||||
|
EXTRA_LIBS += ../Rack/dep/lib/libarchive_static.a
|
||||||
|
else
|
||||||
|
EXTRA_LIBS += ../Rack/dep/lib/libarchive.a
|
||||||
|
endif
|
||||||
|
EXTRA_LIBS += ../Rack/dep/lib/libzstd.a
|
||||||
|
endif
|
||||||
|
|
||||||
|
EXTRA_DEPENDENCIES = $(EXTRA_LIBS)
|
||||||
|
|
||||||
|
# --------------------------------------------------------------
|
||||||
|
# Do some magic
|
||||||
|
|
||||||
|
USE_NANOVG_FBO = true
|
||||||
|
USE_VST2_BUNDLE = true
|
||||||
|
include ../../dpf/Makefile.plugins.mk
|
||||||
|
|
||||||
|
# --------------------------------------------------------------
|
||||||
|
# Extra flags for VCV stuff
|
||||||
|
|
||||||
|
ifeq ($(MACOS),true)
|
||||||
|
BASE_FLAGS += -DARCH_MAC
|
||||||
|
else ifeq ($(WINDOWS),true)
|
||||||
|
BASE_FLAGS += -DARCH_WIN
|
||||||
|
else
|
||||||
|
BASE_FLAGS += -DARCH_LIN
|
||||||
|
endif
|
||||||
|
|
||||||
|
BASE_FLAGS += -fno-finite-math-only
|
||||||
|
BASE_FLAGS += -I..
|
||||||
|
BASE_FLAGS += -I../../dpf/dgl/src/nanovg
|
||||||
|
BASE_FLAGS += -I../../include
|
||||||
|
BASE_FLAGS += -I../../include/neon-compat
|
||||||
|
BASE_FLAGS += -I../Rack/include
|
||||||
|
ifeq ($(SYSDEPS),true)
|
||||||
|
BASE_FLAGS += $(shell pkg-config --cflags jansson libarchive samplerate speexdsp)
|
||||||
|
else
|
||||||
|
BASE_FLAGS += -I../Rack/dep/include
|
||||||
|
endif
|
||||||
|
BASE_FLAGS += -I../Rack/dep/glfw/include
|
||||||
|
BASE_FLAGS += -I../Rack/dep/nanosvg/src
|
||||||
|
BASE_FLAGS += -I../Rack/dep/oui-blendish
|
||||||
|
BASE_FLAGS += -pthread
|
||||||
|
|
||||||
|
ifeq ($(WINDOWS),true)
|
||||||
|
BASE_FLAGS += -D_USE_MATH_DEFINES
|
||||||
|
BASE_FLAGS += -DWIN32_LEAN_AND_MEAN
|
||||||
|
BASE_FLAGS += -I../../include/mingw-compat
|
||||||
|
BASE_FLAGS += -I../../include/mingw-std-threads
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifeq ($(HEADLESS),true)
|
||||||
|
BASE_FLAGS += -DHEADLESS
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifeq ($(WITH_LTO),true)
|
||||||
|
BASE_FLAGS += -fno-strict-aliasing -flto
|
||||||
|
endif
|
||||||
|
|
||||||
|
BUILD_C_FLAGS += -std=gnu11
|
||||||
|
|
||||||
|
# --------------------------------------------------------------
|
||||||
|
# FIXME lots of warnings from VCV side
|
||||||
|
|
||||||
|
BASE_FLAGS += -Wno-unused-parameter
|
||||||
|
BASE_FLAGS += -Wno-unused-variable
|
||||||
|
|
||||||
|
# --------------------------------------------------------------
|
||||||
|
# extra linker flags
|
||||||
|
|
||||||
|
LINK_FLAGS += -pthread
|
||||||
|
|
||||||
|
ifneq ($(HAIKU_OR_MACOS_OR_WINDOWS),true)
|
||||||
|
LINK_FLAGS += -ldl
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifeq ($(MACOS),true)
|
||||||
|
LINK_FLAGS += -framework IOKit
|
||||||
|
else ifeq ($(WINDOWS),true)
|
||||||
|
LINK_FLAGS += -ldbghelp -lshlwapi
|
||||||
|
# needed by JW-Modules
|
||||||
|
EXTRA_LIBS += -lws2_32 -lwinmm
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifeq ($(SYSDEPS),true)
|
||||||
|
LINK_FLAGS += $(shell pkg-config --libs jansson libarchive samplerate speexdsp)
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifeq ($(WITH_LTO),true)
|
||||||
|
LINK_FLAGS += -fno-strict-aliasing -flto -Werror=odr -Werror=lto-type-mismatch
|
||||||
|
endif
|
||||||
|
|
||||||
|
# --------------------------------------------------------------
|
||||||
|
# optional liblo
|
||||||
|
|
||||||
|
ifeq ($(HAVE_LIBLO),true)
|
||||||
|
BASE_FLAGS += $(LIBLO_FLAGS)
|
||||||
|
LINK_FLAGS += $(LIBLO_LIBS)
|
||||||
|
endif
|
||||||
|
|
||||||
|
# --------------------------------------------------------------
|
||||||
|
# fallback path to resource files
|
||||||
|
|
||||||
|
ifeq ($(EXE_WRAPPER),wine)
|
||||||
|
SOURCE_DIR = Z:$(subst /,\\,$(abspath $(CURDIR)/..))
|
||||||
|
else
|
||||||
|
SOURCE_DIR = $(abspath $(CURDIR)/..)
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifneq ($(SYSDEPS),true)
|
||||||
|
BUILD_CXX_FLAGS += -DCARDINAL_PLUGIN_SOURCE_DIR='"$(SOURCE_DIR)"'
|
||||||
|
endif
|
||||||
|
|
||||||
|
BUILD_CXX_FLAGS += -DCARDINAL_PLUGIN_PREFIX='"$(PREFIX)"'
|
||||||
|
|
||||||
|
# --------------------------------------------------------------
|
||||||
|
# Enable all possible plugin types
|
||||||
|
|
||||||
|
all: jack lv2 vst2 vst3 resources
|
||||||
|
|
||||||
|
# --------------------------------------------------------------
|
||||||
|
|
||||||
|
ifeq ($(NAME),Cardinal)
|
||||||
|
|
||||||
|
CORE_RESOURCES = $(subst ../Rack/res/,,$(wildcard ../Rack/res/*)) ../template.vcv
|
||||||
|
|
||||||
|
PLUGIN_RESOURCES += $(CORE_RESOURCES:%=$(TARGET_DIR)/Cardinal.lv2/resources/%)
|
||||||
|
ifeq ($(MACOS),true)
|
||||||
|
PLUGIN_RESOURCES += $(CORE_RESOURCES:%=$(TARGET_DIR)/Cardinal.vst/Contents/Resources/%)
|
||||||
|
else
|
||||||
|
PLUGIN_RESOURCES += $(CORE_RESOURCES:%=$(TARGET_DIR)/Cardinal.vst/resources/%)
|
||||||
|
endif
|
||||||
|
PLUGIN_RESOURCES += $(CORE_RESOURCES:%=$(TARGET_DIR)/Cardinal.vst3/Contents/Resources/%)
|
||||||
|
|
||||||
|
else
|
||||||
|
|
||||||
|
PLUGIN_RESOURCES += $(TARGET_DIR)/$(NAME).lv2/resources
|
||||||
|
ifeq ($(MACOS),true)
|
||||||
|
PLUGIN_RESOURCES += $(TARGET_DIR)/$(NAME).vst/Contents/Resources
|
||||||
|
else
|
||||||
|
PLUGIN_RESOURCES += $(TARGET_DIR)/$(NAME).vst/resources
|
||||||
|
endif
|
||||||
|
PLUGIN_RESOURCES += $(TARGET_DIR)/$(NAME).vst3/Contents/Resources
|
||||||
|
|
||||||
|
endif
|
||||||
|
|
||||||
|
# --------------------------------------------------------------
|
||||||
|
|
||||||
|
resources: $(PLUGIN_RESOURCES)
|
||||||
|
|
||||||
|
ifneq ($(NAME),Cardinal)
|
||||||
|
$(TARGET_DIR)/$(NAME).%: $(TARGET_DIR)/Cardinal.%
|
||||||
|
-@mkdir -p "$(shell dirname $@)"
|
||||||
|
ln -sf $(abspath $<) $@
|
||||||
|
endif
|
||||||
|
|
||||||
|
$(TARGET_DIR)/Cardinal.%/template.vcv: ../template.vcv
|
||||||
|
-@mkdir -p "$(shell dirname $@)"
|
||||||
|
ln -sf $(abspath $<) $@
|
||||||
|
|
||||||
|
$(TARGET_DIR)/Cardinal.lv2/resources/%: ../Rack/res/%
|
||||||
|
-@mkdir -p "$(shell dirname $@)"
|
||||||
|
ln -sf $(abspath $<) $@
|
||||||
|
|
||||||
|
$(TARGET_DIR)/Cardinal.vst/resources/%: ../Rack/res/%
|
||||||
|
-@mkdir -p "$(shell dirname $@)"
|
||||||
|
ln -sf $(abspath $<) $@
|
||||||
|
|
||||||
|
$(TARGET_DIR)/Cardinal.vst/Contents/Resources/%: ../Rack/res/%
|
||||||
|
-@mkdir -p "$(shell dirname $@)"
|
||||||
|
ln -sf $(abspath $<) $@
|
||||||
|
|
||||||
|
$(TARGET_DIR)/Cardinal.vst3/Contents/Resources/%: ../Rack/res/%
|
||||||
|
-@mkdir -p "$(shell dirname $@)"
|
||||||
|
ln -sf $(abspath $<) $@
|
||||||
|
|
||||||
|
# --------------------------------------------------------------
|
|
@ -29,8 +29,6 @@
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include <thread>
|
#include <thread>
|
||||||
|
|
||||||
#include <osdialog.h>
|
|
||||||
|
|
||||||
#include <window/Window.hpp>
|
#include <window/Window.hpp>
|
||||||
#include <asset.hpp>
|
#include <asset.hpp>
|
||||||
#include <widget/Widget.hpp>
|
#include <widget/Widget.hpp>
|
||||||
|
|
|
@ -19,6 +19,10 @@
|
||||||
#include <system.hpp>
|
#include <system.hpp>
|
||||||
#include <plugin/Plugin.hpp>
|
#include <plugin/Plugin.hpp>
|
||||||
|
|
||||||
|
#ifdef NDEBUG
|
||||||
|
# undef DEBUG
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
|
|
||||||
#include "DistrhoUtils.hpp"
|
#include "DistrhoUtils.hpp"
|
||||||
|
|
|
@ -28,6 +28,10 @@
|
||||||
#include <common.hpp>
|
#include <common.hpp>
|
||||||
#include <string.hpp>
|
#include <string.hpp>
|
||||||
|
|
||||||
|
#ifdef NDEBUG
|
||||||
|
# undef DEBUG
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "DistrhoPluginUtils.hpp"
|
#include "DistrhoPluginUtils.hpp"
|
||||||
|
|
||||||
// fopen_u8
|
// fopen_u8
|
||||||
|
|
|
@ -6,7 +6,11 @@
|
||||||
#include <history.hpp>
|
#include <history.hpp>
|
||||||
#include <settings.hpp>
|
#include <settings.hpp>
|
||||||
|
|
||||||
#include "DistrhoPluginUtils.hpp"
|
#ifdef NDEBUG
|
||||||
|
# undef DEBUG
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "DistrhoUtils.hpp"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This file is an edited version of VCVRack's context.cpp
|
* This file is an edited version of VCVRack's context.cpp
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue