diff options
author | Junio C Hamano <gitster@pobox.com> | 2009-03-21 13:23:27 -0700 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2009-03-22 23:52:11 -0700 |
commit | 03d3aada5a2a68a7acdb6286fd72155f01626e41 (patch) | |
tree | c6004aad880990bc7ec00057b24849097ac45ecf /builtin-branch.c | |
parent | a31dca0393fefae894b7a155ae24000107bcc383 (diff) | |
download | git-03d3aada5a2a68a7acdb6286fd72155f01626e41.tar.gz git-03d3aada5a2a68a7acdb6286fd72155f01626e41.tar.xz |
Fix branch -m @{-1} newname
The command is supposed to rename the branch we were on before switched
from to a new name, but was not aware of the short-hand notation we added
recently.
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'builtin-branch.c')
-rw-r--r-- | builtin-branch.c | 14 |
1 files changed, 7 insertions, 7 deletions
diff --git a/builtin-branch.c b/builtin-branch.c index 7452db13c..0df82bf96 100644 --- a/builtin-branch.c +++ b/builtin-branch.c @@ -468,18 +468,18 @@ static void rename_branch(const char *oldname, const char *newname, int force) if (!oldname) die("cannot rename the current branch while not on any."); - strbuf_addf(&oldref, "refs/heads/%s", oldname); - + strbuf_branchname(&oldref, oldname); + strbuf_splice(&oldref, 0, 0, "refs/heads/", 11); if (check_ref_format(oldref.buf)) - die("Invalid branch name: %s", oldref.buf); - - strbuf_addf(&newref, "refs/heads/%s", newname); + die("Invalid branch name: '%s'", oldname); + strbuf_branchname(&newref, newname); + strbuf_splice(&newref, 0, 0, "refs/heads/", 11); if (check_ref_format(newref.buf)) - die("Invalid branch name: %s", newref.buf); + die("Invalid branch name: '%s'", newname); if (resolve_ref(newref.buf, sha1, 1, NULL) && !force) - die("A branch named '%s' already exists.", newname); + die("A branch named '%s' already exists.", newref.buf + 11); strbuf_addf(&logmsg, "Branch: renamed %s to %s", oldref.buf, newref.buf); |