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
This commit is contained in:
commit
f693bb0bb0
17
git-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
|
||||||
|
@ -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…
Reference in New Issue
Block a user