mirror of
git://git.code.sf.net/p/zsh/code
synced 2025-10-07 09:21:18 +02:00
manual/8070
This commit is contained in:
parent
e6367b89ad
commit
c600fcce08
1 changed files with 107 additions and 23 deletions
|
@ -1,31 +1,115 @@
|
||||||
#compdef -k complete-word \e/
|
#compdef -k complete-word \e/ \e,
|
||||||
|
#
|
||||||
|
# Complete words from the history
|
||||||
|
#
|
||||||
|
# by Adam Spiers, with help gratefully received from
|
||||||
|
# Sven Wischnowsky and Bart Schaefer
|
||||||
|
#
|
||||||
|
# Available configuration keys:
|
||||||
|
#
|
||||||
|
# history_list -- display lists of available matches
|
||||||
|
# history_stop -- prevent looping at beginning and end of matches
|
||||||
|
# during menu-completion
|
||||||
|
# history_sort -- sort matches lexically (default is to sort by age)
|
||||||
|
# history_remove_all_dups --
|
||||||
|
# remove /all/ duplicate matches rather than just
|
||||||
|
# consecutives
|
||||||
|
#
|
||||||
|
|
||||||
local expl
|
_history_complete_word () {
|
||||||
|
local expl direction
|
||||||
|
|
||||||
if [[ -n "$compstate[old_list]" && -n "$compconfig[history_stop]" ]]; then
|
case "$KEYS" in
|
||||||
if [[ -z "$_hist_menu_end" &&
|
',') direction='newer'
|
||||||
compstate[old_insert] -lt _hist_menu_length ]]; then
|
;;
|
||||||
compstate[old_list]=keep
|
'/') direction='older'
|
||||||
compstate[insert]=$((compstate[old_insert]+1))
|
;;
|
||||||
|
*) print <<EOF
|
||||||
|
The keypress \`$KEYS\' was not understood by _history_complete_word.
|
||||||
|
You must alter _history_complete_word if you want to bind it to keys
|
||||||
|
other than the defaults, so that it knows which direction the key
|
||||||
|
should move in the history.
|
||||||
|
EOF
|
||||||
|
return 1
|
||||||
|
esac
|
||||||
|
|
||||||
|
[[ -z "$compconfig[history_list]" ]] && compstate[list]=''
|
||||||
|
|
||||||
|
if [[ -n "$compstate[old_list]" &&
|
||||||
|
( -n "$compconfig[history_stop]" || "$compstate[insert]" = menu ) ]]; then
|
||||||
|
# array of matches is newest -> oldest (reverse of history order)
|
||||||
|
if [[ "$direction" == 'older' ]]; then
|
||||||
|
if [[ compstate[old_insert] -eq $_hist_menu_length ||
|
||||||
|
"$_hist_stop" == 'oldest' ]]; then
|
||||||
|
_hist_stop='oldest'
|
||||||
|
[[ "$compconfig[history_stop]" = verbose ]] &&
|
||||||
|
_message 'beginning of history reached'
|
||||||
|
elif [[ "$_hist_stop" == 'newest' ]]; then
|
||||||
|
zle -Rc
|
||||||
|
_history_complete_word_gen_matches
|
||||||
|
else
|
||||||
|
compstate[old_list]=keep
|
||||||
|
(( compstate[insert] = compstate[old_insert] + 1 ))
|
||||||
|
fi
|
||||||
|
elif [[ "$direction" == 'newer' ]]; then
|
||||||
|
if [[ compstate[old_insert] -eq 1 || "$_hist_stop" == 'newest' ]]; then
|
||||||
|
_hist_stop='newest'
|
||||||
|
[[ "$compconfig[history_stop]" = verbose ]] &&
|
||||||
|
_message 'end of history reached'
|
||||||
|
elif [[ "$_hist_stop" == 'oldest' ]]; then
|
||||||
|
zle -Rc
|
||||||
|
_history_complete_word_gen_matches
|
||||||
|
else
|
||||||
|
compstate[old_list]=keep
|
||||||
|
(( compstate[insert] = compstate[old_insert] - 1 ))
|
||||||
|
fi
|
||||||
|
fi
|
||||||
else
|
else
|
||||||
_hist_menu_end=yes
|
_hist_stop=''
|
||||||
if [[ "$compconfig[history_stop]" = verbose ]]; then
|
_hist_old_prefix="$PREFIX"
|
||||||
_message 'end of history reached'
|
_history_complete_word_gen_matches
|
||||||
|
fi
|
||||||
|
|
||||||
|
[[ -n "$compstate[nmatches]" ]]
|
||||||
|
}
|
||||||
|
|
||||||
|
_history_complete_word_gen_matches () {
|
||||||
|
if [[ -n "$compconfig[history_list]" ]]; then
|
||||||
|
if [[ -n "$compconfig[history_sort]" ]]; then
|
||||||
|
_description expl 'history word'
|
||||||
else
|
else
|
||||||
compstate[old_list]=keep
|
_description -V expl 'history word'
|
||||||
compstate[insert]=_hist_menu_length
|
fi
|
||||||
|
else
|
||||||
|
if [[ -n "$compconfig[history_sort]" ]]; then
|
||||||
|
expl=()
|
||||||
|
else
|
||||||
|
expl=('-V' '')
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
else
|
|
||||||
if [[ -n "$compconfig[history_sort]" ]]; then
|
[[ -n "$_hist_stop" ]] && PREFIX="$_hist_old_prefix"
|
||||||
_description expl 'history word'
|
|
||||||
|
local rem_dups
|
||||||
|
if [[ -n "$compconfig[history_remove_all_dups]" ]]; then
|
||||||
|
rem_dups=''
|
||||||
else
|
else
|
||||||
_description -V expl 'history word'
|
rem_dups='-1'
|
||||||
fi
|
fi
|
||||||
compgen "$expl[@]" -Q -H 0 ''
|
|
||||||
if [[ -n "$compconfig[history_stop]" ]]; then
|
compgen "$expl[@]" $rem_dups -Q -H 0 ''
|
||||||
compstate[insert]=1
|
_hist_menu_length="$compstate[nmatches]"
|
||||||
_hist_menu_length="$compstate[nmatches]"
|
|
||||||
_hist_menu_end=''
|
case "$direction" in
|
||||||
fi
|
newer) compstate[insert]=$_hist_menu_length
|
||||||
fi
|
[[ -n "$_hist_stop" ]] && (( compstate[insert]-- ))
|
||||||
|
;;
|
||||||
|
older) compstate[insert]=1
|
||||||
|
[[ -n "$_hist_stop" ]] && (( compstate[insert]++ ))
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
[[ -n "$_hist_stop" ]] && _hist_stop=''
|
||||||
|
}
|
||||||
|
|
||||||
|
_history_complete_word "$@"
|
||||||
|
|
Loading…
Reference in a new issue