about summary refs log tree commit diff
diff options
context:
space:
mode:
authorSven Wischnowsky <wischnow@users.sourceforge.net>2001-04-02 11:02:44 +0000
committerSven Wischnowsky <wischnow@users.sourceforge.net>2001-04-02 11:02:44 +0000
commitc789f5dbdb5e05a7e47b3cd06f3386dfddb438ca (patch)
tree1874a295b9bf3cc47a0b6a83e5badcf82652676a
parentac5b2891754453bdd617a94c8d70e974def016bd (diff)
downloadzsh-c789f5dbdb5e05a7e47b3cd06f3386dfddb438ca.tar.gz
zsh-c789f5dbdb5e05a7e47b3cd06f3386dfddb438ca.tar.xz
zsh-c789f5dbdb5e05a7e47b3cd06f3386dfddb438ca.zip
moved from Completion/Core/_all_labels
-rw-r--r--Completion/Base/Core/_all_labels43
1 files changed, 43 insertions, 0 deletions
diff --git a/Completion/Base/Core/_all_labels b/Completion/Base/Core/_all_labels
new file mode 100644
index 000000000..8665f5bf3
--- /dev/null
+++ b/Completion/Base/Core/_all_labels
@@ -0,0 +1,43 @@
+#autoload
+
+local __gopt=-J __len __tmp __pre __suf __ret=1 __descr __spec __prev
+
+if [[ "$1" = - ]]; then
+  __prev=-
+  shift
+fi
+
+if [[ "$1" = -([12]|)[VJ] ]]; then
+  __gopt="$1"
+  shift
+fi
+
+__tmp=${argv[(ib:4:)-]}
+__len=$#
+if [[ __tmp -lt __len ]]; then
+  __pre=$(( __tmp-1 ))
+  __suf=$__tmp
+elif [[ __tmp -eq $# ]]; then
+  __pre=-2
+  __suf=$(( __len+1 ))
+else
+  __pre=4
+  __suf=5
+fi
+
+while comptags "-A$__prev" "$1" curtag __spec; do
+  _comp_tags="$_comp_tags $__spec "
+  if [[ "$curtag" = *[^\\]:* ]]; then
+    zformat -f __descr "${curtag#*:}" "d:$3"
+    _description "$__gopt" "${curtag%:*}" "$2" "$__descr"
+    curtag="${curtag%:*}"
+
+    "$4" "${(P@)2}" "${(@)argv[5,-1]}" && __ret=0
+  else
+    _description "$__gopt" "$curtag" "$2" "$3"
+
+    "${(@)argv[4,__pre]}" "${(P@)2}" "${(@)argv[__suf,-1]}" && __ret=0
+  fi
+done
+
+return __ret