pull, fetch: add --set-upstream option
Add the --set-upstream option to git pull/fetch
which lets the user set the upstream configuration
(branch.<current-branch-name>.merge and
branch.<current-branch-name>.remote) for the current branch.
A typical use-case is:
git clone http://example.com/my-public-fork
git remote add main http://example.com/project-main-repo
git pull --set-upstream main master
or, instead of the last line:
git fetch --set-upstream main master
git merge # or git rebase
This is mostly equivalent to cloning project-main-repo (which sets
upsteam) and then "git remote add" my-public-fork, but may feel more
natural for people using a hosting system which allows forking from
the web UI.
This functionality is analog to "git push --set-upstream".
Signed-off-by: Corentin BOMPARD <corentin.bompard@etu.univ-lyon1.fr>
Signed-off-by: Nathan BERBEZIER <nathan.berbezier@etu.univ-lyon1.fr>
Signed-off-by: Pablo CHABANNE <pablo.chabanne@etu.univ-lyon1.fr>
Signed-off-by: Matthieu Moy <git@matthieu-moy.fr>
Patch-edited-by: Matthieu Moy <git@matthieu-moy.fr>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
committed by
Junio C Hamano
parent
ff66981f45
commit
24bc1a1292
@ -23,6 +23,7 @@
|
||||
#include "packfile.h"
|
||||
#include "list-objects-filter-options.h"
|
||||
#include "commit-reach.h"
|
||||
#include "branch.h"
|
||||
|
||||
#define FORCED_UPDATES_DELAY_WARNING_IN_MS (10 * 1000)
|
||||
|
||||
@ -50,7 +51,8 @@ static int fetch_prune_tags_config = -1; /* unspecified */
|
||||
static int prune_tags = -1; /* unspecified */
|
||||
#define PRUNE_TAGS_BY_DEFAULT 0 /* do we prune tags by default? */
|
||||
|
||||
static int all, append, dry_run, force, keep, multiple, update_head_ok, verbosity, deepen_relative;
|
||||
static int all, append, dry_run, force, keep, multiple, update_head_ok;
|
||||
static int verbosity, deepen_relative, set_upstream;
|
||||
static int progress = -1;
|
||||
static int enable_auto_gc = 1;
|
||||
static int tags = TAGS_DEFAULT, unshallow, update_shallow, deepen;
|
||||
@ -123,6 +125,8 @@ static struct option builtin_fetch_options[] = {
|
||||
OPT__VERBOSITY(&verbosity),
|
||||
OPT_BOOL(0, "all", &all,
|
||||
N_("fetch from all remotes")),
|
||||
OPT_BOOL(0, "set-upstream", &set_upstream,
|
||||
N_("set upstream for git pull/fetch")),
|
||||
OPT_BOOL('a', "append", &append,
|
||||
N_("append to .git/FETCH_HEAD instead of overwriting")),
|
||||
OPT_STRING(0, "upload-pack", &upload_pack, N_("path"),
|
||||
@ -1367,6 +1371,51 @@ static int do_fetch(struct transport *transport,
|
||||
retcode = 1;
|
||||
goto cleanup;
|
||||
}
|
||||
|
||||
if (set_upstream) {
|
||||
struct branch *branch = branch_get("HEAD");
|
||||
struct ref *rm;
|
||||
struct ref *source_ref = NULL;
|
||||
|
||||
/*
|
||||
* We're setting the upstream configuration for the
|
||||
* current branch. The relevent upstream is the
|
||||
* fetched branch that is meant to be merged with the
|
||||
* current one, i.e. the one fetched to FETCH_HEAD.
|
||||
*
|
||||
* When there are several such branches, consider the
|
||||
* request ambiguous and err on the safe side by doing
|
||||
* nothing and just emit a warning.
|
||||
*/
|
||||
for (rm = ref_map; rm; rm = rm->next) {
|
||||
if (!rm->peer_ref) {
|
||||
if (source_ref) {
|
||||
warning(_("multiple branch detected, incompatible with --set-upstream"));
|
||||
goto skip;
|
||||
} else {
|
||||
source_ref = rm;
|
||||
}
|
||||
}
|
||||
}
|
||||
if (source_ref) {
|
||||
if (!strcmp(source_ref->name, "HEAD") ||
|
||||
starts_with(source_ref->name, "refs/heads/"))
|
||||
install_branch_config(0,
|
||||
branch->name,
|
||||
transport->remote->name,
|
||||
source_ref->name);
|
||||
else if (starts_with(source_ref->name, "refs/remotes/"))
|
||||
warning(_("not setting upstream for a remote remote-tracking branch"));
|
||||
else if (starts_with(source_ref->name, "refs/tags/"))
|
||||
warning(_("not setting upstream for a remote tag"));
|
||||
else
|
||||
warning(_("unknown branch type"));
|
||||
} else {
|
||||
warning(_("no source branch found.\n"
|
||||
"you need to specify exactly one branch with the --set-upstream option."));
|
||||
}
|
||||
}
|
||||
skip:
|
||||
free_refs(ref_map);
|
||||
|
||||
/* if neither --no-tags nor --tags was specified, do automated tag
|
||||
|
||||
Reference in New Issue
Block a user