Merge pull request #443 from darko-poljak/completions
Implement bash and zsh completions.
This commit is contained in:
commit
565150b6cc
3 changed files with 108 additions and 0 deletions
59
completions/bash/cdist-completion.bash
Normal file
59
completions/bash/cdist-completion.bash
Normal file
|
@ -0,0 +1,59 @@
|
||||||
|
_cdist()
|
||||||
|
{
|
||||||
|
local cur prev prevprev opts cmds projects
|
||||||
|
COMPREPLY=()
|
||||||
|
cur="${COMP_WORDS[COMP_CWORD]}"
|
||||||
|
prev="${COMP_WORDS[COMP_CWORD-1]}"
|
||||||
|
prevprev="${COMP_WORDS[COMP_CWORD-2]}"
|
||||||
|
opts="-h --help -d --debug -v --verbose -V --version"
|
||||||
|
cmds="banner shell config"
|
||||||
|
|
||||||
|
case "${prevprev}" in
|
||||||
|
shell)
|
||||||
|
case "${prev}" in
|
||||||
|
-s|--shell)
|
||||||
|
shells=$(grep -v '^#' /etc/shells)
|
||||||
|
COMPREPLY=( $(compgen -W "${shells}" -- ${cur}) )
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
case "${prev}" in
|
||||||
|
-*)
|
||||||
|
COMPREPLY=( $(compgen -W "${opts}" -- ${cur}) )
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
banner)
|
||||||
|
opts="-h --help -d --debug -v --verbose"
|
||||||
|
COMPREPLY=( $(compgen -W "${opts}" -- ${cur}) )
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
shell)
|
||||||
|
opts="-h --help -d --debug -v --verbose -s --shell"
|
||||||
|
COMPREPLY=( $(compgen -W "${opts}" -- ${cur}) )
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
config)
|
||||||
|
opts="-h --help -d --debug -v --verbose \
|
||||||
|
-c --conf-dir -f --file -i --initial-manifest -n --dry-run \
|
||||||
|
-o --out-dir -p --parallel -s --sequential --remote-copy \
|
||||||
|
--remote-exec"
|
||||||
|
COMPREPLY=( $(compgen -W "${opts}" -- ${cur}) )
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
if [[ ${cur} == -* ]]; then
|
||||||
|
COMPREPLY=( $(compgen -W "${opts}" -- ${cur}) )
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
COMPREPLY=( $(compgen -W "${cmds}" -- ${cur}) )
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
complete -F _cdist cdist
|
48
completions/zsh/_cdist
Normal file
48
completions/zsh/_cdist
Normal file
|
@ -0,0 +1,48 @@
|
||||||
|
#compdef cdist
|
||||||
|
|
||||||
|
_cdist()
|
||||||
|
{
|
||||||
|
local curcontext="$curcontext" state line
|
||||||
|
typeset -A opt_args
|
||||||
|
|
||||||
|
_arguments \
|
||||||
|
'1: :->opts_cmds'\
|
||||||
|
'*: :->opts'
|
||||||
|
|
||||||
|
case $state in
|
||||||
|
opts_cmds)
|
||||||
|
_arguments '1:Options and commands:(banner config shell -h --help -d --debug -v --verbose -V --version)'
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
case $words[2] in
|
||||||
|
-*)
|
||||||
|
opts=(-h --help -d --debug -v --verbose -V --version)
|
||||||
|
compadd "$@" -- $opts
|
||||||
|
;;
|
||||||
|
banner)
|
||||||
|
opts=(-h --help -d --debug -v --verbose)
|
||||||
|
compadd "$@" -- $opts
|
||||||
|
;;
|
||||||
|
shell)
|
||||||
|
case $words[3] in
|
||||||
|
-s|--shell)
|
||||||
|
shells=($(grep -v '^#' /etc/shells))
|
||||||
|
compadd "$@" -- $shells
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
opts=(-h --help -d --debug -v --verbose -s --shell)
|
||||||
|
compadd "$@" -- $opts
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
;;
|
||||||
|
config)
|
||||||
|
opts=(-h --help -d --debug -v --verbose -c --conf-dir -f --file -i --initial-manifest -n --dry-run -o --out-dir -p --parallel -s --sequential --remote-copy --remote-exec)
|
||||||
|
compadd "$@" -- $opts
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
_cdist "$@"
|
|
@ -2,6 +2,7 @@ Changelog
|
||||||
---------
|
---------
|
||||||
|
|
||||||
next:
|
next:
|
||||||
|
* Custom: Add bash and zsh completions (Darko Poljak)
|
||||||
* Core: Improve error reporting for local and remote run command (Darko Poljak)
|
* Core: Improve error reporting for local and remote run command (Darko Poljak)
|
||||||
* New type: __jail_freebsd9: Handle jail management on FreeBSD <= 9.X (Jake Guffey)
|
* New type: __jail_freebsd9: Handle jail management on FreeBSD <= 9.X (Jake Guffey)
|
||||||
* New type: __jail_freebsd10: Handle jail management on FreeBSD >= 10.0 (Jake Guffey)
|
* New type: __jail_freebsd10: Handle jail management on FreeBSD >= 10.0 (Jake Guffey)
|
||||||
|
|
Loading…
Reference in a new issue