diff options
Diffstat (limited to 'Completion')
-rw-r--r-- | Completion/Base/.distfiles | 6 | ||||
-rwxr-xr-x | Completion/Base/_in_vared | 28 | ||||
-rw-r--r-- | Completion/Core/_compalso | 16 | ||||
-rw-r--r-- | Completion/Core/_complete | 16 | ||||
-rw-r--r-- | Completion/Core/_main_complete | 6 |
5 files changed, 46 insertions, 26 deletions
diff --git a/Completion/Base/.distfiles b/Completion/Base/.distfiles index 377a56c82..b447accf4 100644 --- a/Completion/Base/.distfiles +++ b/Completion/Base/.distfiles @@ -1,7 +1,7 @@ DISTFILES_SRC=' .distfiles _arg_compile _argument_sets _arguments _brace_parameter _combination - _command_names _condition _default _describe _equal _first _jobs _math - _parameter _precommand _redirect _regex_arguments _subscript _tilde - _value _values + _command_names _condition _default _describe _equal _first _in_vared + _jobs _math _parameter _precommand _redirect _regex_arguments _subscript + _tilde _value _values ' diff --git a/Completion/Base/_in_vared b/Completion/Base/_in_vared new file mode 100755 index 000000000..4d8e814db --- /dev/null +++ b/Completion/Base/_in_vared @@ -0,0 +1,28 @@ +#compdef -vared- + +local also + +# Completion inside vared. + +if [[ $compstate[vared] = *\[* ]]; then + # vared on an array-element + compstate[parameter]=${compstate[vared]%%\[*} + compstate[context]=-value- + also=value +else + # vared on a parameter, let's see if it is an array + compstate[parameter]=$compstate[vared] + if [[ ${(tP)compstate[vared]} = *(array|assoc)* ]]; then + compstate[context]=array_value + also=-array-value- + else + compstate[context]=value + also=-value- + fi +fi + +# Don't insert TAB in first column. Never. + +compstate[insert]="${compstate[insert]//tab /}" + +_compalso "$also" diff --git a/Completion/Core/_compalso b/Completion/Core/_compalso index 23a40e2d0..8df6b4a6f 100644 --- a/Completion/Core/_compalso +++ b/Completion/Core/_compalso @@ -1,13 +1,17 @@ #autoload -# This searches $1 in the array for normal completions and calls the result. +# This searches $* in the array for normal completions and calls the result. # It is used to include completions for another command or special context # into the list generated by the calling function. # For example the function for `-subscript-' could call this as in -# `_compalso -math- "$@"' to get the completions that would be generated -# for a mathematical context. +# `_compalso -math-' to get the completions that would be generated for a +# mathematical context. -local tmp +local i tmp ret=1 -tmp="$_comps[$1]" -[[ -z "$tmp" ]] || "$tmp" "$@" +for i; do + tmp="$_comps[$1]" + [[ -z "$tmp" ]] || "$tmp" && ret=0 +done + +return ret diff --git a/Completion/Core/_complete b/Completion/Core/_complete index e50f73b2e..83b918135 100644 --- a/Completion/Core/_complete +++ b/Completion/Core/_complete @@ -36,21 +36,7 @@ fi # If we are inside `vared' and we don't have a $compcontext, we treat # this like a parameter assignment. Which it is. -if [[ -n $compstate[vared] ]]; then - if [[ $compstate[vared] = *\[* ]]; then - # vared on an array-element - compstate[parameter]=${compstate[vared]%%\[*} - compstate[context]=value - else - # vared on a parameter, let's see if it is an array - compstate[parameter]=$compstate[vared] - if [[ ${(tP)compstate[vared]} = *(array|assoc)* ]]; then - compstate[context]=array_value - else - compstate[context]=value - fi - fi -fi +[[ -n $compstate[vared] ]] && compstate[context]=vared # For arguments and command names we use the `_normal' function. diff --git a/Completion/Core/_main_complete b/Completion/Core/_main_complete index 1b1fdd0e6..34566d2d4 100644 --- a/Completion/Core/_main_complete +++ b/Completion/Core/_main_complete @@ -35,8 +35,10 @@ typeset -U _lastdescr _comp_ignore [[ -z "$curcontext" ]] && curcontext=::: -if [[ "$compstate[insert]" = tab* ]]; then - zstyle -T ":completion:${curcontext}:" insert-tab && return 1 +if [[ "$compstate[insert]" = tab* && "$WIDGET" != *list* ]]; then + { zstyle -T ":completion:${curcontext}:" insert-tab && + { [[ "$curcontext" != :* || -z "$compstate[vared]" ]] || + zstyle -t ":completion:vared${curcontext}:" insert-tab } } && return 1 compstate[insert]="${compstate[insert]//tab /}" fi |