diff options
author | Junio C Hamano <gitster@pobox.com> | 2014-04-21 19:42:45 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2014-04-21 19:42:46 +0200 |
commit | 0b17b4331087224883878e49342037bf69717b62 (patch) | |
tree | 36812666a6ea99efc7455c7437a5e560f3803d46 /git-rebase--interactive.sh | |
parent | Merge branch 'ep/shell-command-substitution' (diff) | |
parent | Revert "rebase: fix run_specific_rebase's use of "return" on FreeBSD" (diff) | |
download | git-0b17b4331087224883878e49342037bf69717b62.tar.xz git-0b17b4331087224883878e49342037bf69717b62.zip |
Merge branch 'km/avoid-non-function-return-in-rebase'
Work around /bin/sh that does not like "return" at the top-level
of a file that is dot-sourced from inside a function definition.
* km/avoid-non-function-return-in-rebase:
Revert "rebase: fix run_specific_rebase's use of "return" on FreeBSD"
rebase: avoid non-function use of "return" on FreeBSD
Diffstat (limited to 'git-rebase--interactive.sh')
-rw-r--r-- | git-rebase--interactive.sh | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/git-rebase--interactive.sh b/git-rebase--interactive.sh index 1c41cbd66c..6ec9d3cb40 100644 --- a/git-rebase--interactive.sh +++ b/git-rebase--interactive.sh @@ -820,6 +820,17 @@ add_exec_commands () { mv "$1.new" "$1" } +# The whole contents of this file is run by dot-sourcing it from +# inside a shell function. It used to be that "return"s we see +# below were not inside any function, and expected to return +# to the function that dot-sourced us. +# +# However, FreeBSD /bin/sh misbehaves on such a construct and +# continues to run the statements that follow such a "return". +# As a work-around, we introduce an extra layer of a function +# here, and immediately call it after defining it. +git_rebase__interactive () { + case "$action" in continue) # do we have anything to commit? @@ -1055,3 +1066,7 @@ GIT_REFLOG_ACTION="$GIT_REFLOG_ACTION: checkout $onto_name" output git checkout $onto || die_abort "could not detach HEAD" git update-ref ORIG_HEAD $orig_head do_rest + +} +# ... and then we call the whole thing. +git_rebase__interactive |