about summary refs log tree commit diff
path: root/Completion/Base/Completer
diff options
context:
space:
mode:
authorSven Wischnowsky <wischnow@users.sourceforge.net>2001-04-02 11:07:45 +0000
committerSven Wischnowsky <wischnow@users.sourceforge.net>2001-04-02 11:07:45 +0000
commit0aa7811fb7c50d015eba37bd317f592b96415e08 (patch)
treea0c232ac2e41335a4479707e266d9decc895fb94 /Completion/Base/Completer
parentfaf058e4bcecb8d0301e817d5e7bf0d719299f9b (diff)
downloadzsh-0aa7811fb7c50d015eba37bd317f592b96415e08.tar.gz
zsh-0aa7811fb7c50d015eba37bd317f592b96415e08.tar.xz
zsh-0aa7811fb7c50d015eba37bd317f592b96415e08.zip
moved from Completion/Core/_list
Diffstat (limited to 'Completion/Base/Completer')
-rw-r--r--Completion/Base/Completer/_list37
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