about summary refs log tree commit diff
path: root/Completion/Base
diff options
context:
space:
mode:
Diffstat (limited to 'Completion/Base')
-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