From 0aa7811fb7c50d015eba37bd317f592b96415e08 Mon Sep 17 00:00:00 2001 From: Sven Wischnowsky Date: Mon, 2 Apr 2001 11:07:45 +0000 Subject: [PATCH] moved from Completion/Core/_list --- Completion/Base/Completer/_list | 37 +++++++++++++++++++++++++++++++++ 1 file changed, 37 insertions(+) create mode 100644 Completion/Base/Completer/_list 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