make for static linkage
This commit is contained in:
parent
432b3de3eb
commit
e6dcb27ecb
|
@ -8,6 +8,7 @@ build/
|
||||||
|
|
||||||
*.so
|
*.so
|
||||||
*.d
|
*.d
|
||||||
|
*.a
|
||||||
|
|
||||||
deps/
|
deps/
|
||||||
|
|
||||||
|
|
17
Makefile
17
Makefile
|
@ -6,10 +6,11 @@
|
||||||
# statdessen: `make clean; make all -j` verwenden
|
# statdessen: `make clean; make all -j` verwenden
|
||||||
|
|
||||||
# windows name
|
# windows name
|
||||||
NAME = lib$(NAMESHORT).dll
|
#NAME = lib$(NAMESHORT).dll
|
||||||
|
|
||||||
NAMESHORT = mrbesen
|
NAMESHORT = mrbesen
|
||||||
NAME ?= lib$(NAMESHORT).so
|
NAME ?= lib$(NAMESHORT).so
|
||||||
|
NAMESTATIC = lib$(NAMESHORT).a
|
||||||
NAMETEST = test
|
NAMETEST = test
|
||||||
CFLAGS = -fpic -std=c++17 -O2 -g -pipe -Wall -Wextra -Wno-unused-parameter -Wpedantic
|
CFLAGS = -fpic -std=c++17 -O2 -g -pipe -Wall -Wextra -Wno-unused-parameter -Wpedantic
|
||||||
CXX = g++
|
CXX = g++
|
||||||
|
@ -32,7 +33,11 @@ BUILDDIRS = $(patsubst $(SRCF)%, $(BUILDDIR)%, $(SOURCEDIRS))
|
||||||
|
|
||||||
INCLUDES += $(addprefix -I, $(SOURCEDIRS))
|
INCLUDES += $(addprefix -I, $(SOURCEDIRS))
|
||||||
|
|
||||||
all: $(OUTF)$(NAME) runtest
|
all: $(OUTF)$(NAME) $(OUTF)$(NAMESTATIC) runtest
|
||||||
|
|
||||||
|
$(OUTF)$(NAMESTATIC): $(BUILDDIRS) $(DEPF) $(OBJFILES)
|
||||||
|
@echo "Archiving $@"
|
||||||
|
@$(AR) rs $@ $(filter %.o, $^)
|
||||||
|
|
||||||
$(OUTF)$(NAME): $(BUILDDIRS) $(DEPF) $(OBJFILES)
|
$(OUTF)$(NAME): $(BUILDDIRS) $(DEPF) $(OBJFILES)
|
||||||
@echo "Linking $@"
|
@echo "Linking $@"
|
||||||
|
@ -50,15 +55,15 @@ clean-depends:
|
||||||
$(RM) -r $(DEPF)
|
$(RM) -r $(DEPF)
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
$(RM) -r $(OUTF)$(NAME) $(BUILDDIR) $(NAMETEST)
|
$(RM) -r $(OUTF)$(NAME) $(BUILDDIR) $(NAMETEST) $(NAMESTATIC)
|
||||||
|
|
||||||
$(NAMETEST): $(NAME) $(TESTF)*.cpp
|
$(NAMETEST): $(TESTF)*.cpp $(NAMESTATIC)
|
||||||
@echo "Compiling tests"
|
@echo "Compiling tests"
|
||||||
@$(CXX) -o $@ $(filter-out %.so, $^) $(CFLAGS) $(INCLUDES) $(LDFLAGS) -L$(OUTF) -l$(NAMESHORT)
|
@$(CXX) -o $@ $^ $(CFLAGS) $(INCLUDES) $(LDFLAGS)
|
||||||
|
|
||||||
runtest: $(NAMETEST)
|
runtest: $(NAMETEST)
|
||||||
@echo "Running tests"
|
@echo "Running tests"
|
||||||
LD_LIBRARY_PATH=$(OUTF):$(LD_LIBRARY_PATH) ./$<
|
./$<
|
||||||
|
|
||||||
install: $(NAME)
|
install: $(NAME)
|
||||||
cp -f ./$(NAME) /usr/lib/
|
cp -f ./$(NAME) /usr/lib/
|
||||||
|
|
Loading…
Reference in New Issue