diff options
author | Sven Wischnowsky <wischnow@users.sourceforge.net> | 2001-04-02 11:07:45 +0000 |
---|---|---|
committer | Sven Wischnowsky <wischnow@users.sourceforge.net> | 2001-04-02 11:07:45 +0000 |
commit | 0aa7811fb7c50d015eba37bd317f592b96415e08 (patch) | |
tree | a0c232ac2e41335a4479707e266d9decc895fb94 | |
parent | faf058e4bcecb8d0301e817d5e7bf0d719299f9b (diff) | |
download | zsh-0aa7811fb7c50d015eba37bd317f592b96415e08.tar.gz zsh-0aa7811fb7c50d015eba37bd317f592b96415e08.tar.xz zsh-0aa7811fb7c50d015eba37bd317f592b96415e08.zip |
moved from Completion/Core/_list
-rw-r--r-- | Completion/Base/Completer/_list | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/Completion/Base/Completer/_list b/Completion/Base/Completer/_list new file mode 100644 index 000000000..a9aa46dfc --- /dev/null +++ b/Completion/Base/Completer/_list @@ -0,0 +1,37 @@ +#autoload + +# This completer function makes the other completer functions used +# insert possible completions only after the list has been shown at +# least once. + +[[ _matcher_num -gt 1 ]] && return 1 + +local pre suf expr + +# Get the strings to compare. + +if zstyle -t ":completion:${curcontext}:" word; then + pre="$HISTNO$LBUFFER" + suf="$RBUFFER" +else + pre="$PREFIX" + suf="$SUFFIX" +fi + +# Should we only show a list now? + +if zstyle -T ":completion:${curcontext}:" condition && + [[ "$pre" != "$_list_prefix" || "$suf" != "$_list_suffix" ]]; then + + # Yes. Tell the completion code about it and save the new values + # to compare the next time. + + compstate[insert]='' + compstate[list]='list force' + _list_prefix="$pre" + _list_suffix="$suf" +fi + +# We always return one, because we don't really do any work here. + +return 1 |