#autoload
local expl disp jobs job jids pfx='%' desc how expls sep
if [[ "$1" = -t ]]; then
zstyle -T ":completion:${curcontext}:jobs" prefix-needed &&
[[ "$PREFIX" != %* && compstate[nmatches] -ne 0 ]] && return 1
shift
fi
zstyle -t ":completion:${curcontext}:jobs" prefix-hidden && pfx=''
zstyle -T ":completion:${curcontext}:jobs" verbose && desc=yes
if [[ "$1" = -r ]]; then
jids=( "${(@k)jobstates[(R)running*]}" )
shift
expls='running job'
elif [[ "$1" = -s ]]; then
jids=( "${(@k)jobstates[(R)suspended*]}" )
shift
expls='suspended job'
else
[[ "$1" = - ]] && shift
jids=( "${(@k)jobtexts}" )
expls=job
fi
if [[ -n "$desc" ]]; then
disp=()
zstyle -s ":completion:${curcontext}:jobs" list-separator sep || sep=--
for job in "$jids[@]"; do
[[ -n "$desc" ]] &&
disp=( "$disp[@]" "${pfx}${(r:2:: :)job} $sep ${(r:COLUMNS-8:: :)jobtexts[$job]}" )
done
fi
zstyle -s ":completion:${curcontext}:jobs" numbers how
if [[ "$how" = (yes|true|on|1) ]]; then
jobs=( "$jids[@]" )
else
local texts i text str tmp num max=0
# Find shortest unambiguous strings.
texts=( "$jobtexts[@]" )
jobs=()
for i in "$jids[@]"; do
text="$jobtexts[$i]"
str="${text%% *}"
if [[ "$text" = *\ * ]]; then
text="${text#* }"
else
text=""
fi
tmp=( "${(@M)texts:#${str}*}" )
num=1
while [[ -n "$text" && $#tmp -ge 2 ]]; do
str="${str} ${text%% *}"
if [[ "$text" = *\ * ]]; then
text="${text#* }"
else
text=""
fi
tmp=( "${(@M)texts:#${str}*}" )
(( num++ ))
done
[[ num -gt max ]] && max="$num"
jobs=( "$jobs[@]" "$str" )
done
if [[ "$how" = [0-9]## && max -gt how ]]; then
jobs=( "$jids[@]" )
else
[[ -z "$pfx" && -n "$desc" ]] && disp=( "${(@)disp#%}" )
fi
fi
if [[ -n "$desc" ]]; then
_wanted jobs expl "$expls" compadd "$@" -ld disp - "%$^jobs[@]"
else
_wanted jobs expl "$expls" compadd "$@" - "%$^jobs[@]"
fi
Copyright 2K16 - 2K18 Indonesian Hacker Rulez