improved lv2 Makefile
This commit is contained in:
parent
7c6589302a
commit
90a739181e
@ -21,29 +21,29 @@
|
|||||||
include vars.mk
|
include vars.mk
|
||||||
|
|
||||||
ifeq ($(OS), Windows_NT)
|
ifeq ($(OS), Windows_NT)
|
||||||
DLL_SUFFIX = .dll
|
DLL_SUFFIX := .dll
|
||||||
UI_TYPE = WindowsUI
|
UI_TYPE := WindowsUI
|
||||||
LV2DIR = $(shell echo '${COMMONPROGRAMFILES}' | sed 's:\\:/:g')/LV2
|
LV2DIR := $(shell echo '$(COMMONPROGRAMFILES)' | sed 's:\\:/:g')/LV2
|
||||||
LV2DIR_USER = $(shell echo '${APPDATA}' | sed 's:\\:/:g')/LV2
|
LV2DIR_USER := $(shell echo '$(APPDATA)' | sed 's:\\:/:g')/LV2
|
||||||
CC = gcc
|
CC := gcc
|
||||||
CXX = g++
|
CXX := g++
|
||||||
else
|
else
|
||||||
UNAME_S = $(shell uname -s)
|
UNAME_S = $(shell uname -s)
|
||||||
ifeq ($(UNAME_S), Darwin)
|
ifeq ($(UNAME_S), Darwin)
|
||||||
DLL_SUFFIX = .dylib
|
DLL_SUFFIX := .dylib
|
||||||
UI_TYPE = CocoaUI
|
UI_TYPE := CocoaUI
|
||||||
LV2DIR = /Library/Audio/Plug-Ins/LV2
|
LV2DIR := /Library/Audio/Plug-Ins/LV2
|
||||||
LV2DIR_USER = ${HOME}/Library/Audio/Plug-Ins/LV2
|
LV2DIR_USER := $(HOME)/Library/Audio/Plug-Ins/LV2
|
||||||
CC = clang
|
CC := clang
|
||||||
CXX = clang++
|
CXX := clang++
|
||||||
else
|
else
|
||||||
DLL_SUFFIX = .so
|
DLL_SUFFIX := .so
|
||||||
UI_TYPE = X11UI
|
UI_TYPE := X11UI
|
||||||
PREFIX = /usr/local
|
PREFIX := /usr/local
|
||||||
LV2DIR = ${PREFIX}/lib/lv2
|
LV2DIR := $(PREFIX)/lib/lv2
|
||||||
LV2DIR_USER = ${HOME}/.lv2
|
LV2DIR_USER := $(HOME)/.lv2
|
||||||
CC = gcc
|
CC := gcc
|
||||||
CXX = g++
|
CXX := g++
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
@ -51,59 +51,73 @@ COMMON_DIR := $(or $(COMMON_DIR),.)
|
|||||||
DATA_DIR := $(or $(DATA_DIR),.)
|
DATA_DIR := $(or $(DATA_DIR),.)
|
||||||
PLUGIN_DIR := $(or $(PLUGIN_DIR),src)
|
PLUGIN_DIR := $(or $(PLUGIN_DIR),src)
|
||||||
|
|
||||||
CFLAGS = -O3 -Wall -Wpedantic -Wextra
|
CFLAGS := -O3 -Wall -Wpedantic -Wextra
|
||||||
CFLAGS_ALL = -I${DATA_DIR}/src -I${PLUGIN_DIR} -fPIC ${CFLAGS} ${CFLAGS_EXTRA}
|
CFLAGS_ALL := -I$(DATA_DIR)/src -I$(PLUGIN_DIR) -fPIC $(CFLAGS) $(CFLAGS_EXTRA)
|
||||||
|
|
||||||
LDFLAGS =
|
LDFLAGS :=
|
||||||
LDFLAGS_ALL = -shared ${LDFLAGS} ${LDFLAGS_EXTRA}
|
LDFLAGS_ALL := -shared $(LDFLAGS) $(LDFLAGS_EXTRA)
|
||||||
|
|
||||||
CXXFLAGS = ${CFLAGS}
|
CXXFLAGS := $(CFLAGS)
|
||||||
CXXFLAGS_ALL = -I${DATA_DIR}/src -I${PLUGIN_DIR} -fPIC ${CXXFLAGS} ${CXXFLAGS_EXTRA}
|
CXXFLAGS_ALL := -I$(DATA_DIR)/src -I$(PLUGIN_DIR) -fPIC $(CXXFLAGS) $(CXXFLAGS_EXTRA)
|
||||||
|
|
||||||
ifeq ($(UNAME_S), Darwin)
|
ifeq ($(UNAME_S), Darwin)
|
||||||
CFLAGS_ALL := ${CFLAGS_ALL} -arch arm64 -arch x86_64
|
CFLAGS_ALL := $(CFLAGS_ALL) -arch arm64 -arch x86_64
|
||||||
LDFLAGS_ALL := ${LDFLAGS_ALL} -arch arm64 -arch x86_64
|
LDFLAGS_ALL := $(LDFLAGS_ALL) -arch arm64 -arch x86_64
|
||||||
CXXFLAGS_ALL := ${CXXFLAGS_ALL} -arch arm64 -arch x86_64
|
CXXFLAGS_ALL := $(CXXFLAGS_ALL) -arch arm64 -arch x86_64
|
||||||
endif
|
endif
|
||||||
|
|
||||||
BUNDLE_DIR = ${BUNDLE_NAME}.lv2
|
BUNDLE_DIR := $(BUNDLE_NAME).lv2
|
||||||
|
|
||||||
DLL_FILE = ${BUNDLE_NAME}${DLL_SUFFIX}
|
DLL_FILE := $(BUNDLE_NAME)$(DLL_SUFFIX)
|
||||||
|
|
||||||
C_SRCS = ${COMMON_DIR}/src/lv2.c ${C_SRCS_EXTRA}
|
C_SRCS := $(COMMON_DIR)/src/lv2.c $(C_SRCS_EXTRA)
|
||||||
C_OBJS = $(addprefix build/obj/, $(notdir $(C_SRCS:.c=.o)))
|
C_OBJS := $(addprefix build/obj/, $(notdir $(C_SRCS:.c=.o)))
|
||||||
|
|
||||||
CXX_SRCS = ${CXX_SRCS_EXTRA}
|
CXX_SRCS := $(CXX_SRCS_EXTRA)
|
||||||
CXX_OBJS = $(addprefix build/obj/, $(notdir $(CXX_SRCS:.cpp=.o)))
|
CXX_OBJS := $(addprefix build/obj/, $(notdir $(CXX_SRCS:.cpp=.o)))
|
||||||
|
|
||||||
all: build/${BUNDLE_DIR}/manifest.ttl build/${BUNDLE_DIR}/${DLL_FILE}
|
ALL := build/$(BUNDLE_DIR)/manifest.ttl build/$(BUNDLE_DIR)/$(DLL_FILE)
|
||||||
|
|
||||||
build/${BUNDLE_DIR}/manifest.ttl: ${DATA_DIR}/data/manifest.ttl.in | build/${BUNDLE_DIR}
|
-include vars-extra.mk
|
||||||
cat $^ | sed s/@DLL_SUFFIX@/${DLL_SUFFIX}/g | sed s/@UI_TYPE@/${UI_TYPE}/g > $@
|
|
||||||
|
all: $(ALL)
|
||||||
|
|
||||||
|
build/$(BUNDLE_DIR)/manifest.ttl: $(DATA_DIR)/data/manifest.ttl.in | build/$(BUNDLE_DIR)
|
||||||
|
cat $^ | sed s/@DLL_SUFFIX@/$(DLL_SUFFIX)/g | sed s/@UI_TYPE@/$(UI_TYPE)/g > $@
|
||||||
|
|
||||||
ifeq ($(CXX_OBJS),)
|
ifeq ($(CXX_OBJS),)
|
||||||
build/${BUNDLE_DIR}/${DLL_FILE}: ${C_OBJS} | build/${BUNDLE_DIR}
|
build/$(BUNDLE_DIR)/$(DLL_FILE): $(C_OBJS) | build/$(BUNDLE_DIR)
|
||||||
${CC} $^ -o $@ ${CFLAGS_ALL} ${LDFLAGS_ALL}
|
$(CC) $^ -o $@ $(CFLAGS_ALL) $(LDFLAGS_ALL)
|
||||||
else
|
else
|
||||||
build/${BUNDLE_DIR}/${DLL_FILE}: ${C_OBJS} ${CXX_OBJS} | build/${BUNDLE_DIR}
|
build/$(BUNDLE_DIR)/$(DLL_FILE): $(C_OBJS) $(CXX_OBJS) | build/$(BUNDLE_DIR)
|
||||||
${CXX} $^ -o $@ ${CFLAGS_ALL} ${CXXFLAGS_ALL} ${LDFLAGS_ALL}
|
$(CXX) $^ -o $@ $(CFLAGS_ALL) $(CXXFLAGS_ALL) $(LDFLAGS_ALL)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
build/${BUNDLE_DIR} build/obj:
|
build/$(BUNDLE_DIR) build/obj:
|
||||||
mkdir -p $@
|
mkdir -p $@
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm -fr build
|
rm -fr build
|
||||||
|
|
||||||
install: all
|
install: all
|
||||||
mkdir -p -m 0755 "${LV2DIR}/${BUNDLE_DIR}"
|
@for f in `find build/$(BUNDLE_DIR) -type f`; do \
|
||||||
install -m 0644 build/${BUNDLE_DIR}/manifest.ttl "${LV2DIR}/${BUNDLE_DIR}"
|
m=`[ -x $$f ] && echo 0755 || echo 0644`; \
|
||||||
install -m 0755 build/${BUNDLE_DIR}/${DLL_FILE} "${LV2DIR}/${BUNDLE_DIR}"
|
d=`echo $$f | sed 's:^build/::'` ; \
|
||||||
|
d=`dirname $$d`; \
|
||||||
|
echo install -m $$m -t "$(LV2DIR)/$$d" -D $$f; \
|
||||||
|
install -m $$m -t "$(LV2DIR)/$$d" -D $$f; \
|
||||||
|
done
|
||||||
|
|
||||||
install-user: all
|
install-user: all
|
||||||
mkdir -p -m 0755 "${LV2DIR_USER}/${BUNDLE_DIR}"
|
@for f in `find build/$(BUNDLE_DIR) -type f`; do \
|
||||||
install -m 0644 build/${BUNDLE_DIR}/manifest.ttl "${LV2DIR_USER}/${BUNDLE_DIR}"
|
m=`[ -x $$f ] && echo 0755 || echo 0644`; \
|
||||||
install -m 0755 build/${BUNDLE_DIR}/${DLL_FILE} "${LV2DIR_USER}/${BUNDLE_DIR}"
|
d=`echo $$f | sed 's:^build/::'` ; \
|
||||||
|
d=`dirname $$d`; \
|
||||||
|
echo install -m $$m -t "$(LV2DIR_USER)/$$d" -D $$f; \
|
||||||
|
install -m $$m -t "$(LV2DIR_USER)/$$d" -D $$f; \
|
||||||
|
done
|
||||||
|
|
||||||
|
-include rules-extra.mk
|
||||||
|
|
||||||
.PHONY: all clean install install-user
|
.PHONY: all clean install install-user
|
||||||
|
|
||||||
@ -112,7 +126,9 @@ install-user: all
|
|||||||
PERCENT := %
|
PERCENT := %
|
||||||
|
|
||||||
$(C_OBJS): build/obj/%.o: $$(filter $$(PERCENT)/$$(basename $$(notdir $$@)).c,$$(C_SRCS)) | build/obj
|
$(C_OBJS): build/obj/%.o: $$(filter $$(PERCENT)/$$(basename $$(notdir $$@)).c,$$(C_SRCS)) | build/obj
|
||||||
${CC} $^ -o $@ -c ${CFLAGS_ALL}
|
$(CC) $^ -o $@ -c $(CFLAGS_ALL)
|
||||||
|
|
||||||
$(CXX_OBJS): build/obj/%.o: $$(filter $$(PERCENT)/$$(basename $$(notdir $$@)).cpp,$$(CXX_SRCS)) | build/obj
|
$(CXX_OBJS): build/obj/%.o: $$(filter $$(PERCENT)/$$(basename $$(notdir $$@)).cpp,$$(CXX_SRCS)) | build/obj
|
||||||
${CXX} $^ -o $@ -c ${CXXFLAGS_ALL}
|
$(CXX) $^ -o $@ -c $(CXXFLAGS_ALL)
|
||||||
|
|
||||||
|
-include rules-secondexp-extra.mk
|
||||||
|
Loading…
Reference in New Issue
Block a user