summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLibravatar Felipe Contreras <felipe.contreras@gmail.com>2021-05-31 14:51:17 -0500
committerLibravatar Junio C Hamano <gitster@pobox.com>2021-06-02 10:12:01 +0900
commit00458dc5f191f52ef965ca7185b739e8c800b7cb (patch)
treeadc489b48b9dce01a18c39678c29d5977b529d16
parentpush: only get the branch when needed (diff)
downloadtgif-00458dc5f191f52ef965ca7185b739e8c800b7cb.tar.xz
push: make setup_push_* return the dst
All of the setup_push_* functions are appending a refspec. Do this only once on the parent function. Signed-off-by: Felipe Contreras <felipe.contreras@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
-rw-r--r--builtin/push.c30
1 files changed, 16 insertions, 14 deletions
diff --git a/builtin/push.c b/builtin/push.c
index d9f9d20f39..933b1cc6c0 100644
--- a/builtin/push.c
+++ b/builtin/push.c
@@ -202,8 +202,8 @@ static const char *get_upstream_ref(struct branch *branch, const char *remote_na
return branch->merge[0]->src;
}
-static void setup_push_upstream(struct remote *remote, struct branch *branch,
- int same_remote)
+static const char *setup_push_upstream(struct remote *remote, struct branch *branch,
+ int same_remote)
{
const char *upstream_ref;
upstream_ref = get_upstream_ref(branch, remote->name);
@@ -212,16 +212,15 @@ static void setup_push_upstream(struct remote *remote, struct branch *branch,
"your current branch '%s', without telling me what to push\n"
"to update which remote branch."),
remote->name, branch->name);
-
- refspec_appendf(&rs, "%s:%s", branch->refname, upstream_ref);
+ return upstream_ref;
}
-static void setup_push_current(struct remote *remote, struct branch *branch)
+static const char *setup_push_current(struct remote *remote, struct branch *branch)
{
- refspec_appendf(&rs, "%s:%s", branch->refname, branch->refname);
+ return branch->refname;
}
-static void setup_push_simple(struct remote *remote, struct branch *branch, int same_remote)
+static const char *setup_push_simple(struct remote *remote, struct branch *branch, int same_remote)
{
if (same_remote) {
const char *upstream_ref;
@@ -232,7 +231,7 @@ static void setup_push_simple(struct remote *remote, struct branch *branch, int
if (strcmp(branch->refname, upstream_ref))
die_push_simple(branch, remote);
}
- refspec_appendf(&rs, "%s:%s", branch->refname, branch->refname);
+ return branch->refname;
}
static int is_same_remote(struct remote *remote)
@@ -245,6 +244,7 @@ static void setup_default_push_refspecs(struct remote *remote)
{
struct branch *branch;
int same_remote = is_same_remote(remote);
+ const char *dst;
switch (push_default) {
case PUSH_DEFAULT_MATCHING:
@@ -267,17 +267,19 @@ static void setup_default_push_refspecs(struct remote *remote)
default:
case PUSH_DEFAULT_UNSPECIFIED:
case PUSH_DEFAULT_SIMPLE:
- setup_push_simple(remote, branch, same_remote);
- return;
+ dst = setup_push_simple(remote, branch, same_remote);
+ break;
case PUSH_DEFAULT_UPSTREAM:
- setup_push_upstream(remote, branch, same_remote);
- return;
+ dst = setup_push_upstream(remote, branch, same_remote);
+ break;
case PUSH_DEFAULT_CURRENT:
- setup_push_current(remote, branch);
- return;
+ dst = setup_push_current(remote, branch);
+ break;
}
+
+ refspec_appendf(&rs, "%s:%s", branch->refname, dst);
}
static const char message_advice_pull_before_push[] =