summaryrefslogtreecommitdiff
path: root/Completion/Zsh/Function
diff options
context:
space:
mode:
authorAxel Beckert <abe@deuxchevaux.org>2016-12-04 04:32:03 +0100
committerAxel Beckert <abe@deuxchevaux.org>2016-12-04 04:32:03 +0100
commit3e439c3863f14c82f70666804c8570a13b3732e6 (patch)
tree07036c43e0f3f9242bb6dd42cd2a849ec8ea8aca /Completion/Zsh/Function
parent2aedc4b88fd0e87b89583983951b04b96f48efd3 (diff)
parent7b7e84f0815ed22a0ee348a217776529035dccf3 (diff)
downloadzsh-3e439c3863f14c82f70666804c8570a13b3732e6.tar.gz
zsh-3e439c3863f14c82f70666804c8570a13b3732e6.zip
Merge tag 'zsh-5.2-test-1' into debian
Diffstat (limited to 'Completion/Zsh/Function')
-rw-r--r--Completion/Zsh/Function/_add-zle-hook-widget35
-rw-r--r--Completion/Zsh/Function/_add-zsh-hook5
-rw-r--r--Completion/Zsh/Function/_zargs2
3 files changed, 38 insertions, 4 deletions
diff --git a/Completion/Zsh/Function/_add-zle-hook-widget b/Completion/Zsh/Function/_add-zle-hook-widget
new file mode 100644
index 000000000..93954a2bb
--- /dev/null
+++ b/Completion/Zsh/Function/_add-zle-hook-widget
@@ -0,0 +1,35 @@
+#compdef add-zle-hook-widget
+
+_add-zle-hook-widget_types() {
+ local -a tmp
+
+ autoload -U add-zle-hook-widget
+ add-zle-hook-widget -h >&/dev/null # sets the zstyle
+ zstyle -g tmp zle-hook types
+
+ compadd "$@" -M 'L:|=zle-' -M 'r:|-=* r:|=*' -- zle-${^tmp}
+}
+
+_add-zle-hook-widget_widgets() {
+ if (( $+opt_args[-d] )); then
+ local -a tmp
+ zstyle -g tmp $line[1] widgets
+ _wanted widgets expl "installed hook" compadd -- ${tmp#<->:} && return 0
+ else
+ _wanted widgets expl widget _widgets -g 'user:*' && return 0
+ fi
+ return 1
+}
+
+_add-zle-hook-widget() {
+ local context state state_descr line
+ typeset -A opt_args
+ _arguments -s -w -S : \
+ '(-D)-d[remove HOOK from the array]' \
+ '(-d)-D[interpret HOOK as pattern to remove from the array]' \
+ {-U,-z,-k}"[passed to 'autoload']" \
+ ':hook type:_add-zle-hook-widget_types' \
+ ':widget:_add-zle-hook-widget_widgets'
+}
+
+_add-zle-hook-widget "$@"
diff --git a/Completion/Zsh/Function/_add-zsh-hook b/Completion/Zsh/Function/_add-zsh-hook
index c70a4976f..fb5403a60 100644
--- a/Completion/Zsh/Function/_add-zsh-hook
+++ b/Completion/Zsh/Function/_add-zsh-hook
@@ -1,8 +1,5 @@
#compdef add-zsh-hook
-local context state state_descr line
-typeset -A opt_args
-
_add-zsh-hook_hooks() {
if (( $+opt_args[-d] )); then
_wanted functions expl "installed hooks" compadd -a - "$line[1]_functions" && return 0
@@ -13,6 +10,8 @@ _add-zsh-hook_hooks() {
}
_add-zsh-hook() {
+ local context state state_descr line
+ typeset -A opt_args
_arguments -s -w -S : \
'(-D)-d[remove HOOK from the array]' \
'(-d)-D[interpret HOOK as pattern to remove from the array]' \
diff --git a/Completion/Zsh/Function/_zargs b/Completion/Zsh/Function/_zargs
index c24b276f2..f974ab646 100644
--- a/Completion/Zsh/Function/_zargs
+++ b/Completion/Zsh/Function/_zargs
@@ -4,7 +4,7 @@ local arguments eofstr pos=$((CURRENT)) numeofs=0 ret=1 cmdpos=1
#this doesn't handle '--' on the command line, only --
#it also by extension doesn't handle eofstr being the empty string
-#it also also doesn't handle eofstr being -e or --eof, and everything will
+#it also doesn't handle eofstr being -e or --eof, and everything will
# probably also be confused if the command at the end takes a -e, --eof= or --
eofstr=${${${${words[(r)(--eof=*|-e*)]}#--eof=}#-e}:---}
while {