Merge branch 'nielsdg/update-bash-completion' into 'main'

Integrate external extended bash-completion script

Closes #103

See merge request GNOME/libsecret!161
This commit is contained in:
Niels De Graef 2025-01-26 17:23:44 +00:00
commit 37d3912f25

View File

@ -1,19 +1,50 @@
# secret-tool(1) completion # bash completion for secret-tool(1) -*- shell-script -*-
_secret-tool() _comp_cmd_secret_tool()
{ {
local cur prev word cword local cur prev words cword was_split comp_args
_init_completion || return _comp_initialize -s -- "$@" || return
if [[ $cur == -* ]]; then [[ $was_split ]] && return
local opts="--help --verbose -q --quiet"
COMPREPLY=( $(compgen -W "$opts" -- "$cur") ) local -i i
return local mode="" has_mode="" word
elif [[ $cword -eq 1 ]]; then for i in ${!words[*]}; do
local commands='store lookup clear search' if [[ $i -gt 0 && ${words[i]} != -* ]]; then
COMPREPLY=( $(compgen -W "$commands" -- "$cur") ) ((i != cword)) && mode=${words[i]} has_mode=set
break
fi fi
done
if [[ ! $has_mode ]]; then
# generate modes
_comp_compgen_split -- "$("$1" nonexistent-mode 2>&1 |
while read -r first second third rest; do
if [[ $first == "${1##*/}" ]]; then
printf "%s\n" "$second"
elif [[ $first == usage: && $second == "${1##*/}" ]]; then
printf "%s\n" "$third"
fi
done)"
return
fi
case $mode in
store)
if [[ ${words[*]} != *\ --label[\ =]* ]]; then
_comp_compgen -- -W "--label="
[[ ${COMPREPLY-} == *= ]] && compopt -o nospace
fi
;;
search)
local -A opts=([--all]="" [--unlock]="")
for word in "${words[@]:2}"; do
[[ $word ]] && unset -v 'opts[$word]'
done
((${#opts[@]})) &&
_comp_compgen -- -W '"${!opts[@]}"'
;;
esac
} && } &&
complete -F _secret-tool secret-tool complete -F _comp_cmd_secret_tool secret-tool
# ex: filetype=sh # ex: filetype=sh