Teach Makefile to check header dependencies
Add a target to use the gcc-generated makefile snippets for dependencies on header files to check the hard-coded dependencies. With this patch applied, if any dependencies are missing, then make clean make COMPUTE_HEADER_DEPENDENCIES=YesPlease make CHECK_HEADER_DEPENDENCIES=YesPlease will produce an error message like the following: CHECK fast-import.o missing dependencies: exec_cmd.h make: *** [fast-import.o] Error 1 Signed-off-by: Jonathan Nieder <jrnieder@gmail.com>
This commit is contained in:
parent
1b22c99c14
commit
f2fabbf76e
105
Makefile
105
Makefile
@ -221,6 +221,9 @@ all::
|
|||||||
# Define COMPUTE_HEADER_DEPENDENCIES if your compiler supports the -MMD option
|
# Define COMPUTE_HEADER_DEPENDENCIES if your compiler supports the -MMD option
|
||||||
# and you want to avoid rebuilding objects when an unrelated header file
|
# and you want to avoid rebuilding objects when an unrelated header file
|
||||||
# changes.
|
# changes.
|
||||||
|
#
|
||||||
|
# Define CHECK_HEADER_DEPENDENCIES to check for problems in the hard-coded
|
||||||
|
# dependency rules.
|
||||||
|
|
||||||
GIT-VERSION-FILE: FORCE
|
GIT-VERSION-FILE: FORCE
|
||||||
@$(SHELL_PATH) ./GIT-VERSION-GEN
|
@$(SHELL_PATH) ./GIT-VERSION-GEN
|
||||||
@ -1088,6 +1091,14 @@ endif
|
|||||||
-include config.mak.autogen
|
-include config.mak.autogen
|
||||||
-include config.mak
|
-include config.mak
|
||||||
|
|
||||||
|
ifdef CHECK_HEADER_DEPENDENCIES
|
||||||
|
USE_COMPUTED_HEADER_DEPENDENCIES =
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifdef COMPUTE_HEADER_DEPENDENCIES
|
||||||
|
USE_COMPUTED_HEADER_DEPENDENCIES = YesPlease
|
||||||
|
endif
|
||||||
|
|
||||||
ifdef SANE_TOOL_PATH
|
ifdef SANE_TOOL_PATH
|
||||||
SANE_TOOL_PATH_SQ = $(subst ','\'',$(SANE_TOOL_PATH))
|
SANE_TOOL_PATH_SQ = $(subst ','\'',$(SANE_TOOL_PATH))
|
||||||
BROKEN_PATH_FIX = 's|^\# @@BROKEN_PATH_FIX@@$$|git_broken_path_fix $(SANE_TOOL_PATH_SQ)|'
|
BROKEN_PATH_FIX = 's|^\# @@BROKEN_PATH_FIX@@$$|git_broken_path_fix $(SANE_TOOL_PATH_SQ)|'
|
||||||
@ -1681,9 +1692,7 @@ XDIFF_OBJS = xdiff/xdiffi.o xdiff/xprepare.o xdiff/xutils.o xdiff/xemit.o \
|
|||||||
xdiff/xmerge.o xdiff/xpatience.o
|
xdiff/xmerge.o xdiff/xpatience.o
|
||||||
OBJECTS := $(GIT_OBJS) $(XDIFF_OBJS)
|
OBJECTS := $(GIT_OBJS) $(XDIFF_OBJS)
|
||||||
|
|
||||||
ASM_SRC := $(wildcard $(OBJECTS:o=S))
|
dep_files := $(foreach f,$(OBJECTS),$(dir $f)deps/$(notdir $f).d)
|
||||||
ASM_OBJ := $(ASM_SRC:S=o)
|
|
||||||
C_OBJ := $(filter-out $(ASM_OBJ),$(OBJECTS))
|
|
||||||
|
|
||||||
ifdef COMPUTE_HEADER_DEPENDENCIES
|
ifdef COMPUTE_HEADER_DEPENDENCIES
|
||||||
dep_dirs := $(addsuffix deps,$(sort $(dir $(OBJECTS))))
|
dep_dirs := $(addsuffix deps,$(sort $(dir $(OBJECTS))))
|
||||||
@ -1691,33 +1700,89 @@ $(dep_dirs):
|
|||||||
mkdir -p $@
|
mkdir -p $@
|
||||||
|
|
||||||
missing_dep_dirs := $(filter-out $(wildcard $(dep_dirs)),$(dep_dirs))
|
missing_dep_dirs := $(filter-out $(wildcard $(dep_dirs)),$(dep_dirs))
|
||||||
else
|
dep_file = $(dir $@)deps/$(notdir $@).d
|
||||||
|
dep_args = -MF $(dep_file) -MMD -MP
|
||||||
|
ifdef CHECK_HEADER_DEPENDENCIES
|
||||||
|
$(error cannot compute header dependencies outside a normal build. \
|
||||||
|
Please unset CHECK_HEADER_DEPENDENCIES and try again)
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifndef COMPUTE_HEADER_DEPENDENCIES
|
||||||
|
ifndef CHECK_HEADER_DEPENDENCIES
|
||||||
dep_dirs =
|
dep_dirs =
|
||||||
missing_dep_dirs =
|
missing_dep_dirs =
|
||||||
|
dep_args =
|
||||||
endif
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifdef CHECK_HEADER_DEPENDENCIES
|
||||||
|
ifndef PRINT_HEADER_DEPENDENCIES
|
||||||
|
missing_deps = $(filter-out $(notdir $^), \
|
||||||
|
$(notdir $(shell $(MAKE) -s $@ \
|
||||||
|
CHECK_HEADER_DEPENDENCIES=YesPlease \
|
||||||
|
USE_COMPUTED_HEADER_DEPENDENCIES=YesPlease \
|
||||||
|
PRINT_HEADER_DEPENDENCIES=YesPlease)))
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
ASM_SRC := $(wildcard $(OBJECTS:o=S))
|
||||||
|
ASM_OBJ := $(ASM_SRC:S=o)
|
||||||
|
C_OBJ := $(filter-out $(ASM_OBJ),$(OBJECTS))
|
||||||
|
|
||||||
.SUFFIXES:
|
.SUFFIXES:
|
||||||
|
|
||||||
$(C_OBJ): %.o: %.c GIT-CFLAGS $(missing_dep_dirs)
|
ifdef PRINT_HEADER_DEPENDENCIES
|
||||||
$(QUIET_CC)$(CC) -o $*.o -c $(dep_args) $(ALL_CFLAGS) $<
|
$(C_OBJ): %.o: %.c FORCE
|
||||||
%.s: %.c GIT-CFLAGS FORCE
|
echo $^
|
||||||
$(QUIET_CC)$(CC) -S $(ALL_CFLAGS) $<
|
$(ASM_OBJ): %.o: %.S FORCE
|
||||||
$(ASM_OBJ): %.o: %.S GIT-CFLAGS $(missing_dep_dirs)
|
echo $^
|
||||||
$(QUIET_CC)$(CC) -o $*.o -c $(dep_args) $(ALL_CFLAGS) $<
|
|
||||||
|
|
||||||
ifdef COMPUTE_HEADER_DEPENDENCIES
|
ifndef CHECK_HEADER_DEPENDENCIES
|
||||||
# Take advantage of gcc's on-the-fly dependency generation
|
$(error cannot print header dependencies during a normal build. \
|
||||||
# See <http://gcc.gnu.org/gcc-3.0/features.html>.
|
Please set CHECK_HEADER_DEPENDENCIES and try again)
|
||||||
dep_files := $(wildcard $(foreach f,$(OBJECTS),$(dir f)deps/$(notdir $f).d))
|
endif
|
||||||
ifneq ($(dep_files),)
|
|
||||||
include $(dep_files)
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
dep_file = $(dir $@)deps/$(notdir $@).d
|
ifndef PRINT_HEADER_DEPENDENCIES
|
||||||
dep_args = -MF $(dep_file) -MMD -MP
|
ifdef CHECK_HEADER_DEPENDENCIES
|
||||||
else
|
$(C_OBJ): %.o: %.c $(dep_files) FORCE
|
||||||
dep_args =
|
@set -e; echo CHECK $@; \
|
||||||
|
missing_deps="$(missing_deps)"; \
|
||||||
|
if test "$$missing_deps"; \
|
||||||
|
then \
|
||||||
|
echo missing dependencies: $$missing_deps; \
|
||||||
|
false; \
|
||||||
|
fi
|
||||||
|
$(ASM_OBJ): %.o: %.S $(dep_files) FORCE
|
||||||
|
@set -e; echo CHECK $@; \
|
||||||
|
missing_deps="$(missing_deps)"; \
|
||||||
|
if test "$$missing_deps"; \
|
||||||
|
then \
|
||||||
|
echo missing dependencies: $$missing_deps; \
|
||||||
|
false; \
|
||||||
|
fi
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifndef CHECK_HEADER_DEPENDENCIES
|
||||||
|
$(C_OBJ): %.o: %.c GIT-CFLAGS $(missing_dep_dirs)
|
||||||
|
$(QUIET_CC)$(CC) -o $*.o -c $(dep_args) $(ALL_CFLAGS) $<
|
||||||
|
$(ASM_OBJ): %.o: %.S GIT-CFLAGS $(missing_dep_dirs)
|
||||||
|
$(QUIET_CC)$(CC) -o $*.o -c $(dep_args) $(ALL_CFLAGS) $<
|
||||||
|
endif
|
||||||
|
|
||||||
|
%.s: %.c GIT-CFLAGS FORCE
|
||||||
|
$(QUIET_CC)$(CC) -S $(ALL_CFLAGS) $<
|
||||||
|
|
||||||
|
ifdef USE_COMPUTED_HEADER_DEPENDENCIES
|
||||||
|
# Take advantage of gcc's on-the-fly dependency generation
|
||||||
|
# See <http://gcc.gnu.org/gcc-3.0/features.html>.
|
||||||
|
dep_files_present := $(wildcard $(dep_files))
|
||||||
|
ifneq ($(dep_files_present),)
|
||||||
|
include $(dep_files_present)
|
||||||
|
endif
|
||||||
|
else
|
||||||
# Dependencies on header files, for platforms that do not support
|
# Dependencies on header files, for platforms that do not support
|
||||||
# the gcc -MMD option.
|
# the gcc -MMD option.
|
||||||
#
|
#
|
||||||
|
Loading…
Reference in New Issue
Block a user