Commit 03fcffb3 authored by Nico Schottelius's avatar Nico Schottelius

Merge pull request #22 from darko-poljak/completions

Implement bash and zsh completions.
parents c0eeb5a4 3079ab36
_ctt()
{
local cur prev opts cmds projects
COMPREPLY=()
cur="${COMP_WORDS[COMP_CWORD]}"
prev="${COMP_WORDS[COMP_CWORD-1]}"
opts="-h --help -d --debug -v --verbose"
cmds="listprojects track report"
case "${prev}" in
track|report)
if [[ -d ~/.ctt ]]; then
projects=$(ls ~/.ctt)
else
projects=""
fi
;;
esac
case "${prev}" in
-*|listprojects)
COMPREPLY=( $(compgen -W "${opts}" -- ${cur}) )
return 0
;;
track)
opts="-h --help -d --debug -v --verbose --sd --start --ed --end -n --no-comment"
COMPREPLY=( $(compgen -W "${opts} ${projects}" -- ${cur}) )
return 0
;;
report)
opts="-h --help -d --debug -v --verbose --sd --start --ed --end -a --all -e --regexp -i --ignore-case -f -format -s --summary"
COMPREPLY=( $(compgen -W "${opts} ${projects}" -- ${cur}) )
return 0
;;
*)
;;
esac
if [[ ${cur} == -* ]]; then
COMPREPLY=( $(compgen -W "${opts}" -- ${cur}) )
return 0
fi
COMPREPLY=( $(compgen -W "${cmds}" -- ${cur}) )
return 0
}
complete -F _ctt ctt
#compdef ctt
_ctt()
{
local curcontext="$curcontext" state line
typeset -A opt_args
_arguments \
'1: :->opts_cmds'\
'*: :->opts'
case $state in
opts_cmds)
_arguments '1:Options and commands:(listprojects track report -h --help -d --debug -v --verbose)'
;;
*)
case $words[2] in
track|report)
projects=($(ls ~/.ctt))
;;
esac
case $words[2] in
listprojects|-*)
opts=(-h --help -d --debug -v --verbose)
compadd "$@" -- $opts
;;
track)
opts=(-h --help -d --debug -v --verbose --sd --start --ed --end -n --no-comment)
compadd "$@" -- $opts $projects
;;
report)
opts=(-h --help -d --debug -v --verbose --sd --start --ed --end -a --all -e --regexp -i --ignore-case -f -format -s --summary)
compadd "$@" -- $opts $projects
;;
*)
;;
esac
esac
}
_ctt "$@"
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment