From 2e1bb72c072193bbd5c32a32aaad2cb942656ee8 Mon Sep 17 00:00:00 2001 From: Eric Cook Date: Thu, 18 Jun 2015 22:41:47 +0200 Subject: 35490: silence errors and avoid blank match due to missing local --- Completion/Zsh/Type/_file_descriptors | 29 +++++++++++++++++++++-------- 1 file changed, 21 insertions(+), 8 deletions(-) (limited to 'Completion/Zsh/Type/_file_descriptors') diff --git a/Completion/Zsh/Type/_file_descriptors b/Completion/Zsh/Type/_file_descriptors index 3e251b733..0b2cd0015 100644 --- a/Completion/Zsh/Type/_file_descriptors +++ b/Completion/Zsh/Type/_file_descriptors @@ -1,28 +1,41 @@ #autoload -local i fds expl list link sep +local i fds expl link sep +local -a list -fds=( /dev/fd/<0-9>(N:t) ) +fds=( /dev/fd/<3->(N:t) ) if zstyle -T ":completion:${curcontext}:" verbose && [[ -h /proc/$$/fd/$fds[1] ]]; then zstyle -s ":completion:${curcontext}:" list-separator sep || sep=-- - if zmodload -F zsh/stat b:zstat; then for i in "${fds[@]}"; do - zstat +link -A link /proc/$$/fd/$i - list+=( "$i $sep ${link[1]}" ) + if zstat +link -A link /proc/$$/fd/$i; then + list+=( "$i $sep ${link[1]}" ) + else + fds[(i)$i]=() + fi done elif (( $+commands[readlink] )); then for i in "${fds[@]}"; do - list+=( "$i $sep $(readlink /proc/$$/fd/$i)" ) + if link=$(readlink /proc/$$/fd/$i); then + list+=( "$i $sep $link" ) + else + fds[(i)$i]=() + fi done else for i in "${fds[@]}"; do - list+=( "$i $sep $(ls -l /proc/$$/fd/$i|sed 's/.*-> //' )" ) + if link=$(ls -l /proc/$$/fd/$i); then + list+=( "$i $sep ${link#* -> }" ) + else + fds[(i)$i]=() + fi done - fi + fi 2>/dev/null if (( $list[(I)* $sep ?*] )); then + list=( "0 $sep standard input" "1 $sep standard output" "2 $sep standard error" $list ) + fds=( 0 1 2 $fds ) _wanted file-descriptors expl 'file descriptor' compadd "$@" -d list -a - fds return fi -- cgit 1.4.1