1
0
Fork 0
mirror of git://git.code.sf.net/p/zsh/code synced 2025-10-25 17:20:25 +02:00

38965: _svnadmin: Complete 'freeze' as a precommand.

This commit is contained in:
Daniel Shahaf 2016-07-29 17:03:03 +00:00
parent 774f654e36
commit eaaac9c89f
2 changed files with 32 additions and 1 deletions

View file

@ -183,6 +183,9 @@ _svn () {
_svnadmin () {
local curcontext="$curcontext" state line ret=1
integer NORMARG
local context state_descr
typeset -A opt_args
_arguments -C \
'(-)--help[print help information]' \
@ -214,11 +217,36 @@ _svnadmin () {
)
if [[ $usage == *REPOS_PATH* ]]; then
args+=( ":repository path:_files -/" )
case $cmd in
(freeze)
args+=( "*:arguments:->normal" )
;;
esac
elif [[ $cmd = help ]]; then
args+=( "*:subcommand:_svnadmin_commands" )
fi
_arguments "$args[@]" && ret=0
_arguments -n -s -S : "$args[@]" && ret=0
case $state in
# Test cases:
# svnadmin freeze . rsync --<TAB> offers --file
# svnadmin freeze -- . rsync -<TAB> offers rsync's options
#
# Note: the NORMARG calculations here include one positional argument
# (the '.') before the command.
(normal)
if (( ${words[(i)--]} < CURRENT )); then
words[1,NORMARG]=()
(( CURRENT -= NORMARG ))
_normal && ret=0
elif (( NORMARG+1 == CURRENT )); then
# ### don't allow --options in this case
# TODO: this should just use '_normal -F "(-*)"', but _normal ignores its arguments.
_command_names -e && ret=0
fi
;;
esac
else
_message "unknown svnadmin command: $words[1]"
fi