Fix make_update switching branches with multiple upstreams
If repository has multiple remotes with the same name of branch checking out to the branch using simple `git checkout branch` exists with an error: this is because there is ambiguity w.r.t which remote to track. Now the code explicitly provides remote to track, preferring to use "origin" first (which is to be used for Blender style of workflow, and Github style workflow when there is a fork available), and use "upstream" if there is no origin. Pull Request #105176
This commit is contained in:
parent
2c5434c3f5
commit
f30c395a7c
|
@ -432,7 +432,10 @@ def external_scripts_update(args: argparse.Namespace,
|
|||
# Switch to branch and pull.
|
||||
if submodule_branch:
|
||||
if make_utils.git_branch(args.git_command) != submodule_branch:
|
||||
call([args.git_command, "checkout", submodule_branch])
|
||||
if make_utils.git_remote_exist(args.git_command, "origin"):
|
||||
call([args.git_command, "checkout", "-t", f"origin/{submodule_branch}"])
|
||||
elif make_utils.git_remote_exist(args.git_command, "upstream"):
|
||||
call([args.git_command, "checkout", "-t", f"upstream/{submodule_branch}"])
|
||||
# Don't use extra fetch since all remotes of interest have been already fetched
|
||||
# some lines above.
|
||||
skip_msg += work_tree_update(args, use_fetch=False)
|
||||
|
|
Loading…
Reference in New Issue