diff --git a/makefile b/makefile.basic similarity index 56% rename from makefile rename to makefile.basic index 5314f16..3c57450 100644 --- a/makefile +++ b/makefile.basic @@ -13,45 +13,69 @@ #Copyright 2018-2019 rexy712 +#Makefile to generate a single executable from all sources in SOURCE_DIRS that end in EXT -SOURCE_DIRS:=src -OBJDIR:=obj -DEPDIR:=$(OBJDIR)/dep -INCLUDE_DIRS:=include -EXT:=cpp -MAIN_EXECUTABLE:=tester +ifeq ($(OS),Windows_NT) + WINDOWS=1 +endif + +SOURCE_DIRS::=src +OBJDIR::=obj +DEPDIR::=$(OBJDIR)/dep +LIBDIR::=lib +INCLUDE_DIRS::=include +CXXFLAGS::=-g -std=c++17 -Wall -pedantic -Wextra +EXT::=cpp +MAIN_EXECUTABLE::=tester + +ifneq ($(WINDOWS),1) + CXX::=g++ + LDLIBS::= + LDFLAGS::= + STRIP?=strip + RANLIB?=ranlib + AR?=ar + AS?=as +else + MINGW_PREFIX::=x86_64-w64-mingw32- + CXX::=$(MINGW_PREFIX)g++ + LDLIBS::= + LDFLAGS::= + STRIP?=$(MINGW_PREFIX)strip + RANLIB?=$(MINGW_PREFIX)ranlib + AR?=$(MINGW_PREFIX)ar + AS?=$(MINGW_PREFIX)as + MAIN_EXECUTABLE::=$(MAIN_EXECUTABLE).exe +endif -CXX:=g++ -CXXFLAGS:=-g -std=c++17 -Wall -pedantic -Wextra all: CXXFLAGS+=-O0 release: CXXFLAGS+=-O2 -LDFLAGS= -LDLIBS:= -STRIP:=strip -memchk:LDFLAGS+=-fsanitize=address -fno-omit-frame-pointer -fno-optimize-sibling-calls -memchk:CXXFLAGS+=-O0 -fsanitize=address -fno-omit-frame-pointer -fno-optimize-sibling-calls +memchk: LDFLAGS+=-fsanitize=address -fno-omit-frame-pointer -fno-optimize-sibling-calls +memchk: CXXFLAGS+=-O0 -fsanitize=address -fno-omit-frame-pointer -fno-optimize-sibling-calls ifeq ($(OS),Windows_NT) mkdir=mkdir $(subst /,\,$(1)) > NUL 2>&1 rm=del /F $(1) > NUL 2>&1 - rmdir=rd /s /q $(1) > NUL 2>&1 - move=move /y $(subst /,\,$(1)) $(subst /,\,$(2)) > NUL 2>&1 - MAIN_EXECUTABLE:=$(MAIN_EXECUTABLE).exe - LDLIBS:= + rmdir=rd /S /Q $(1) > NUL 2>&1 + move=move /Y $(subst /,\,$(1)) $(subst /,\,$(2)) > NUL 2>&1 + copy=copy /Y /B $(subst /,\,$(1)) $(subst /,\,$(2)) > NUL 2>&1 else mkdir=mkdir -p $(1) rm=rm -f $(1) rmdir=rm -rf $(1) move=mv $(1) $(2) + copy=cp $(1) $(2) endif INTERNAL_CXXFLAGS=-c $(foreach dir,$(INCLUDE_DIRS),-I"$(dir)") -MMD -MP -MF"$(DEPDIR)/$(notdir $(patsubst %.o,%.d,$@))" -SOURCES:=$(foreach source,$(SOURCE_DIRS),$(foreach ext,$(EXT),$(wildcard $(source)/*.$(ext)))) -OBJECTS:=$(addprefix $(OBJDIR)/,$(subst \,.,$(subst /,.,$(addsuffix .o,$(SOURCES))))) +SOURCES::=$(foreach source,$(SOURCE_DIRS),$(foreach ext,$(EXT),$(wildcard $(source)/*.$(ext)))) +OBJECTS::=$(addprefix $(OBJDIR)/,$(subst \,.,$(subst /,.,$(addsuffix .o,$(SOURCES))))) +.PHONY: all all: $(MAIN_EXECUTABLE) -memchk: $(MAIN_EXECUTABLE) +.PHONY: memchk +memchk: all $(MAIN_EXECUTABLE): $(OBJECTS) $(CXX) $(LDFLAGS) $^ -o "$(basename $@)" $(LDLIBS) @@ -81,6 +105,9 @@ clean: $(call rmdir,"$(DEPDIR)") $(call rmdir,"$(OBJDIR)") $(call rm,"$(MAIN_EXECUTABLE)") +ifneq ($(OS),Windows_NT) + $(call rm,"$(MAIN_EXECUTABLE).exe") +endif -include $(wildcard $(DEPDIR)/*.d) diff --git a/makefile.library b/makefile.library new file mode 100644 index 0000000..328ed7c --- /dev/null +++ b/makefile.library @@ -0,0 +1,138 @@ +#This program is free software: you can redistribute it and/or modify +#it under the terms of the GNU General Public License as published by +#the Free Software Foundation, either version 3 of the License, or +#(at your option) any later version. + +#This program is distributed in the hope that it will be useful, +#but WITHOUT ANY WARRANTY; without even the implied warranty of +#MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +#GNU General Public License for more details. + +#You should have received a copy of the GNU General Public License +#along with this program. If not, see . + +#Copyright 2018-2019 rexy712 + +#Makefile to generate a single static or shared library from all the sources in SOURCE_DIRS ending in EXT + +ifeq ($(OS),Windows_NT) + WINDOWS::=1 +endif + +SOURCE_DIRS::=src +OBJDIR::=obj +DEPDIR::=$(OBJDIR)/dep +LIBDIR::=lib +INCLUDE_DIRS::=include +CXXFLAGS::=-g -std=c++17 -Wall -pedantic -Wextra +EXT::=cpp +MAIN_LIBRARY::=test +SHARED?=1 + +ifneq ($(WINDOWS),1) + CXX::=g++ + LDLIBS::= + LDFLAGS::= + STRIP?=strip + RANLIB?=ranlib + AR?=ar + AS?=as +else #windows + MINGW_PREFIX::=x86_64-w64-mingw32- + CXX::=$(MINGW_PREFIX)g++ + LDLIBS::= + LDFLAGS::=-static-libgcc -static-libstdc++ + STRIP?=$(MINGW_PREFIX)strip + RANLIB?=$(MINGW_PREFIX)ranlib + AR?=$(MINGW_PREFIX)ar + AS?=$(MINGW_PREFIX)as + DLLOUT::=$(MAIN_LIBRARY).dll +endif #windows + +ifeq ($(SHARED),1) + ifeq ($(OS),Windows_NT) + INTERNAL_MAIN_LIBRARY::=lib$(MAIN_LIBRARY).a + else + INTERNAL_MAIN_LIBRARY::=lib$(MAIN_LIBRARY).so + endif +else + INTERNAL_MAIN_LIBRARY::=lib$(MAIN_LIBRARY).a +endif + + +all: CXXFLAGS+=-O0 +release: CXXFLAGS+=-O2 + +memchk: LDFLAGS+=-fsanitize=address -fno-omit-frame-pointer -fno-optimize-sibling-calls +memchk: CXXFLAGS+=-O0 -fsanitize=address -fno-omit-frame-pointer -fno-optimize-sibling-calls + +ifeq ($(OS),Windows_NT) + mkdir=mkdir $(subst /,\,$(1)) > NUL 2>&1 + rm=del /F $(1) > NUL 2>&1 + rmdir=rd /S /Q $(1) > NUL 2>&1 + move=move /Y $(subst /,\,$(1)) $(subst /,\,$(2)) > NUL 2>&1 + copy=copy /Y /B $(subst /,\,$(1)) $(subst /,\,$(2)) > NUL 2>&1 +else + mkdir=mkdir -p $(1) + rm=rm -f $(1) + rmdir=rm -rf $(1) + move=mv $(1) $(2) + copy=cp $(1) $(2) +endif + +INTERNAL_CXXFLAGS=-c $(foreach dir,$(INCLUDE_DIRS),-I"$(dir)") -MMD -MP -MF"$(DEPDIR)/$(notdir $(patsubst %.o,%.d,$@))" +ifeq ($(SHARED),1) + INTERNAL_CXXFLAGS+=-fPIC +endif +SOURCES::=$(foreach source,$(SOURCE_DIRS),$(foreach ext,$(EXT),$(wildcard $(source)/*.$(ext)))) +OBJECTS::=$(addprefix $(OBJDIR)/,$(subst \,.,$(subst /,.,$(addsuffix .o,$(SOURCES))))) + +.PHONY: all + +ifeq ($(SHARED),1) +ifeq ($(WINDOWS),1) +all: $(DLLOUT) +$(INTERNAL_MAIN_LIBRARY): $(OBJECTS) + $(CXX) -shared -o "$(DLLOUT)" $^ -Wl,--out-implib,"$(INTERNAL_MAIN_LIBRARY)" $(LDLIBS) $(LDFLAGS) +$(DLLOUT): $(INTERNAL_MAIN_LIBRARY) +else #windows +$(INTERNAL_MAIN_LIBRARY): $(OBJECTS) + $(CXX) -shared -o "$@" $^ $(CXXFLAGS) $(LDFLAGS) $(LDLIBS) +endif #windows +else #shared +all: $(INTERNAL_MAIN_LIBRARY) +$(INTERNAL_MAIN_LIBRARY): $(OBJECTS) + $(AR) rcs "$@" $^ + $(RANLIB) "$@" +endif #shared + +.PHONY: memchk +.PHONY: release +memchk: all +release: all + +define GENERATE_OBJECTS + +$$(OBJDIR)/$(subst \,.,$(subst /,.,$(1))).%.o: $(1)/% + $$(CXX) $$(CXXFLAGS) $$(INTERNAL_CXXFLAGS) "$$<" -o "$$@" + +endef + +$(foreach dir,$(SOURCE_DIRS),$(eval $(call GENERATE_OBJECTS,$(dir)))) +$(OBJECTS): | $(OBJDIR) $(DEPDIR) + +$(OBJDIR): + $(call mkdir,"$@") +$(DEPDIR): + $(call mkdir,"$@") + +.PHONY: clean +clean: + $(call rmdir,"$(DEPDIR)") + $(call rmdir,"$(OBJDIR)") + $(call rm,"lib$(MAIN_LIBRARY).so") + $(call rm,"lib$(MAIN_LIBRARY).a") + $(call rm,"$(DLLOUT)") + +-include $(wildcard $(DEPDIR)/*.d) +