From fcffaf214966be45ca78fecc6aaa5fae0b42d05a Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Mon, 17 Jun 2024 11:07:14 +0200 Subject: Adding upstream version 0.16.7.2. Signed-off-by: Daniel Baumann --- auto-completion/bash/.gita-completion.bash | 45 ++++++++++++++++++++++++++++++ 1 file changed, 45 insertions(+) create mode 100644 auto-completion/bash/.gita-completion.bash (limited to 'auto-completion/bash/.gita-completion.bash') diff --git a/auto-completion/bash/.gita-completion.bash b/auto-completion/bash/.gita-completion.bash new file mode 100644 index 0000000..cad120c --- /dev/null +++ b/auto-completion/bash/.gita-completion.bash @@ -0,0 +1,45 @@ + +_gita_completions() +{ + + local cur commands repos cmd + local IFS=$'\n\t ' + + cur=${COMP_WORDS[COMP_CWORD]} + cmd=${COMP_WORDS[1]} + + + # this doesn't work for two repos with the same basename + #gita_path=${XDG_CONFIG_HOME:-$HOME/.config}/gita/repo_path + #repos=`awk '{split($0, paths, ":")} END {for (i in paths) {n=split(paths[i],b, /\//); print b[n]}}' ${gita_path}` + + if [ $COMP_CWORD -eq 1 ]; then + # FIXME: this is somewhat slow + commands=`gita -h | sed '2q;d' |sed 's/[{}.,]/ /g'` + COMPREPLY=($(compgen -W "${commands}" ${cur})) + elif [ $COMP_CWORD -gt 1 ]; then + case $cmd in + add) + COMPREPLY=($(compgen -d ${cur})) + ;; + clone) + COMPREPLY=($(compgen -f ${cur})) + ;; + color | flags) + COMPREPLY=($(compgen -W "ll set" ${cur})) + ;; + ll | context) + groups=`gita group ls` + COMPREPLY=($(compgen -W "${groups}" ${cur})) + return + ;; + *) + repos=`gita ls` + COMPREPLY=($(compgen -W "${repos}" ${cur})) + ;; + esac + fi +} + +complete -F _gita_completions gita + -- cgit v1.2.3