diff options
author | Felipe Contreras <felipe.contreras@gmail.com> | 2021-05-31 14:51:14 -0500 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2021-06-02 10:12:01 +0900 |
commit | 04159fba42b61ffa954dfb1fa13df1862c210ad8 (patch) | |
tree | 1d125e46b967b87a1b7422ef8d3f2182c512cea6 | |
parent | push: return immediately in trivial switch case (diff) | |
download | tgif-04159fba42b61ffa954dfb1fa13df1862c210ad8.tar.xz |
push: split switch cases
We want all the cases that don't do anything with a branch first, and
then the rest. That way we will be able to get the branch and die if
there's a problem in the parent function, instead of inside the function
of each mode.
Signed-off-by: Felipe Contreras <felipe.contreras@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
-rw-r--r-- | builtin/push.c | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/builtin/push.c b/builtin/push.c index 0aa1d0f07d..f64b7100f0 100644 --- a/builtin/push.c +++ b/builtin/push.c @@ -254,11 +254,20 @@ static void setup_default_push_refspecs(struct remote *remote) int same_remote = is_same_remote(remote); switch (push_default) { - default: case PUSH_DEFAULT_MATCHING: refspec_append(&rs, ":"); return; + case PUSH_DEFAULT_NOTHING: + die(_("You didn't specify any refspecs to push, and " + "push.default is \"nothing\".")); + return; + default: + break; + } + + switch (push_default) { + default: case PUSH_DEFAULT_UNSPECIFIED: case PUSH_DEFAULT_SIMPLE: setup_push_simple(remote, branch, same_remote); @@ -271,11 +280,6 @@ static void setup_default_push_refspecs(struct remote *remote) case PUSH_DEFAULT_CURRENT: setup_push_current(remote, branch); return; - - case PUSH_DEFAULT_NOTHING: - die(_("You didn't specify any refspecs to push, and " - "push.default is \"nothing\".")); - return; } } |