Browse Source

Merge branch 'jk/stash-options'

Make "git stash something --help" error out, so that users can
safely say "git stash drop --help".

* jk/stash-options:
  stash: recognize "--help" for subcommands
  stash: complain about unknown flags
maint
Junio C Hamano 10 years ago
parent
commit
f693bb0bb0
  1. 17
      git-stash.sh
  2. 4
      t/t3903-stash.sh

17
git-stash.sh

@ -219,6 +219,9 @@ save_stash () {
-a|--all) -a|--all)
untracked=all untracked=all
;; ;;
--help)
show_help
;;
--) --)
shift shift
break break
@ -301,11 +304,17 @@ list_stash () {
} }


show_stash () { show_stash () {
ALLOW_UNKNOWN_FLAGS=t
assert_stash_like "$@" assert_stash_like "$@"


git diff ${FLAGS:---stat} $b_commit $w_commit git diff ${FLAGS:---stat} $b_commit $w_commit
} }


show_help () {
exec git help stash
exit 1
}

# #
# Parses the remaining options looking for flags and # Parses the remaining options looking for flags and
# at most one revision defaulting to ${ref_stash}@{0} # at most one revision defaulting to ${ref_stash}@{0}
@ -332,13 +341,14 @@ show_stash () {
# #
# GIT_QUIET is set to t if -q is specified # GIT_QUIET is set to t if -q is specified
# INDEX_OPTION is set to --index if --index is specified. # INDEX_OPTION is set to --index if --index is specified.
# FLAGS is set to the remaining flags # FLAGS is set to the remaining flags (if allowed)
# #
# dies if: # dies if:
# * too many revisions specified # * too many revisions specified
# * no revision is specified and there is no stash stack # * no revision is specified and there is no stash stack
# * a revision is specified which cannot be resolve to a SHA1 # * a revision is specified which cannot be resolve to a SHA1
# * a non-existent stash reference is specified # * a non-existent stash reference is specified
# * unknown flags were set and ALLOW_UNKNOWN_FLAGS is not "t"
# #


parse_flags_and_rev() parse_flags_and_rev()
@ -371,7 +381,12 @@ parse_flags_and_rev()
--index) --index)
INDEX_OPTION=--index INDEX_OPTION=--index
;; ;;
--help)
show_help
;;
-*) -*)
test "$ALLOW_UNKNOWN_FLAGS" = t ||
die "$(eval_gettext "unknown option: \$opt")"
FLAGS="${FLAGS}${FLAGS:+ }$opt" FLAGS="${FLAGS}${FLAGS:+ }$opt"
;; ;;
esac esac

4
t/t3903-stash.sh

@ -100,6 +100,10 @@ test_expect_success 'unstashing in a subdirectory' '
) )
' '


test_expect_success 'stash drop complains of extra options' '
test_must_fail git stash drop --foo
'

test_expect_success 'drop top stash' ' test_expect_success 'drop top stash' '
git reset --hard && git reset --hard &&
git stash list > stashlist1 && git stash list > stashlist1 &&

Loading…
Cancel
Save