From 64f7260b3a578593e1c01f48bad4c3c66b1b5105 Mon Sep 17 00:00:00 2001 From: anth64 Date: Sun, 1 Feb 2026 11:19:02 +0100 Subject: [PATCH] feat(build): add install and uninstall targets for Unix systems - Add PREFIX, LIBDIR, and INCDIR variables (default: /usr/local) - Implement install target that builds release and installs to system paths - Implement uninstall target to cleanly remove installed files - Support custom install locations via PREFIX variable - Add helpful message on Windows directing users to manual installation Both gmake.mk and bmake.mk now support standard installation workflow on Unix-like systems (Linux, BSD, macOS). Windows users are instructed to copy files manually as per platform conventions. Usage: make install # Install to /usr/local (requires root) make PREFIX=$HOME install # Install to custom location make uninstall # Remove installed files --- bmake.mk | 15 ++++++++++++++- gmake.mk | 25 ++++++++++++++++++++++++- 2 files changed, 38 insertions(+), 2 deletions(-) diff --git a/bmake.mk b/bmake.mk index e689edf..16b36de 100644 --- a/bmake.mk +++ b/bmake.mk @@ -1,5 +1,9 @@ .include "config.mk" +PREFIX ?= /usr/local +LIBDIR ?= ${PREFIX}/lib +INCDIR ?= ${PREFIX}/include + UNAME_S != uname -s .if ${UNAME_S} == "Darwin" @@ -12,7 +16,7 @@ LDFLAGS_PLAT = -ldl CFLAGS_PLAT = -fPIC CFLAGS_BASE = -Wall -Wpedantic -I${.CURDIR}/${INC_DIR} -std=c89 ${CFLAGS_PLAT} -.PHONY: all debug release clean test +.PHONY: all debug release clean test install uninstall all: debug @@ -52,3 +56,12 @@ clean: test: debug @echo "=== Building and running stk tests ===" cd ${.CURDIR}/test && ${MAKE} -f bmake.mk + +install: release + install -d ${LIBDIR} ${INCDIR} + install -m 755 ${.CURDIR}/${BIN_DIR}/release/${FULL_LIB} ${LIBDIR}/ + install -m 644 ${.CURDIR}/${INC_DIR}/stk.h ${INCDIR}/ + +uninstall: + rm -f ${LIBDIR}/${FULL_LIB} + rm -f ${INCDIR}/stk.h diff --git a/gmake.mk b/gmake.mk index 4eb7472..40bffa3 100644 --- a/gmake.mk +++ b/gmake.mk @@ -18,7 +18,11 @@ endif RELEASE_LDFLAGS := -s CFLAGS_BASE := -Wall -Wpedantic -I$(INC_DIR) -std=c89 $(CFLAGS_PLAT) -.PHONY: all debug release clean test +PREFIX ?= /usr/local +LIBDIR ?= $(PREFIX)/lib +INCDIR ?= $(PREFIX)/include + +.PHONY: all debug release clean test install uninstall all: debug @@ -53,3 +57,22 @@ clean: test: debug @echo "=== Building and running stk tests ===" @$(MAKE) -C test -f gmake.mk + +# Installation (Unix only) +ifneq ($(OS),Windows_NT) +install: release + install -d $(LIBDIR) $(INCDIR) + install -m 755 $(BIN_DIR)/release/$(FULL_LIB) $(LIBDIR)/ + install -m 644 $(INC_DIR)/stk.h $(INCDIR)/ + +uninstall: + rm -f $(LIBDIR)/$(FULL_LIB) + rm -f $(INCDIR)/stk.h +else +install: + @echo "make install is not supported on Windows." + @echo "Copy include/stk.h and bin/release/stk.dll to your project." + +uninstall: + @echo "make uninstall is not supported on Windows." +endif