diff options
author | Steffen Prohaska <prohaska@zib.de> | 2007-11-11 15:01:47 +0100 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2007-11-19 03:39:01 +0100 |
commit | ae36bdcf5147b1b54de852eda111ad76a3040726 (patch) | |
tree | c50286f86b92ead687ddab7d51460bd9cbc70825 /remote.c | |
parent | add refname_match() (diff) | |
download | git-ae36bdcf5147b1b54de852eda111ad76a3040726.tar.xz git-ae36bdcf5147b1b54de852eda111ad76a3040726.zip |
push: use same rules as git-rev-parse to resolve refspecs
This commit changes the rules for resolving refspecs to match the
rules for resolving refs in rev-parse. git-rev-parse uses clear rules
to resolve a short ref to its full name, which are well documented.
The rules for resolving refspecs documented in git-send-pack were
less strict and harder to understand. This commit replaces them by
the rules of git-rev-parse.
The unified rules are easier to understand and better resolve ambiguous
cases. You can now push from a repository containing several branches
ending on the same short name.
Note, this may break existing setups. For example, "master" will no longer
resolve to "origin/master" even when there is no other "master" elsewhere.
Signed-off-by: Steffen Prohaska <prohaska@zib.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'remote.c')
-rw-r--r-- | remote.c | 5 |
1 files changed, 1 insertions, 4 deletions
@@ -519,10 +519,7 @@ static int count_refspec_match(const char *pattern, char *name = refs->name; int namelen = strlen(name); - if (namelen < patlen || - memcmp(name + namelen - patlen, pattern, patlen)) - continue; - if (namelen != patlen && name[namelen - patlen - 1] != '/') + if (!refname_match(pattern, name, ref_rev_parse_rules)) continue; /* A match is "weak" if it is with refs outside |