diff options
Diffstat (limited to 'completions/mdtool')
-rw-r--r-- | completions/mdtool | 27 |
1 files changed, 14 insertions, 13 deletions
diff --git a/completions/mdtool b/completions/mdtool index 67a3c7c3..428e33b7 100644 --- a/completions/mdtool +++ b/completions/mdtool @@ -7,17 +7,18 @@ _mdtool() local command i - for (( i=0; i < ${#words[@]}-1; i++ )); do + for ((i = 1; i < ${#words[@]} - 1; i++)); do if [[ ${words[i]} == @(build|generate-makefiles|setup) ]]; then command=${words[i]} + break fi done - if [[ -n "$command" ]]; then + if [[ -v command ]]; then case $command in "build") - COMPREPLY=( $(compgen -W '--f --buildfile --p --project' \ - -S":" -- "$cur") ) + COMPREPLY=($(compgen -W '--f --buildfile --p --project' \ + -S":" -- "$cur")) # TODO: This does not work :( #if [[ "$prev" == *: ]]; then # case $prev in @@ -33,29 +34,29 @@ _mdtool() ;; "generate-makefiles") compopt -o filenames - COMPREPLY=( $(compgen -o filenames -G"*.mds" -- "$cur") ) - if [[ "$prev" == *mds ]]; then - COMPREPLY=( $(compgen -W '--simple-makefiles --s --d:' \ - -- "$cur") ) + COMPREPLY=($(compgen -o filenames -G"*.mds" -- "$cur")) + if [[ $prev == *mds ]]; then + COMPREPLY=($(compgen -W '--simple-makefiles --s --d:' \ + -- "$cur")) fi return ;; "setup") # TODO: at least return filenames after these options. - COMPREPLY=( $(compgen -W 'install i uninstall u check-install + COMPREPLY=($(compgen -W 'install i uninstall u check-install ci update up list l list-av la list-update lu rep-add ra rep-remove rr rep-update ru rep-list rl reg-update reg-build rgu info rep-build rb pack p help h dump-file' \ - -- "$cur") ) + -- "$cur")) return ;; esac fi - COMPREPLY=( $(compgen -W 'gsetup build dbgen project-export - generate-makefiles gettext-update setup -q' -- "$cur") ) + COMPREPLY=($(compgen -W 'gsetup build dbgen project-export + generate-makefiles gettext-update setup -q' -- "$cur")) } && -complete -F _mdtool mdtool + complete -F _mdtool mdtool # ex: filetype=sh |