fetch --all/--multiple: keep all the fetched branch information
authorJunio C Hamano <gitster@pobox.com>
Wed, 24 Feb 2010 19:02:05 +0000 (11:02 -0800)
committerJunio C Hamano <gitster@pobox.com>
Wed, 24 Feb 2010 19:16:36 +0000 (11:16 -0800)
commite6cc51046f3669332f51a52a7de966d842b9d4e4
treecfeb5cb99a2312d95d219874ac68080f9089f67c
parentbba5322a71a3399a94f53e1dddf5bd66e493dfbc
fetch --all/--multiple: keep all the fetched branch information

Since "git fetch" learned "--all" and "--multiple" options, it has become
tempting for users to say "git pull --all".  Even though it may fetch from
remotes that do not need to be fetched from for merging with the current
branch, it is handy.

"git fetch" however clears the list of fetched branches every time it
contacts a different remote.  Unless the current branch is configured to
merge with a branch from a remote that happens to be the last in the list
of remotes that are contacted, "git pull" that fetches from multiple
remotes will not be able to find the branch it should be merging with.

Make "fetch" clear FETCH_HEAD (unless --append is given) and then append
the list of branches fetched to it (even when --append is not given).  That
way, "pull" will be able to find the data for the branch being merged in
FETCH_HEAD no matter where the remote appears in the list of remotes to be
contacted by "git fetch".

Reported-by: Michael Lukashov
Signed-off-by: Junio C Hamano <gitster@pobox.com>
builtin-fetch.c
t/t5521-pull-options.sh