Rebuild when c(xx) flags change

This commit is contained in:
rexy712 2020-03-17 16:49:33 -07:00
parent 0d48b49510
commit c8460d11f1
2 changed files with 49 additions and 13 deletions

View File

@ -35,6 +35,7 @@ POST_TARGETS::=
CLEAN_TARGETS::= CLEAN_TARGETS::=
RELEASE?=0 RELEASE?=0
MEMCHK?=0 MEMCHK?=0
SAVECFLAGS?=1
ifneq ($(WINDOWS),1) ifneq ($(WINDOWS),1)
#*nix settings #*nix settings
@ -114,12 +115,19 @@ else
COMPILER_FLAGS+=-O0 -g3 -ggdb COMPILER_FLAGS+=-O0 -g3 -ggdb
endif endif
ifeq ($(SAVECFLAGS),1)
CFLAGS_TMPFILE::=.cflags.tmp
OLD_COMPILEFLAGS::=$(file <$(CFLAGS_TMPFILE))
endif
#add dependency tracking and include directories #add dependency tracking and include directories
INTERNAL_COMPILERFLAGS=-c $(foreach dir,$(INCLUDE_DIRS),-I"$(dir)") -MMD -MP -MF"$(DEPDIR)/$(notdir $(patsubst %.o,%.d,$@))" INTERNAL_COMPILERFLAGS=-c $(foreach dir,$(INCLUDE_DIRS),-I"$(dir)") -MMD -MP -MF"$(DEPDIR)/$(notdir $(patsubst %.o,%.d,$@))"
INTERNAL_LINKFLAGS=$(foreach dir,$(LIBDIRS),-L"$(dir)") INTERNAL_LINKFLAGS=$(foreach dir,$(LIBDIRS),-L"$(dir)")
THIS_MAKEFILE_NAME::=$(lastword $(MAKEFILE_LIST)) THIS_MAKEFILE_NAME::=$(lastword $(MAKEFILE_LIST))
INTERNAL_SOURCES::=$(SOURCES) $(foreach source,$(SOURCE_DIRS),$(foreach ext,$(EXT),$(wildcard $(source)/*.$(ext)))) INTERNAL_SOURCES::=$(SOURCES) $(foreach source,$(SOURCE_DIRS),$(foreach ext,$(EXT),$(wildcard $(source)/*.$(ext))))
OBJECTS::=$(addprefix $(OBJDIR)/,$(subst \,.,$(subst /,.,$(addsuffix .o,$(INTERNAL_SOURCES))))) OBJECTS::=$(addprefix $(OBJDIR)/,$(subst \,.,$(subst /,.,$(addsuffix .o,$(INTERNAL_SOURCES)))))
ALL_COMPILEFLAGS=$(COMPILER_FLAGS) $(INTERNAL_COMPILERFLAGS)
ALL_LINKFLAGS=$(INTERNAL_LINKFLAGS) $(LDFLAGS)
#Arguments to make submake use this makefile without "Entering directory" stuff #Arguments to make submake use this makefile without "Entering directory" stuff
SUBMAKE_ARGUMENTS::=--no-print-directory -f "$(THIS_MAKEFILE_NAME)" SUBMAKE_ARGUMENTS::=--no-print-directory -f "$(THIS_MAKEFILE_NAME)"
@ -129,9 +137,16 @@ define \n
endef endef
.PHONY: cflags-update
cflags-update:
ifeq ($(SAVECFLAGS),1)
ifneq ($(subst $(DEPDIR)/,$(DEPDIR)/cflags-update,$(ALL_COMPILEFLAGS)),$(OLD_COMPILEFLAGS))
$(file >$(CFLAGS_TMPFILE),$(ALL_COMPILEFLAGS))
endif
endif
#default target: run targets in PRE_TARGETS, then the main executable, then POST_TARGETS #default target: run targets in PRE_TARGETS, then the main executable, then POST_TARGETS
.PHONY: all .PHONY: all
all: all: cflags-update
$(foreach target,$(PRE_TARGETS),@$(MAKE) $(SUBMAKE_ARGUMENTS) "$(target)"$(\n)) $(foreach target,$(PRE_TARGETS),@$(MAKE) $(SUBMAKE_ARGUMENTS) "$(target)"$(\n))
@$(MAKE) $(SUBMAKE_ARGUMENTS) "$(MAIN_EXECUTABLE)" @$(MAKE) $(SUBMAKE_ARGUMENTS) "$(MAIN_EXECUTABLE)"
$(foreach target,$(POST_TARGETS),@$(MAKE) $(SUBMAKE_ARGUMENTS) "$(target)"$(\n)) $(foreach target,$(POST_TARGETS),@$(MAKE) $(SUBMAKE_ARGUMENTS) "$(target)"$(\n))
@ -143,16 +158,16 @@ do_strip:
#Link executable #Link executable
$(MAIN_EXECUTABLE): $(OBJECTS) $(MAIN_EXECUTABLE): $(OBJECTS)
$(COMPILER) $^ -o "$(basename $@)" $(INTERNAL_LINKFLAGS) $(LDFLAGS) $(LDLIBS) $(COMPILER) $^ -o "$(basename $@)" $(ALL_LINKFLAGS) $(LDLIBS)
#Object target recipe #Object target recipe
define GENERATE_OBJECTS define GENERATE_OBJECTS
$$(OBJDIR)/$(subst \,.,$(subst /,.,$(1))).%.o: $(1)/% $$(OBJDIR)/$(subst \,.,$(subst /,.,$(1))).%.o: $(1)/% $(CFLAGS_TMPFILE)
$$(COMPILER) $$(COMPILER_FLAGS) $$(INTERNAL_COMPILERFLAGS) "$$<" -o "$$@" $$(COMPILER) $$(ALL_COMPILEFLAGS) "$$<" -o "$$@"
endef endef
define GENERATE_INDIVIDUAL_OBJECTS define GENERATE_INDIVIDUAL_OBJECTS
$$(OBJDIR)/$(subst \,.,$(subst /,.,$(1))).o: $(1) $$(OBJDIR)/$(subst \,.,$(subst /,.,$(1))).o: $(1) $(CFLAGS_TMPFILE)
$$(COMPILER) $$(COMPILER_FLAGS) $$(INTERNAL_COMPILERFLAGS) "$$<" -o "$$@" $$(COMPILER) $$(ALL_COMPILEFLAGS) "$$<" -o "$$@"
endef endef
#Create targets for object files #Create targets for object files
@ -173,6 +188,9 @@ clean:
$(call rmdir,"$(OBJDIR)") $(call rmdir,"$(OBJDIR)")
$(call rm,"$(MAIN_EXECUTABLE)") $(call rm,"$(MAIN_EXECUTABLE)")
$(call rm,"$(MAIN_EXECUTABLE).exe") $(call rm,"$(MAIN_EXECUTABLE).exe")
ifeq ($(SAVECFLAGS),1)
$(call rm,"$(CFLAGS_TMPFILE)")
endif
#header file dep tracking #header file dep tracking
-include $(wildcard $(DEPDIR)/*.d) -include $(wildcard $(DEPDIR)/*.d)

View File

@ -37,6 +37,7 @@ SHARED?=1
STATIC?=0 STATIC?=0
RELEASE?=0 RELEASE?=0
MEMCHK?=0 MEMCHK?=0
SAVECFLAGS?=1
ifneq ($(WINDOWS),1) ifneq ($(WINDOWS),1)
#*nix settings #*nix settings
@ -122,6 +123,11 @@ else
COMPILER_FLAGS+=-O0 -g3 -ggdb COMPILER_FLAGS+=-O0 -g3 -ggdb
endif endif
ifeq ($(SAVECFLAGS),1)
CFLAGS_TMPFILE::=.cflags.tmp
OLD_COMPILEFLAGS::=$(file <$(CFLAGS_TMPFILE))
endif
#add dependency tracking and include directories #add dependency tracking and include directories
INTERNAL_COMPILERFLAGS=-c $(foreach dir,$(INCLUDE_DIRS),-I"$(dir)") -MMD -MP -MF"$(DEPDIR)/$(notdir $(patsubst %.o,%.d,$@))" INTERNAL_COMPILERFLAGS=-c $(foreach dir,$(INCLUDE_DIRS),-I"$(dir)") -MMD -MP -MF"$(DEPDIR)/$(notdir $(patsubst %.o,%.d,$@))"
INTERNAL_LINKFLAGS=$(foreach dir,$(LIBDIRS),-L"$(dir)") INTERNAL_LINKFLAGS=$(foreach dir,$(LIBDIRS),-L"$(dir)")
@ -131,6 +137,8 @@ endif
THIS_MAKEFILE_NAME::=$(lastword $(MAKEFILE_LIST)) THIS_MAKEFILE_NAME::=$(lastword $(MAKEFILE_LIST))
INTERNAL_SOURCES::=$(SOURCES) $(foreach source,$(SOURCE_DIRS),$(foreach ext,$(EXT),$(wildcard $(source)/*.$(ext)))) INTERNAL_SOURCES::=$(SOURCES) $(foreach source,$(SOURCE_DIRS),$(foreach ext,$(EXT),$(wildcard $(source)/*.$(ext))))
OBJECTS::=$(addprefix $(OBJDIR)/,$(subst \,.,$(subst /,.,$(addsuffix .o,$(INTERNAL_SOURCES))))) OBJECTS::=$(addprefix $(OBJDIR)/,$(subst \,.,$(subst /,.,$(addsuffix .o,$(INTERNAL_SOURCES)))))
ALL_COMPILEFLAGS=$(COMPILER_FLAGS) $(INTERNAL_COMPILERFLAGS)
ALL_LINKFLAGS=$(INTERNAL_LINKFLAGS) $(LDFLAGS)
#Arguments to make submake use this makefile without "Entering directory" stuff #Arguments to make submake use this makefile without "Entering directory" stuff
SUBMAKE_ARGUMENTS::=--no-print-directory -f "$(THIS_MAKEFILE_NAME)" SUBMAKE_ARGUMENTS::=--no-print-directory -f "$(THIS_MAKEFILE_NAME)"
@ -140,9 +148,16 @@ define \n
endef endef
.PHONY: cflags-update
cflags-update:
ifeq ($(SAVECFLAGS),1)
ifneq ($(subst $(DEPDIR)/,$(DEPDIR)/cflags-update,$(ALL_COMPILEFLAGS)),$(OLD_COMPILEFLAGS))
$(file >$(CFLAGS_TMPFILE),$(ALL_COMPILEFLAGS))
endif
endif
#default target: run targets in PRE_TARGETS, then build the main library, then POST_TARGETS #default target: run targets in PRE_TARGETS, then build the main library, then POST_TARGETS
.PHONY: all .PHONY: all
all: all: cflags-update
$(foreach target,$(PRE_TARGETS),@$(MAKE) $(SUBMAKE_ARGUMENTS) "$(target)"$(\n)) $(foreach target,$(PRE_TARGETS),@$(MAKE) $(SUBMAKE_ARGUMENTS) "$(target)"$(\n))
ifeq ($(SHARED),1) ifeq ($(SHARED),1)
ifeq ($(WINDOWS),1) ifeq ($(WINDOWS),1)
@ -162,12 +177,12 @@ endif #static
ifeq ($(WINDOWS),1) ifeq ($(WINDOWS),1)
#target for windows shared library #target for windows shared library
$(DLLOUT): $(OBJECTS) $(DLLOUT): $(OBJECTS)
$(COMPILER) -shared -o "$(DLLOUT)" $^ -Wl,--out-implib,"lib$(MAIN_LIBRARY).a" $(SHARED_LIBRARY_FLAGS) $(INTERNAL_LINKFLAGS) $(LDFLAGS) $(LDLIBS) $(COMPILER) -shared -o "$(DLLOUT)" $^ -Wl,--out-implib,"lib$(MAIN_LIBRARY).a" $(SHARED_LIBRARY_FLAGS) $(ALL_LINKFLAGS) $(LDLIBS)
else #windows else #windows
#target for *nix shared library #target for *nix shared library
$(INTERNAL_SHARED_LIBRARY): $(OBJECTS) $(INTERNAL_SHARED_LIBRARY): $(OBJECTS)
$(COMPILER) -shared -o "$@" $^ $(COMPILER_FLAGS) $(SHARED_LIBRARY_FLAGS) $(INTERNAL_LINKFLAGS) $(LDFLAGS) $(LDLIBS) $(COMPILER) -shared -o "$@" $^ $(COMPILER_FLAGS) $(SHARED_LIBRARY_FLAGS) $(ALL_LINKFLAGS) $(LDLIBS)
endif #windows endif #windows
#target for static library #target for static library
@ -188,12 +203,12 @@ endif
#Object target recipe #Object target recipe
define GENERATE_OBJECTS define GENERATE_OBJECTS
$$(OBJDIR)/$(subst \,.,$(subst /,.,$(1))).%.o: $(1)/% $$(OBJDIR)/$(subst \,.,$(subst /,.,$(1))).%.o: $(1)/% $(CFLAGS_TMPFILE)
$$(COMPILER) $$(COMPILER_FLAGS) $$(INTERNAL_COMPILERFLAGS) "$$<" -o "$$@" $$(COMPILER) $$(ALL_COMPILEFLAGS) "$$<" -o "$$@"
endef endef
define GENERATE_INDIVIDUAL_OBJECTS define GENERATE_INDIVIDUAL_OBJECTS
$$(OBJDIR)/$(subst \,.,$(subst /,.,$(1))).o: $(1) $$(OBJDIR)/$(subst \,.,$(subst /,.,$(1))).o: $(1) $(CFLAGS_TMPFILE)
$$(COMPILER) $$(COMPILER_FLAGS) $$(INTERNAL_COMPILERFLAGS) "$$<" -o "$$@" $$(COMPILER) $$(ALL_COMPILEFLAGS) "$$<" -o "$$@"
endef endef
@ -218,6 +233,9 @@ clean: object_clean
$(call rm,"lib$(MAIN_LIBRARY).so") $(call rm,"lib$(MAIN_LIBRARY).so")
$(call rm,"lib$(MAIN_LIBRARY).a") $(call rm,"lib$(MAIN_LIBRARY).a")
$(call rm,"$(DLLOUT)") $(call rm,"$(DLLOUT)")
ifeq ($(SAVECFLAGS),1)
$(call rm,"$(CFLAGS_TMPFILE)")
endif
#header file dep tracking #header file dep tracking
-include $(wildcard $(DEPDIR)/*.d) -include $(wildcard $(DEPDIR)/*.d)