about summary refs log tree commit diff
path: root/Completion
diff options
context:
space:
mode:
authorMikael Magnusson <mikachu@gmail.com>2012-03-24 22:49:20 +0000
committerMikael Magnusson <mikachu@gmail.com>2012-03-24 22:49:20 +0000
commit511fc6e367e886fda47569acafc8f82ba1265546 (patch)
tree7349b1f3c8066c3a480c54dba1762954f1481216 /Completion
parent9db18318288d7a413885fb5d1618bf239b6ed182 (diff)
downloadzsh-511fc6e367e886fda47569acafc8f82ba1265546.tar.gz
zsh-511fc6e367e886fda47569acafc8f82ba1265546.tar.xz
zsh-511fc6e367e886fda47569acafc8f82ba1265546.zip
30368: _tmux: complete arguments to unambiguous partial subcommands
Diffstat (limited to 'Completion')
-rw-r--r--Completion/Unix/Command/_tmux12
1 files changed, 12 insertions, 0 deletions
diff --git a/Completion/Unix/Command/_tmux b/Completion/Unix/Command/_tmux
index 3327b1462..39befe884 100644
--- a/Completion/Unix/Command/_tmux
+++ b/Completion/Unix/Command/_tmux
@@ -1528,6 +1528,18 @@ function _tmux() {
             if [[ -n ${_tmux_aliasmap[$tmuxcommand]} ]] ; then
                 tmuxcommand="${_tmux_aliasmap[$tmuxcommand]}"
             fi
+            if ! (( ${+functions[_tmux-$tmuxcommand]} )); then
+              local low high
+              low=$_tmux_commands[(i)$tmuxcommand*]
+              high=$_tmux_commands[(I)$tmuxcommand*]
+              if (( low == high )); then
+                tmuxcommand=${_tmux_commands[low]%%:*}
+              elif (( low < high )); then
+                _message -e "Ambiguous command $tmuxcommand"
+              else
+                _message -e "Subcommand $tmuxcommand not known"
+              fi
+            fi
             curcontext="${curcontext%:*:*}:tmux-${tmuxcommand}:"
             _call_function ret _tmux-${tmuxcommand}
         fi