* "git push" says "src refspec XYZ matches more than one" even without explicit XYZ argument.
@ 2016-10-28 3:00 Kannan Goundan
2016-10-28 19:13 ` Junio C Hamano
0 siblings, 1 reply; 2+ messages in thread
From: Kannan Goundan @ 2016-10-28 3:00 UTC (permalink / raw)
To: git
1. My repo has a branch named 'v1' that is tracking 'origin/v1'.
2. My repo has a tag named 'v1'.
3. I have "push.default" set to "upstream".
I made a commit on branch 'v1' and tried doing a push:
# git push
error: src refspec v1 matches more than one.
error: failed to push some refs to 'git@github.com:whatever/ns1-go.git'
If I rename the branch to 'v1-dev', then the push goes through.
I understand why the command "git push origin/v1 v1" is ambiguous.
But if I do a plain "git push", I thought Git would know to push my
current branch.
[Git version 2.10.1 from Homebrew on Mac OS 10.11.6.]
^ permalink raw reply [flat|nested] 2+ messages in thread
* Re: "git push" says "src refspec XYZ matches more than one" even without explicit XYZ argument.
2016-10-28 3:00 "git push" says "src refspec XYZ matches more than one" even without explicit XYZ argument Kannan Goundan
@ 2016-10-28 19:13 ` Junio C Hamano
0 siblings, 0 replies; 2+ messages in thread
From: Junio C Hamano @ 2016-10-28 19:13 UTC (permalink / raw)
To: Kannan Goundan; +Cc: git
Kannan Goundan <kannan@cakoose.com> writes:
> 1. My repo has a branch named 'v1' that is tracking 'origin/v1'.
> 2. My repo has a tag named 'v1'.
> 3. I have "push.default" set to "upstream".
>
> I made a commit on branch 'v1' and tried doing a push:
>
> # git push
> error: src refspec v1 matches more than one.
> error: failed to push some refs to 'git@github.com:whatever/ns1-go.git'
>
> If I rename the branch to 'v1-dev', then the push goes through.
>
> I understand why the command "git push origin/v1 v1" is ambiguous.
> But if I do a plain "git push", I thought Git would know to push my
> current branch.
>
> [Git version 2.10.1 from Homebrew on Mac OS 10.11.6.]
Thanks.
You are right that the refspec Git internally create for this case
should not be v1:refs/heads/v1, which would notice that the source
side (e.g. "v1") is ambiguous. Instead we should spell that out.
Perhaps something like this would fix it for you?
builtin/push.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/builtin/push.c b/builtin/push.c
index 3bb9d6b7e6..02fd235742 100644
--- a/builtin/push.c
+++ b/builtin/push.c
@@ -194,7 +194,7 @@ static void setup_push_upstream(struct remote *remote, struct branch *branch,
die_push_simple(branch, remote);
}
- strbuf_addf(&refspec, "%s:%s", branch->name, branch->merge[0]->src);
+ strbuf_addf(&refspec, "%s:%s", branch->refname, branch->merge[0]->src);
add_refspec(refspec.buf);
}
^ permalink raw reply related [flat|nested] 2+ messages in thread
end of thread, other threads:[~2016-10-28 19:13 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2016-10-28 3:00 "git push" says "src refspec XYZ matches more than one" even without explicit XYZ argument Kannan Goundan
2016-10-28 19:13 ` Junio C Hamano
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.