#compdef svn svnadmin svnadmin-static=svnadmin _svn () { _arguments -s \ '(-)--help[print help information]' \ '(- *)--version[print client version information]' \ '*::svn command:_svn_command' } _svnadmin () { _arguments -s \ '(-)--help[print help information]' \ '(- *)--version[print client version information]' \ '*::svnadmin command:_svnadmin_command' } (( $+functions[_svn_controlled] )) || _svn_controlled() { [[ -f ${(M)REPLY##*/}.svn/text-base/${REPLY##*/}.svn-base ]] } (( $+functions[_svn_urls] )) || _svn_urls() { local expl if [[ -prefix *: ]]; then _urls else compset -S '[^:]*' _wanted url-schemas expl 'URL schema' compadd -S '' - \ file:// http:// https:// svn:// svn+ssh:// fi } (( $+functions[_svn_command] )) || _svn_command () { local cmd if (( ! $+_svn_cmds )); then typeset -gA _svn_cmds _svn_cmds=( ${=${(f)${${"$(_call_program commands svn help)"#l#*Available subcommands:}%%Subversion is a tool*}}/(#s)[[:space:]]#(#b)([a-z]##)[[:space:]]#(\([a-z, ?]##\))#/$match[1] :$match[1]${match[2]:+:${${match[2]//[(),]}// /:}}:} ) fi if (( CURRENT == 1 )); then _tags commands && { compadd "$@" -k _svn_cmds || compadd "$@" ${(s.:.)_svn_cmds} } else local curcontext="$curcontext" cmd="${${(k)_svn_cmds[(R)*:$words[1]:*]}:-${(k)_svn_cmds[(i):$words[1]:]}}" if (( $#cmd )); then curcontext="${curcontext%:*:*}:svn-${cmd}:" _svn_subcommand $cmd else _message "unknown svn command: $words[1]" fi fi } (( $+functions[_svn_subcommand] )) || _svn_subcommand () { local subcmd _svn_subcmds _svn_subcmd_usage _svn_subcmd_usage=${${(M)${(f)"$(_call_program options svn help $1)"}:#usage:*}#usage: $1 } _svn_subcmds=( ${${=${${${(M)${(f)"$(_call_program options svn help $1)"##*Valid options:}:#*:*}%% #:*}/ arg/:arg:}/(#b)-([[:alpha:]]) \[--([a-z-]##)\](:arg:)#/(--$match[2])-$match[1]$match[3] (-$match[1])--$match[2]$match[3]}[2,-1]} ) case $1 in; add) _svn_subcmds=( $_svn_subcmds '*:file:_files -g "*(^e:_svn_controlled:)"' ) ;; log) _svn_subcmds=( $_svn_subcmds '1: : _alternative "files:file:_files -g \*\(e:_svn_controlled:\)" "urls:url:_svn_urls"' '*:file:_files -g "*(e:_svn_controlled:)"' ) ;; *) case $_svn_subcmd_usage in *(TARGET|URL*PATH)*) _svn_subcmds=( $_svn_subcmds '*: : _alternative "files:file:_files" "urls:url:_svn_urls"' ) ;; *URL*) _svn_subcmds=( $_svn_subcmds ':url:_svn_urls' ) ;; *PATH*) _svn_subcmds=( $_svn_subcmds '*:file:_files' ) ;; esac ;; esac _arguments "$_svn_subcmds[@]" && ret=0 return ret } (( $+functions[_svnadmin_command] )) || _svnadmin_command () { local cmd if (( ! $+_svnadmin_cmds )); then typeset -gA _svnadmin_cmds _svnadmin_cmds=( ${=${(f)${${"$(_call_program commands svnadmin help)"#l#*Available subcommands:}}}/(#s)[[:space:]]#(#b)([a-z]##)[[:space:]]#(\([a-z, ?]##\))#/$match[1] :$match[1]${match[2]:+:${${match[2]//[(),]}// /:}}:} ) fi if (( CURRENT == 1 )); then _tags commands && { compadd "$@" -k _svnadmin_cmds || compadd "$@" ${(s.:.)_svnadmin_cmds} } else local curcontext="$curcontext" cmd="${${(k)_svnadmin_cmds[(R)*:$words[1]:*]}:-${(k)_svnadmin_cmds[(i):$words[1]:]}}" if (( $#cmd )); then curcontext="${curcontext%:*:*}:svnadmin-${cmd}:" _svnadmin_subcommand $cmd else _message "unknown svnadmin command: $words[1]" fi fi } (( $+functions[_svnadmin_subcommand] )) || _svnadmin_subcommand () { local subcmd _svnadmin_subcmds _svnadmin_subcmd_usage _svnadmin_subcmd_usage=${${(M)${(f)"$(_call_program options svnadmin help $1)"}:#$1: usage:*}#$1: usage: svnadmin $1 } _svnadmin_subcmds=( ${${=${${${(M)${(f)"$(_call_program options svnadmin help $1)"##*Valid options:}:#*:*}%% #:*}/ arg/:arg:}/(#b)-([[:alpha:]]) \[--([a-z-]##)\](:arg:)#/(--$match[2])-$match[1]$match[3] (-$match[1])--$match[2]$match[3]}[2,-1]} ) [[ "$_svnadmin_subcmd_usage" == *REPOS_PATH* ]] && _svnadmin_subcmds=($_svnadmin_subcmds ":path:_files -/") _arguments "$_svnadmin_subcmds[@]" && ret=0 return ret } _subversion () { case $service in (svn) _svn "$@" ;; (svnadmin) _svnadmin "$@" ;; esac } _subversion "$@"