summaryrefslogtreecommitdiff
path: root/Completion/Unix/Command/_fuser
diff options
context:
space:
mode:
authorOliver Kiddle <opk@users.sourceforge.net>2005-04-01 19:49:21 +0000
committerOliver Kiddle <opk@users.sourceforge.net>2005-04-01 19:49:21 +0000
commit5a67b1323e987de9c15cca521fdc7682b8a4553b (patch)
tree8a317e0c086db176098243923e9418680c52dfe6 /Completion/Unix/Command/_fuser
parente75966d3c77116216ac21471b580e09907b56b97 (diff)
downloadzsh-5a67b1323e987de9c15cca521fdc7682b8a4553b.tar.gz
zsh-5a67b1323e987de9c15cca521fdc7682b8a4553b.zip
21081: complete network services for the psmisc version of fuser
Diffstat (limited to 'Completion/Unix/Command/_fuser')
-rw-r--r--Completion/Unix/Command/_fuser75
1 files changed, 50 insertions, 25 deletions
diff --git a/Completion/Unix/Command/_fuser b/Completion/Unix/Command/_fuser
index 5252839c5..6c291473f 100644
--- a/Completion/Unix/Command/_fuser
+++ b/Completion/Unix/Command/_fuser
@@ -1,42 +1,67 @@
#compdef fuser
local -a args arg1
+typeset -A opt_args
+
+if _pick_variant -c $words[1] psmisc=psmisc unix -V; then
+
+ (( $+functions[_fuser_services] )) ||
+ _fuser_services() {
+ local expl suf ret=1
+
+ [[ $opt_args[-n] = ??p || $EUID = 0 ]] || return
+
+ if compset -P '*/'; then
+ _wanted protocols expl protocol compadd tcp udp
+ elif compset -P '*,*,'; then
+ compset -S '/*' || [[ -n $opt_args[-n] ]] || suf=( -qS / )
+ _ports $suf && ret=0
+ elif compset -P '*,'; then
+ compset -S ',*' || suf=( -S , -r "/ \t\n\-" )
+ _hosts $suf && ret=0
+ else
+ compset -S ',*' || suf=( -S ${${opt_args[-n]/?*/,}:-/} -r "/, \t\n\-" )
+ _ports $suf && ret=0
+ fi
+
+ return ret
+ }
-if _pick_variant -c $words[1] gnu=GNU unix -V; then
_arguments \
- '(-s)-a[show all files specified on the command line]' \
- {-c,-m}'[list all processes accessing files on the filesystem specified by name]' \
- '-k[kill processes accessing the file]' \
- '-i[ask for confirmation before killing]' \
- '-l[list all known signal names]' \
- '-n[select name space]:namespace:(file udp tcp)' \
- '(-a)-s[silent operation]' \
- '-signal[send alternate signal with -k]:signal:_signals' \
- '-u[append the user name of the process owner to each PID]' \
- '-v[verbose mode]' \
- '-V[display version information]' \
- '-4[search only for IPv4 sockets]' \
- '-6[search only for IPv6 sockets]' \
- ':name:_files'
+ '(-s)-a[show all files specified on the command line]' \
+ {-c,-m}'[list all processes accessing files on the filesystem specified by name]' \
+ '-k[kill processes accessing the file]' \
+ '-i[ask for confirmation before killing]' \
+ '-l[list all known signal names]' \
+ '-n[select name space]:namespace:(file udp tcp)' \
+ '(-a)-s[silent operation]' \
+ '-signal[send alternate signal with -k]:signal:_signals' \
+ '-u[append the user name of the process owner to each PID]' \
+ '-v[verbose mode]' \
+ '-V[display version information]' \
+ '-4[search only for IPv4 sockets]' \
+ '-6[search only for IPv6 sockets]' \
+ '*:name: _alternative "files:file:_files" "services:service:_fuser_services"'
+
else
case $OSTYPE in
solaris2.9 )
args=(
- '-n[list only processes with non-blocking mandatory locks]'
- '-s[send alternate signal with -k]:signal:_signals'
+ '-n[list only processes with non-blocking mandatory locks]'
+ '-s[send alternate signal with -k]:signal:_signals'
)
;;
sysv4 )
- (( $+words[(r)-k] )) && arg1=( ':signal: _alternative signals\:signal\:_signals\ -p files:name:_files' )
+ (( $+words[(r)-k] )) && arg1=( ':name: _alternative signals\:signal\:_signals\ -p files:file:_files' )
;;
esac
_arguments \
- '(-f)-c[list all processes accessing files on the filesystem specified by name]' \
- '(-c)-f[list all processes accessing named files]' \
- '-k[kill processes accessing the file]' \
- '-u[append the user name of the process owner to each PID]' \
- $args \
- $arg1 \
- '*:name:_files'
+ '(-f)-c[list all processes accessing files on the filesystem specified by name]' \
+ '(-c)-f[list all processes accessing named files]' \
+ '-k[kill processes accessing the file]' \
+ '-u[append the user name of the process owner to each PID]' \
+ $args \
+ $arg1 \
+ '*:file:_files'
fi