From: Stefan Beller Date: Fri, 5 Jan 2018 20:03:03 +0000 (-0800) Subject: unpack-trees: oneway_merge to update submodules X-Git-Tag: v2.16.3~35^2~1 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=ad17312e1170715a15651b3185dae9ebc6b6b8ef;p=git unpack-trees: oneway_merge to update submodules When there is a one way merge, each submodule needs to be one way merged as well, if we're asked to recurse into submodules. In case of a submodule, check if it is up-to-date, otherwise set the flag CE_UPDATE, which will trigger an update of it in the phase updating the tree later. Signed-off-by: Stefan Beller Signed-off-by: Junio C Hamano --- diff --git a/unpack-trees.c b/unpack-trees.c index bf8b602901..96c3327f19 100644 --- a/unpack-trees.c +++ b/unpack-trees.c @@ -2139,6 +2139,9 @@ int oneway_merge(const struct cache_entry * const *src, ie_match_stat(o->src_index, old, &st, CE_MATCH_IGNORE_VALID|CE_MATCH_IGNORE_SKIP_WORKTREE)) update |= CE_UPDATE; } + if (o->update && S_ISGITLINK(old->ce_mode) && + should_update_submodules() && !verify_uptodate(old, o)) + update |= CE_UPDATE; add_entry(o, old, update, 0); return 0; }