about summary refs log tree commit diff
path: root/Completion/Builtins/_unhash
diff options
context:
space:
mode:
authorOliver Kiddle <opk@users.sourceforge.net>2000-05-28 19:40:22 +0000
committerOliver Kiddle <opk@users.sourceforge.net>2000-05-28 19:40:22 +0000
commit24695d682feac4c07014e14710cc4af2eb66e029 (patch)
tree168e1967e4057600f14fbe27862a5947c96e05be /Completion/Builtins/_unhash
parent47532f255ef58d9e0e5bd6c909b3a7008e35ee43 (diff)
downloadzsh-24695d682feac4c07014e14710cc4af2eb66e029.tar.gz
zsh-24695d682feac4c07014e14710cc4af2eb66e029.tar.xz
zsh-24695d682feac4c07014e14710cc4af2eb66e029.zip
use of _arguments for completion of a couple more builtins (11615)
Diffstat (limited to 'Completion/Builtins/_unhash')
-rw-r--r--Completion/Builtins/_unhash18
1 files changed, 13 insertions, 5 deletions
diff --git a/Completion/Builtins/_unhash b/Completion/Builtins/_unhash
index fe40c25a2..b99c00ad3 100644
--- a/Completion/Builtins/_unhash
+++ b/Completion/Builtins/_unhash
@@ -1,6 +1,14 @@
-#defcomp unhash
+#compdef unhash
 
-[[ -mword 1 -*d* ]] && complist -n
-[[ -mword 1 -*a* ]] && complist -a
-[[ -mword 1 -*f* ]] && complist -F
-[[ ! -mword 1 -* ]] && complist -m
+local expl state line curcontext="$curcontext"
+
+_arguments -C -s \
+  '(-a -f *)-d[remove named directories]:*:named directory:->nameddir' \
+  '(-d -f *)-a[remove aliases]:*:aliases:_aliases' \
+  '(-d -a *)-f[remove functions]:*:functions:_functions' \
+  '-m[treat arguments as patterns]' \
+  '*:commands:_command_names -e'  && return 0
+
+if [[ "$state" = nameddir ]]; then
+  _wanted nameddir expl 'named directory' compadd - ${(@k)nameddirs}
+fi