change the recursive dependency template to use more make evaluation - the shell command got so long that it triggered "Argument list too long" on some systems (#8231)
SVN-Revision: 24131
This commit is contained in:
parent
721a005dc2
commit
695a1268e1
1 changed files with 22 additions and 21 deletions
|
@ -20,28 +20,29 @@ define rdep
|
||||||
.SILENT: $(2)_check
|
.SILENT: $(2)_check
|
||||||
|
|
||||||
$(2): $(2)_check
|
$(2): $(2)_check
|
||||||
|
|
||||||
|
ifneq ($(wildcard $(2)),)
|
||||||
$(2)_check::
|
$(2)_check::
|
||||||
if [ -f "$(2)" ]; then \
|
$(if $(3), \
|
||||||
$(if $(3), \
|
$(call find_md5,$(1),$(4)) > $(3).1; \
|
||||||
$(call find_md5,$(1),$(4)) > $(3).1; \
|
{ [ \! -f "$(3)" ] || diff $(3) $(3).1 >/dev/null; } && \
|
||||||
{ [ \! -f "$(3)" ] || diff $(3) $(3).1 >/dev/null; } && \
|
) \
|
||||||
) \
|
{ \
|
||||||
{ \
|
[ -f "$(2)_check.1" ] && mv "$(2)_check.1"; \
|
||||||
[ -f "$(2)_check.1" ] && mv "$(2)_check.1"; \
|
$(TOPDIR)/scripts/timestamp.pl $(DEP_FINDPARAMS) $(4) -n $(2) $(1) && { \
|
||||||
$(TOPDIR)/scripts/timestamp.pl $(DEP_FINDPARAMS) $(4) -n $(2) $(1) && { \
|
$(call debug_eval,$(SUBDIR),r,echo "No need to rebuild $(2)";) \
|
||||||
$(call debug_eval,$(SUBDIR),r,echo "No need to rebuild $(2)";) \
|
touch -r "$(2)" "$(2)_check"; \
|
||||||
touch -r "$(2)" "$(2)_check"; \
|
} \
|
||||||
} \
|
} || { \
|
||||||
} || { \
|
$(call debug_eval,$(SUBDIR),r,echo "Need to rebuild $(2)";) \
|
||||||
$(call debug_eval,$(SUBDIR),r,echo "Need to rebuild $(2)";) \
|
touch "$(2)_check"; \
|
||||||
touch "$(2)_check"; \
|
}
|
||||||
}; \
|
$(if $(3), mv $(3).1 $(3))
|
||||||
$(if $(3), mv $(3).1 $(3);) \
|
else
|
||||||
else \
|
$(2)_check::
|
||||||
$(if $(3), rm -f $(3) $(3).1;) \
|
$(if $(3), rm -f $(3) $(3).1)
|
||||||
$(call debug_eval,$(SUBDIR),r,echo "Target $(2) not built";) \
|
$(call debug_eval,$(SUBDIR),r,echo "Target $(2) not built")
|
||||||
true; \
|
endif
|
||||||
fi
|
|
||||||
|
|
||||||
endef
|
endef
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue