chore(build): add static library output and privilege-safe install
- debug and release targets now produce both shared and static libs - obj dirs split into shared/ and static/ to keep fPIC objects isolated - install no longer depends on release, guards with existence check instead - build.sh handles privilege escalation for install/uninstall via doas or sudo, falling back gracefully if already root - uninstall cleans up static lib alongside shared
This commit is contained in:
@@ -2,17 +2,25 @@ include config.mk
|
||||
|
||||
ifeq ($(OS),Windows_NT)
|
||||
SHELL := cmd.exe
|
||||
FULL_LIB := $(LIB_NAME).dll
|
||||
LDFLAGS_PLAT :=
|
||||
CFLAGS_PLAT :=
|
||||
FULL_LIB := $(LIB_NAME).dll
|
||||
STATIC_LIB := $(LIB_NAME).lib
|
||||
LDFLAGS_PLAT :=
|
||||
CFLAGS_PLAT :=
|
||||
CFLAGS_STATIC :=
|
||||
MKDIR = if not exist $(subst /,\,$(1)) mkdir $(subst /,\,$(1))
|
||||
RMDIR = if exist $(subst /,\,$(1)) rd /s /q $(subst /,\,$(1))
|
||||
AR := lib
|
||||
ARFLAGS_STATIC := /OUT:
|
||||
else
|
||||
FULL_LIB := lib$(LIB_NAME).so
|
||||
LDFLAGS_PLAT := -ldl
|
||||
CFLAGS_PLAT := -fPIC
|
||||
FULL_LIB := lib$(LIB_NAME).so
|
||||
STATIC_LIB := lib$(LIB_NAME).a
|
||||
LDFLAGS_PLAT := -ldl
|
||||
CFLAGS_PLAT := -fPIC
|
||||
CFLAGS_STATIC :=
|
||||
MKDIR = mkdir -p $(1)
|
||||
RMDIR = rm -rf $(1)
|
||||
AR := ar
|
||||
ARFLAGS_STATIC := rcs
|
||||
endif
|
||||
|
||||
RELEASE_LDFLAGS := -s
|
||||
@@ -24,31 +32,57 @@ INCDIR ?= $(PREFIX)/include
|
||||
|
||||
.PHONY: all debug release clean test install uninstall
|
||||
|
||||
all: debug
|
||||
all: debug
|
||||
|
||||
debug: $(BIN_DIR)/debug/$(FULL_LIB)
|
||||
release: $(BIN_DIR)/release/$(FULL_LIB)
|
||||
debug: $(BIN_DIR)/debug/$(FULL_LIB) $(BIN_DIR)/debug/$(STATIC_LIB)
|
||||
release: $(BIN_DIR)/release/$(FULL_LIB) $(BIN_DIR)/release/$(STATIC_LIB)
|
||||
|
||||
# Debug Rules
|
||||
$(BIN_DIR)/debug/$(FULL_LIB): $(SRCS:src/%.c=obj/debug/%.o)
|
||||
$(BIN_DIR)/debug/$(FULL_LIB): $(SRCS:src/%.c=obj/debug/shared/%.o)
|
||||
@$(call MKDIR,$(@D))
|
||||
$(CC) -shared -o $@ $^ $(LDFLAGS_PLAT)
|
||||
$(CC) -shared -o $@ $^ $(LDFLAGS_PLAT)
|
||||
|
||||
obj/debug/%.o: src/%.c
|
||||
$(BIN_DIR)/debug/$(STATIC_LIB): $(SRCS:src/%.c=obj/debug/static/%.o)
|
||||
@$(call MKDIR,$(@D))
|
||||
$(CC) $(CFLAGS_BASE) -g -O0 -MMD -MP -c $< -o $@
|
||||
ifeq ($(OS),Windows_NT)
|
||||
$(AR) $(ARFLAGS_STATIC)$@ $^
|
||||
else
|
||||
$(AR) $(ARFLAGS_STATIC) $@ $^
|
||||
endif
|
||||
|
||||
obj/debug/shared/%.o: src/%.c
|
||||
@$(call MKDIR,$(@D))
|
||||
$(CC) $(CFLAGS_BASE) -g -O0 -MMD -MP -c $< -o $@
|
||||
|
||||
obj/debug/static/%.o: src/%.c
|
||||
@$(call MKDIR,$(@D))
|
||||
$(CC) $(CFLAGS_BASE) $(CFLAGS_STATIC) -g -O0 -MMD -MP -c $< -o $@
|
||||
|
||||
# Release Rules
|
||||
$(BIN_DIR)/release/$(FULL_LIB): $(SRCS:src/%.c=obj/release/%.o)
|
||||
$(BIN_DIR)/release/$(FULL_LIB): $(SRCS:src/%.c=obj/release/shared/%.o)
|
||||
@$(call MKDIR,$(@D))
|
||||
$(CC) -shared $(RELEASE_LDFLAGS) -o $@ $^ $(LDFLAGS_PLAT)
|
||||
$(CC) -shared $(RELEASE_LDFLAGS) -o $@ $^ $(LDFLAGS_PLAT)
|
||||
|
||||
obj/release/%.o: src/%.c
|
||||
$(BIN_DIR)/release/$(STATIC_LIB): $(SRCS:src/%.c=obj/release/static/%.o)
|
||||
@$(call MKDIR,$(@D))
|
||||
$(CC) $(CFLAGS_BASE) -O2 -MMD -MP -c $< -o $@
|
||||
ifeq ($(OS),Windows_NT)
|
||||
$(AR) $(ARFLAGS_STATIC)$@ $^
|
||||
else
|
||||
$(AR) $(ARFLAGS_STATIC) $@ $^
|
||||
endif
|
||||
|
||||
-include $(wildcard obj/debug/*.d)
|
||||
-include $(wildcard obj/release/*.d)
|
||||
obj/release/shared/%.o: src/%.c
|
||||
@$(call MKDIR,$(@D))
|
||||
$(CC) $(CFLAGS_BASE) -O2 -MMD -MP -c $< -o $@
|
||||
|
||||
obj/release/static/%.o: src/%.c
|
||||
@$(call MKDIR,$(@D))
|
||||
$(CC) $(CFLAGS_BASE) $(CFLAGS_STATIC) -O2 -MMD -MP -c $< -o $@
|
||||
|
||||
-include $(wildcard obj/debug/shared/*.d)
|
||||
-include $(wildcard obj/debug/static/*.d)
|
||||
-include $(wildcard obj/release/shared/*.d)
|
||||
-include $(wildcard obj/release/static/*.d)
|
||||
|
||||
clean:
|
||||
@$(call RMDIR,$(OBJ_DIR))
|
||||
@@ -58,23 +92,26 @@ test: debug
|
||||
@echo "=== Building and running stk tests ==="
|
||||
@$(MAKE) -C test -f gmake.mk
|
||||
|
||||
# Installation (Unix only)
|
||||
ifneq ($(OS),Windows_NT)
|
||||
install: release
|
||||
install:
|
||||
@test -f $(BIN_DIR)/release/$(FULL_LIB) || { echo "Run 'make -f gmake.mk release' before installing."; exit 1; }
|
||||
install -d $(LIBDIR) $(INCDIR)/stk
|
||||
install -m 755 $(BIN_DIR)/release/$(FULL_LIB) $(LIBDIR)/
|
||||
install -m 644 $(BIN_DIR)/release/$(STATIC_LIB) $(LIBDIR)/
|
||||
install -m 644 $(INC_DIR)/stk.h $(INCDIR)/stk/
|
||||
install -m 644 $(INC_DIR)/stk_version.h $(INCDIR)/stk/
|
||||
install -m 644 $(INC_DIR)/stk_log.h $(INCDIR)/stk/
|
||||
|
||||
uninstall:
|
||||
rm -f $(LIBDIR)/$(FULL_LIB)
|
||||
rm -f $(LIBDIR)/$(STATIC_LIB)
|
||||
rm -rf $(INCDIR)/stk
|
||||
else
|
||||
install:
|
||||
@echo "make install is not supported on Windows."
|
||||
@echo "Copy include/ directory contents to your_project/include/stk/"
|
||||
@echo "Copy bin/release/stk.dll to your project's lib directory."
|
||||
@echo "Copy bin/release/stk.lib to your project's lib directory."
|
||||
|
||||
uninstall:
|
||||
@echo "make uninstall is not supported on Windows."
|
||||
|
||||
Reference in New Issue
Block a user