diff --git a/Makefile b/Makefile index ae29f1c..4648f61 100644 --- a/Makefile +++ b/Makefile @@ -1,71 +1,102 @@ -LIBNAME := $(shell basename $$(pwd)) -MAJOR := 1 -MINOR := 1.0 +include premake.make +LIBNAME := $(shell basename $$(pwd)) UNAME_S := $(shell uname -s) ifeq ($(UNAME_S),Darwin) LINKERNAME := $(LIBNAME).dylib SONAME := $(LIBNAME).$(MAJOR).dylib REALNAME := $(LINKERNAME) -else +endif +ifeq ($(UNAME_S),OpenBSD) + REALNAME := $(LIBNAME).so.$(MAJOR).$(MINOR) +endif +ifeq ($(UNAME_S),Linux) LINKERNAME := $(LIBNAME).so SONAME := $(LINKERNAME).$(MAJOR) - REALNAME := $(SONAME).$(MINOR) + REALNAME := $(SONAME).$(MINOR).$(PATCH) endif +STATICLIB := $(LIBNAME).a +BUILDDIR := build/intermediates/ PREFIX ?= /usr/local BINDIR ?= $(PREFIX)/bin -LIBDIR ?= $(PREFIX)/lib +CONFIGDIR ?= $(PREFIX)/etc INCLUDEDIR ?= $(PREFIX)/include +LIBDIR ?= $(PREFIX)/lib DATADIR ?= $(PREFIX)/share MANDIR ?= $(DATADIR)/man +DOCDIR ?= $(DATADIR)/$(LIBNAME)/doc -SRCS := $(wildcard *.cpp) -OBJS := $(subst .cpp,.o,$(SRCS)) -DEPS := $(subst .cpp,.d,$(SRCS)) +SRCS := $(notdir $(wildcard src/*.cpp)) +OBJS := $(SRCS:.cpp=.o) +DEPS := $(SRCS:.cpp=.d) +HDRS := $(wildcard src/*.hpp) CXX ?= g++ -CXXFLAGS += -Wshadow -Wall -Wpedantic -Wextra -g -std=c++17 -fPIC +CXXFLAGS += -Wshadow -Wall -Wpedantic -Wextra -g -fno-strict-aliasing -std=c++17 -fPIC ifeq ($(DEBUG),1) CXXFLAGS += -D DEBUG -O0 + CONFIG := debug else CXXFLAGS += -D NDEBUG -O3 + CONFIG := release endif +OUTDIR := build/$(CONFIG)/ -LDLIBS := -lscerror - -RM := /bin/rm -f +RM := /bin/rm -rf INSTALL := /usr/bin/install -c -all: $(REALNAME) +vpath %.cpp src +vpath %.d $(BUILDDIR) +vpath %.o $(BUILDDIR) -$(REALNAME): $(OBJS) $(DEPS) +.PHONY: all clean install prebuild test + +all: prebuild $(OUTDIR)$(REALNAME) $(OUTDIR)$(STATICLIB) + +prebuild: + @mkdir -p $(BUILDDIR) $(OUTDIR) + +$(OUTDIR)$(REALNAME): $(OBJS) $(DEPS) ifeq ($(UNAME_S),Darwin) - $(CXX) -dynamiclib -o $(REALNAME) -current_version $(MAJOR) -compatibility_version $(MINOR) $(LDFLAGS) $(LDLIBS) $(OBJS) -else - $(CXX) -g -shared -Wl,-soname,$(SONAME) -o $(REALNAME) $(LDFLAGS) $(LDLIBS) $(OBJS) + $(CXX) -dynamiclib -o $(OUTDIR)$(REALNAME) -current_version $(MAJOR) -compatibility_version $(MINOR) $(LDFLAGS) $(LDLIBS) $(addprefix $(BUILDDIR),$(OBJS)) +endif +ifeq ($(UNAME_S),OpenBSD) + $(CXX) -g -shared -Wl,-soname,$(REALNAME) -o $(OUTDIR)$(REALNAME) $(LDFLAGS) $(LDLIBS) $(addprefix $(BUILDDIR),$(OBJS)) +endif +ifeq ($(UNAME_S),Linux) + $(CXX) -g -shared -Wl,-soname,$(SONAME) -o $(OUTDIR)$(REALNAME) $(LDFLAGS) $(LDLIBS) $(addprefix $(BUILDDIR),$(OBJS)) endif -%.o: %.cpp %.d Makefile +%.o: %.cpp %.d $(CXX) $(CXXFLAGS) -MMD -MP -MT $@ -MF $*.d -c $< + @mv $@ $*.d $(BUILDDIR) --include *.d +-include $(BUILDDIR)*.d %.d: ; -.PHONY: clean install +$(OUTDIR)$(STATICLIB): $(OBJS) + ar r $(OUTDIR)$(STATICLIB) $(addprefix $(BUILDDIR),$(OBJS)) + +test: + $(MAKE) -C tests && tests/tests clean: - $(RM) $(OBJS) $(DEPS) $(REALNAME) + $(RM) build + $(MAKE) -C tests clean -install: $(REALNAME) $(LIBNAME).hpp - $(INSTALL) -m 644 $(REALNAME) $(LIBDIR) - $(INSTALL) -m 644 $(LIBNAME).hpp $(INCLUDEDIR) +install: $(OUTDIR)$(REALNAME) + $(INSTALL) -d $(LIBDIR) + $(INSTALL) -m 644 $(OUTDIR)$(REALNAME) $(LIBDIR) + $(INSTALL) -d $(INCLUDEDIR) + $(INSTALL) -m 644 src/$(LIBNAME).hpp $(INCLUDEDIR) ifeq ($(UNAME_S),Darwin) cd $(LIBDIR) && ln -sf $(REALNAME) $(SONAME) -else +endif +ifeq ($(UNAME_S),Linux) ldconfig cd $(LIBDIR) && ln -sf $(SONAME) $(LINKERNAME) endif diff --git a/premake.make b/premake.make new file mode 100644 index 0000000..2116d5c --- /dev/null +++ b/premake.make @@ -0,0 +1,5 @@ +LDLIBS := -lscerror + +MAJOR := 1 +MINOR := 1 +PATCH := 0