forked from DISTRHO/Cardinal
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Signed-off-by: falkTX <falktx@falktx.com>
- Loading branch information
Showing
9 changed files
with
584 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
../CardinalCommon.cpp |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
../Cardinal/DistrhoPluginInfo.h |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,292 @@ | ||
#!/usr/bin/make -f | ||
# Makefile for DISTRHO Plugins # | ||
# ---------------------------- # | ||
# Created by falkTX | ||
# | ||
|
||
# -------------------------------------------------------------- | ||
# Carla stuff | ||
|
||
CWD = ../../carla/source | ||
STATIC_PLUGIN_TARGET = true | ||
include $(CWD)/Makefile.deps.mk | ||
|
||
CARLA_BUILD_DIR = ../../carla/build | ||
ifeq ($(DEBUG),true) | ||
CARLA_BUILD_TYPE = Debug | ||
else | ||
CARLA_BUILD_TYPE = Release | ||
endif | ||
|
||
CARLA_EXTRA_LIBS = $(CARLA_BUILD_DIR)/plugin/$(CARLA_BUILD_TYPE)/carla-host-plugin.cpp.o | ||
CARLA_EXTRA_LIBS += $(CARLA_BUILD_DIR)/modules/$(CARLA_BUILD_TYPE)/carla_engine_plugin.a | ||
CARLA_EXTRA_LIBS += $(CARLA_BUILD_DIR)/modules/$(CARLA_BUILD_TYPE)/carla_plugin.a | ||
CARLA_EXTRA_LIBS += $(CARLA_BUILD_DIR)/modules/$(CARLA_BUILD_TYPE)/native-plugins.a | ||
CARLA_EXTRA_LIBS += $(CARLA_BUILD_DIR)/modules/$(CARLA_BUILD_TYPE)/audio_decoder.a | ||
CARLA_EXTRA_LIBS += $(CARLA_BUILD_DIR)/modules/$(CARLA_BUILD_TYPE)/jackbridge.min.a | ||
CARLA_EXTRA_LIBS += $(CARLA_BUILD_DIR)/modules/$(CARLA_BUILD_TYPE)/lilv.a | ||
CARLA_EXTRA_LIBS += $(CARLA_BUILD_DIR)/modules/$(CARLA_BUILD_TYPE)/rtmempool.a | ||
CARLA_EXTRA_LIBS += $(CARLA_BUILD_DIR)/modules/$(CARLA_BUILD_TYPE)/sfzero.a | ||
CARLA_EXTRA_LIBS += $(CARLA_BUILD_DIR)/modules/$(CARLA_BUILD_TYPE)/water.a | ||
CARLA_EXTRA_LIBS += $(CARLA_BUILD_DIR)/modules/$(CARLA_BUILD_TYPE)/ysfx.a | ||
CARLA_EXTRA_LIBS += $(CARLA_BUILD_DIR)/modules/$(CARLA_BUILD_TYPE)/zita-resampler.a | ||
|
||
# -------------------------------------------------------------- | ||
# Import base definitions | ||
|
||
USE_NANOVG_FBO = true | ||
include ../../dpf/Makefile.base.mk | ||
|
||
# -------------------------------------------------------------- | ||
# Build config | ||
|
||
PREFIX ?= /usr/local | ||
|
||
ifeq ($(BSD),true) | ||
SYSDEPS ?= true | ||
else | ||
SYSDEPS ?= false | ||
endif | ||
|
||
ifeq ($(SYSDEPS),true) | ||
DEP_LIB_PATH = $(abspath ../../deps/sysroot/lib) | ||
else | ||
DEP_LIB_PATH = $(abspath ../Rack/dep/lib) | ||
endif | ||
|
||
# -------------------------------------------------------------- | ||
# Extra libraries to link against | ||
|
||
RACK_EXTRA_LIBS = ../../plugins/plugins.a | ||
RACK_EXTRA_LIBS += ../rack.a | ||
RACK_EXTRA_LIBS += $(DEP_LIB_PATH)/libquickjs.a | ||
|
||
ifneq ($(SYSDEPS),true) | ||
RACK_EXTRA_LIBS += $(DEP_LIB_PATH)/libjansson.a | ||
RACK_EXTRA_LIBS += $(DEP_LIB_PATH)/libsamplerate.a | ||
RACK_EXTRA_LIBS += $(DEP_LIB_PATH)/libspeexdsp.a | ||
ifeq ($(WINDOWS),true) | ||
RACK_EXTRA_LIBS += $(DEP_LIB_PATH)/libarchive_static.a | ||
else | ||
RACK_EXTRA_LIBS += $(DEP_LIB_PATH)/libarchive.a | ||
endif | ||
RACK_EXTRA_LIBS += $(DEP_LIB_PATH)/libzstd.a | ||
endif | ||
|
||
# -------------------------------------------------------------- | ||
|
||
EXTRA_DEPENDENCIES = $(RACK_EXTRA_LIBS) $(CARLA_EXTRA_LIBS) | ||
EXTRA_LIBS = $(RACK_EXTRA_LIBS) $(CARLA_EXTRA_LIBS) $(STATIC_CARLA_PLUGIN_LIBS) | ||
|
||
ifeq ($(shell pkg-config --exists fftw3f && echo true),true) | ||
EXTRA_DEPENDENCIES += ../../deps/aubio/libaubio.a | ||
EXTRA_LIBS += ../../deps/aubio/libaubio.a | ||
EXTRA_LIBS += $(shell $(PKG_CONFIG) --libs fftw3f) | ||
endif | ||
|
||
# -------------------------------------------------------------- | ||
# Extra flags for liblo | ||
|
||
BASE_FLAGS += -DHAVE_LIBLO | ||
BASE_FLAGS += $(LIBLO_FLAGS) | ||
LINK_FLAGS += $(LIBLO_LIBS) | ||
|
||
# -------------------------------------------------------------- | ||
# 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 += -DPRIVATE= | ||
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 += -DCARDINAL_SYSDEPS | ||
BASE_FLAGS += $(shell pkg-config --cflags jansson libarchive samplerate speexdsp) | ||
else | ||
BASE_FLAGS += -DZSTDLIB_VISIBILITY= | ||
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 | ||
|
||
ifeq ($(WASM),true) | ||
BASE_FLAGS += -DNANOVG_GLES2=1 | ||
BASE_FLAGS += -msse -msse2 -msse3 -msimd128 | ||
else ifneq ($(HAIKU),true) | ||
BASE_FLAGS += -pthread | ||
endif | ||
|
||
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 | ||
|
||
BUILD_C_FLAGS += -std=gnu11 | ||
BUILD_C_FLAGS += -fno-finite-math-only -fno-strict-aliasing | ||
BUILD_CXX_FLAGS += -fno-finite-math-only -fno-strict-aliasing | ||
|
||
ifneq ($(MACOS),true) | ||
BUILD_CXX_FLAGS += -faligned-new -Wno-abi | ||
endif | ||
|
||
# Rack code is not tested for this flag, unset it | ||
BUILD_CXX_FLAGS += -U_GLIBCXX_ASSERTIONS -Wp,-U_GLIBCXX_ASSERTIONS | ||
|
||
# -------------------------------------------------------------- | ||
# FIXME lots of warnings from VCV side | ||
|
||
BASE_FLAGS += -Wno-unused-parameter | ||
BASE_FLAGS += -Wno-unused-variable | ||
|
||
# -------------------------------------------------------------- | ||
# extra linker flags | ||
|
||
ifeq ($(HAIKU),true) | ||
LINK_FLAGS += -lpthread | ||
else | ||
LINK_FLAGS += -pthread | ||
endif | ||
|
||
ifneq ($(HAIKU_OR_MACOS_OR_WINDOWS),true) | ||
ifneq ($(STATIC_BUILD),true) | ||
LINK_FLAGS += -ldl | ||
endif | ||
endif | ||
|
||
ifeq ($(BSD),true) | ||
ifeq ($(DEBUG),true) | ||
LINK_FLAGS += -lexecinfo | ||
endif | ||
endif | ||
|
||
ifeq ($(MACOS),true) | ||
LINK_FLAGS += -framework IOKit | ||
else ifeq ($(WINDOWS),true) | ||
# needed by VCVRack | ||
EXTRA_LIBS += -ldbghelp -lshlwapi -Wl,--stack,0x100000 | ||
# needed by JW-Modules | ||
EXTRA_LIBS += -lws2_32 -lwinmm | ||
endif | ||
|
||
ifeq ($(SYSDEPS),true) | ||
EXTRA_LIBS += $(shell pkg-config --libs jansson libarchive samplerate speexdsp) | ||
endif | ||
|
||
ifeq ($(WITH_LTO),true) | ||
# false positive | ||
LINK_FLAGS += -Wno-alloc-size-larger-than | ||
ifneq ($(SYSDEPS),true) | ||
# triggered by jansson | ||
LINK_FLAGS += -Wno-stringop-overflow | ||
endif | ||
endif | ||
|
||
# -------------------------------------------------------------- | ||
# fallback path to resource files | ||
|
||
ifneq ($(CIBUILD),true) | ||
ifneq ($(SYSDEPS),true) | ||
|
||
ifeq ($(EXE_WRAPPER),wine) | ||
SOURCE_DIR = Z:$(subst /,\\,$(abspath $(CURDIR)/..)) | ||
else | ||
SOURCE_DIR = $(abspath $(CURDIR)/..) | ||
endif | ||
|
||
BUILD_CXX_FLAGS += -DCARDINAL_PLUGIN_SOURCE_DIR='"$(SOURCE_DIR)"' | ||
|
||
endif | ||
endif | ||
|
||
# -------------------------------------------------------------- | ||
# install path prefix for resource files | ||
|
||
BUILD_CXX_FLAGS += -DCARDINAL_PLUGIN_PREFIX='"$(PREFIX)"' | ||
|
||
# -------------------------------------------------------------- | ||
# Files to build | ||
|
||
FILES = main.cpp | ||
FILES += RemoteUI.cpp | ||
FILES += CardinalCommon.cpp | ||
FILES += common.cpp | ||
FILES += glfw.cpp | ||
FILES += Window.cpp | ||
|
||
ifeq ($(WINDOWS),true) | ||
FILES += distrho.rc | ||
endif | ||
|
||
# -------------------------------------------------------------- | ||
# Build setup | ||
|
||
TARGET_DIR = ../../bin | ||
BUILD_DIR = ../../build/CardinalRemote | ||
DPF_PATH = ../../dpf | ||
|
||
DGL_FLAGS += -DDGL_OPENGL -DHAVE_DGL | ||
DGL_FLAGS += $(OPENGL_FLAGS) | ||
DGL_LIBS += $(OPENGL_LIBS) | ||
DGL_LIBS += $(DGL_SYSTEM_LIBS) -lm | ||
DGL_LIB = $(DPF_PATH)/build/libdgl-opengl.a | ||
|
||
BUILD_C_FLAGS += -I. | ||
BUILD_CXX_FLAGS += -I. -I$(DPF_PATH)/distrho -I$(DPF_PATH)/dgl | ||
|
||
OBJS = $(FILES:%=$(BUILD_DIR)/%.o) | ||
|
||
all: $(TARGET_DIR)/CardinalRemote$(APP_EXT) | ||
|
||
# --------------------------------------------------------------------------------------------------------------------- | ||
|
||
$(TARGET_DIR)/CardinalRemote$(APP_EXT): $(OBJS) $(DGL_LIB) | ||
-@mkdir -p $(shell dirname $@) | ||
@echo "Linking CardinalRemote" | ||
$(SILENT)$(CXX) $^ $(BUILD_CXX_FLAGS) $(LINK_FLAGS) $(EXTRA_LIBS) $(DGL_LIBS) $(JACK_LIBS) -o $@ | ||
|
||
# --------------------------------------------------------------------------------------------------------------------- | ||
# Common | ||
|
||
$(BUILD_DIR)/%.S.o: %.S | ||
-@mkdir -p "$(shell dirname $(BUILD_DIR)/$<)" | ||
@echo "Compiling $<" | ||
@$(CC) $< $(BUILD_C_FLAGS) -c -o $@ | ||
|
||
$(BUILD_DIR)/%.c.o: %.c | ||
-@mkdir -p "$(shell dirname $(BUILD_DIR)/$<)" | ||
@echo "Compiling $<" | ||
$(SILENT)$(CC) $< $(BUILD_C_FLAGS) -c -o $@ | ||
|
||
$(BUILD_DIR)/%.cc.o: %.cc | ||
-@mkdir -p "$(shell dirname $(BUILD_DIR)/$<)" | ||
@echo "Compiling $<" | ||
$(SILENT)$(CXX) $< $(BUILD_CXX_FLAGS) -c -o $@ | ||
|
||
$(BUILD_DIR)/%.cpp.o: %.cpp | ||
-@mkdir -p "$(shell dirname $(BUILD_DIR)/$<)" | ||
@echo "Compiling $<" | ||
$(SILENT)$(CXX) $< $(BUILD_CXX_FLAGS) -c -o $@ | ||
|
||
# -------------------------------------------------------------- | ||
# Extra rules for Windows icon | ||
|
||
ifeq ($(WINDOWS),true) | ||
JACK_LIBS += -Wl,-subsystem,windows | ||
|
||
$(BUILD_DIR)/distrho.rc.o: ../../utils/distrho.rc ../../utils/distrho.ico | ||
-@mkdir -p "$(shell dirname $(BUILD_DIR)/$<)" | ||
@echo "Compiling distrho.rc" | ||
$(SILENT)$(WINDRES) $< -O coff -o $@ | ||
endif |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,91 @@ | ||
/* | ||
* DISTRHO Cardinal Plugin | ||
* Copyright (C) 2021-2022 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. | ||
*/ | ||
|
||
#include "RemoteUI.hpp" | ||
|
||
// #include <asset.hpp> | ||
// #include <random.hpp> | ||
#include <patch.hpp> | ||
#include <settings.hpp> | ||
#include <system.hpp> | ||
|
||
#include <app/Scene.hpp> | ||
#include <engine/Engine.hpp> | ||
|
||
CardinalRemoteUI::CardinalRemoteUI(Window& window, const std::string& templatePath) | ||
: NanoTopLevelWidget(window), | ||
context(nullptr) | ||
{ | ||
// create unique temporary path for this instance | ||
try { | ||
char uidBuf[24]; | ||
const std::string tmp = rack::system::getTempDirectory(); | ||
|
||
for (int i=1;; ++i) | ||
{ | ||
std::snprintf(uidBuf, sizeof(uidBuf), "CardinalRemote.%04d", i); | ||
const std::string trypath = rack::system::join(tmp, uidBuf); | ||
|
||
if (! rack::system::exists(trypath)) | ||
{ | ||
if (rack::system::createDirectories(trypath)) | ||
autosavePath = trypath; | ||
break; | ||
} | ||
} | ||
} DISTRHO_SAFE_EXCEPTION("create unique temporary path"); | ||
|
||
rack::contextSet(&context); | ||
|
||
context.bufferSize = 512; | ||
rack::settings::sampleRate = context.sampleRate = 48000; | ||
|
||
context.engine = new rack::engine::Engine; | ||
context.engine->setSampleRate(context.sampleRate); | ||
|
||
context.history = new rack::history::State; | ||
context.patch = new rack::patch::Manager; | ||
context.patch->autosavePath = autosavePath; | ||
context.patch->templatePath = templatePath; | ||
|
||
context.event = new rack::widget::EventState; | ||
context.scene = new rack::app::Scene; | ||
context.event->rootWidget = context.scene; | ||
context.window = new rack::window::Window; | ||
|
||
context.patch->loadTemplate(); | ||
context.scene->rackScroll->reset(); | ||
|
||
context.nativeWindowId = getWindow().getNativeWindowHandle(); | ||
} | ||
|
||
CardinalRemoteUI::~CardinalRemoteUI() | ||
{ | ||
rack::contextSet(&context); | ||
|
||
context.nativeWindowId = 0; | ||
context.patch->clear(); | ||
|
||
if (! autosavePath.empty()) | ||
rack::system::removeRecursively(autosavePath); | ||
} | ||
|
||
void CardinalRemoteUI::onNanoDisplay() | ||
{ | ||
rack::contextSet(&context); | ||
context.window->step(); | ||
} |
Oops, something went wrong.