提交 8f84fef2 编写于 作者: J Jim Meyering

build: submodule machinery now works also when no tag is reachable

The code in cfg.mk to detect when the git submodule was out of date
worked most of the time, but not when checked out in a certain way.
* cfg.mk: Extract submodule hash from command output and file,
and compare only that, since the format of the full line may vary.
Reported by Mike Burns, with some diagnosis by Daniel P Berrange.
上级 0714b2ba
...@@ -242,9 +242,17 @@ prev_version_file = /dev/null ...@@ -242,9 +242,17 @@ prev_version_file = /dev/null
ifeq (0,$(MAKELEVEL)) ifeq (0,$(MAKELEVEL))
_curr_status = .git-module-status _curr_status = .git-module-status
_update_required := \ # The sed filter accommodates those who check out on a commit from which
$(shell t=$$(git submodule status); \ # no tag is reachable. In that case, git submodule status prints a "-"
test "$$t" = "$$(cat $(_curr_status) 2>/dev/null)"; echo $$?) # in column 1 and does not print a "git describe"-style string after the
# submodule name. Contrast these:
# -b653eda3ac4864de205419d9f41eec267cb89eeb .gnulib
# b653eda3ac4864de205419d9f41eec267cb89eeb .gnulib (v0.0-2286-gb653eda)
_submodule_hash = sed 's/.//;s/ .*//'
_update_required := $(shell \
actual=$$(git submodule status | $(_submodule_hash)); \
stamp="$$($(_submodule_hash) $(_curr_status) 2>/dev/null)"; \
test "$$stamp" = "$$actual"; echo $$?)
ifeq (1,$(_update_required)) ifeq (1,$(_update_required))
$(error gnulib update required; run ./autogen.sh first) $(error gnulib update required; run ./autogen.sh first)
endif endif
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册