diff options
author | Paul Tan <pyokagan@gmail.com> | 2015-06-06 19:46:11 +0800 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2015-06-08 13:10:45 -0700 |
commit | e06764c8ebf87a80737dc0a6198a013799f18e32 (patch) | |
tree | 88a26db295be4d1b2d97fabb50105ad046aa67a2 /git-am.sh | |
parent | 20c3fe762105a29150fd21e3e0a340bca7890848 (diff) | |
download | git-e06764c8ebf87a80737dc0a6198a013799f18e32.tar.gz git-e06764c8ebf87a80737dc0a6198a013799f18e32.tar.xz |
am --abort: support aborting to unborn branch
When git-am is first run on an unborn branch, no ORIG_HEAD is created.
As such, any applied commits will remain even after a git am --abort.
To be consistent with the behavior of git am --abort when it is not run
from an unborn branch, we empty the index, and then destroy the branch
pointed to by HEAD if there is no ORIG_HEAD.
Signed-off-by: Paul Tan <pyokagan@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'git-am.sh')
-rwxr-xr-x | git-am.sh | 9 |
1 files changed, 8 insertions, 1 deletions
@@ -514,7 +514,14 @@ then index_tree=$(git write-tree) && orig_head=$(git rev-parse --verify -q ORIG_HEAD || echo $empty_tree) && git read-tree -m -u $index_tree $orig_head - git reset ORIG_HEAD + if git rev-parse --verify -q ORIG_HEAD >/dev/null 2>&1 + then + git reset ORIG_HEAD + else + git read-tree $empty_tree + curr_branch=$(git symbolic-ref HEAD 2>/dev/null) && + git update-ref -d $curr_branch + fi fi rm -fr "$dotest" exit ;; |