From 90bbd87734053303751d401a807be8a7fe3b9176 Mon Sep 17 00:00:00 2001 From: Sven Wischnowsky Date: Mon, 7 Jan 2002 14:38:13 +0000 Subject: fixes for completion of signal names with SIG prefix and for completing command names instead of pids (16406) --- Completion/Unix/Type/_signals | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) (limited to 'Completion/Unix/Type') diff --git a/Completion/Unix/Type/_signals b/Completion/Unix/Type/_signals index 32cb8285c..5723f4f9c 100644 --- a/Completion/Unix/Type/_signals +++ b/Completion/Unix/Type/_signals @@ -4,12 +4,13 @@ # # -a use all signals (even the pseudo-signals) # -p needs a `-' prefix +# -s SIG prefix allowed # # A `-' or `--' as the first argument is ignored. -local expl last minus +local expl last minus pre sigs -zparseopts -D -K -E 'p=minus' 'a=last' +zparseopts -D -K -E 'p=minus' 'a=last' 's=pre' if [[ -z "$last" ]]; then last=-1 else @@ -24,14 +25,21 @@ if [[ -z "$minus" ]] || [[ -prefix -* ]]; then local disp tmp - [[ -prefix ${minus}SIG* ]] && minus+=SIG if zstyle -t ":completion:${curcontext}:signals" prefix-hidden; then tmp=( "${(@)signals[1,last]}" ) disp=(-d tmp) else disp=() fi + + if [[ -n "$pre" && $PREFIX = ${minus}S* ]]; then + sigs=( "${minus}SIG${(@)^signals[1,last]}" ) + (( $#disp )) && tmp=( "$tmp[@]" "${(@)signals[1,last]}" ) + else + sigs=() + fi + _wanted signals expl signal \ compadd "$@" "$disp[@]" -M 'm:{a-z}={A-Z}' - \ - "${minus}${(@)^signals[1,last]}" + "${minus}${(@)^signals[1,last]}" "$sigs[@]" fi -- cgit 1.4.1