From e6e2c7f3f809e4b6a4055593118105c90b142d03 Mon Sep 17 00:00:00 2001 From: Clint Adams Date: Sat, 5 Dec 2009 17:38:23 +0000 Subject: Frank Terbeck: 27458: set-option -w completion. --- Completion/Unix/Command/_tmux | 52 +++++++++++++++++++++++-------------------- 1 file changed, 28 insertions(+), 24 deletions(-) (limited to 'Completion/Unix/Command') diff --git a/Completion/Unix/Command/_tmux b/Completion/Unix/Command/_tmux index 481a34bf9..60092ae88 100644 --- a/Completion/Unix/Command/_tmux +++ b/Completion/Unix/Command/_tmux @@ -837,27 +837,19 @@ function _tmux-set-environment() { function _tmux-set-option() { [[ -n ${tmux_describe} ]] && print "Set a session option" && return + local mode local -a args args=( '-a[Append to string options]' '-g[Set a global session option]' '-u[Unset a non-global option]' + '-w[Change window (not session) options]' '-t[Choose a target session]:target session:__tmux-sessions' '*:: :->name_or_value' ) + __tmux-got-option-already -w && mode=window || mode=session _arguments -C ${args} - - case ${state} in - name_or_value) - if (( CURRENT == 1 )); then - __tmux-options - elif (( CURRENT == 2 )); then - __tmux-option-guard 'session' ${words[1]} - else - __tmux-nothing-else - fi - ;; - esac + __tmux-options-complete ${mode} ${state} } function _tmux-set-window-option() { @@ -871,18 +863,7 @@ function _tmux-set-window-option() { '*:: :->name_or_value' ) _arguments -C ${args} - - case ${state} in - name_or_value) - if (( CURRENT == 1 )); then - __tmux-window-options - elif (( CURRENT == 2 )); then - __tmux-option-guard 'window' ${words[1]} - else - __tmux-nothing-else - fi - ;; - esac + __tmux-options-complete window ${state} } function _tmux-show-buffer() { @@ -1133,6 +1114,11 @@ function __tmux-get-optarg() { done } +function __tmux-got-option-already() { + [[ -n ${(M)words:#$1} ]] && return 0 + return 1 +} + function __tmux-key-tables() { local expl local -a tables @@ -1326,6 +1312,24 @@ function __tmux-options() { _describe -t tmux-options 'tmux option' tmux_options } +function __tmux-options-complete() { + local mode="$1" state="$2" + + case ${state} in + name_or_value) + if (( CURRENT == 1 )) && [[ ${mode} == 'session' ]]; then + __tmux-options + elif (( CURRENT == 1 )) && [[ ${mode} == 'window' ]]; then + __tmux-window-options + elif (( CURRENT == 2 )); then + __tmux-option-guard ${mode} ${words[1]} + else + __tmux-nothing-else + fi + ;; + esac +} + function __tmux-panes() { local expl line local -i num -- cgit 1.4.1