summaryrefslogtreecommitdiffstats
path: root/completions/gpg
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--completions/gpg47
-rw-r--r--completions/gpg239
-rw-r--r--completions/gpgv27
3 files changed, 67 insertions, 46 deletions
diff --git a/completions/gpg b/completions/gpg
index f0ca884..ca0d8e0 100644
--- a/completions/gpg
+++ b/completions/gpg
@@ -1,38 +1,53 @@
# bash completion for gpg -*- shell-script -*-
-_gpg()
+_comp_cmd_gpg()
{
- local cur prev words cword
- _init_completion || return
+ local cur prev words cword comp_args
+ _comp_initialize -- "$@" || return
+ local noargopts='!(-*|*[skKr]*)'
+ # shellcheck disable=SC2254
case $prev in
- --sign | --clearsign | --decrypt-files | --load-extension | -!(-*)s)
- _filedir
+ --sign | --clear-sign | --clearsign | --decrypt-files | \
+ --load-extension | -${noargopts}s)
+ _comp_compgen_filedir
return
;;
- --export | --sign-key | --lsign-key | --nrsign-key | --nrlsign-key | --edit-key)
+ --list-keys | --list-public-keys | --locate-keys | \
+ --locate-external-keys | --fingerprint | --delete-keys | \
+ --delete-secret-and-public-keys | --export | --refresh-keys | \
+ --search-keys | --edit-key | --sign-key | --lsign-key | \
+ --nrsign-key | --nrlsign-key | --try-secret-key | -${noargopts}k)
# return list of public keys
- COMPREPLY=($(compgen -W "$($1 --list-keys 2>/dev/null | command sed -ne \
- 's@^pub.*/\([^ ]*\).*$@\1@p' -ne \
- 's@^.*\(<\([^>]*\)>\).*$@\2@p')" -- "$cur"))
+ _comp_compgen_split -- "$("$1" --list-keys 2>/dev/null |
+ command sed -ne \
+ 's@^pub.*/\([^ ]*\).*$@\1@p' -ne \
+ 's@^.*\(<\([^>]*\)>\).*$@\2@p')"
return
;;
- --recipient | -!(-*)r)
- COMPREPLY=($(compgen -W "$($1 --list-keys 2>/dev/null | command sed -ne \
- 's@^.*<\([^>]*\)>.*$@\1@p')" -- "$cur"))
+ --list-secret-keys | --delete-secret-keys | --export-secret-keys | \
+ --export-secret-subkeys | -${noargopts}K)
+ # return list of secret keys
+ _comp_compgen_split -- "$("$1" --list-secret-keys 2>/dev/null |
+ command sed -ne 's@^.*<\([^>]*\)>.*$@\1@p')"
+ return
+ ;;
+ --recipient | -${noargopts}r)
+ _comp_compgen_split -- "$("$1" --list-keys 2>/dev/null |
+ command sed -ne 's@^.*<\([^>]*\)>.*$@\1@p')"
if [[ -e ~/.gnupg/gpg.conf ]]; then
- COMPREPLY+=($(compgen -W "$(command sed -ne \
+ _comp_compgen -a split -- "$(command sed -ne \
's@^[ \t]*group[ \t][ \t]*\([^=]*\).*$@\1@p' \
- ~/.gnupg/gpg.conf)" -- "$cur"))
+ ~/.gnupg/gpg.conf)"
fi
return
;;
esac
if [[ $cur == -* ]]; then
- COMPREPLY=($(compgen -W '$($1 --dump-options)' -- "$cur"))
+ _comp_compgen_split -- "$("$1" --dump-options)"
fi
} &&
- complete -F _gpg -o default gpg
+ complete -F _comp_cmd_gpg -o default gpg
# ex: filetype=sh
diff --git a/completions/gpg2 b/completions/gpg2
index cfa4023..fc54ff9 100644
--- a/completions/gpg2
+++ b/completions/gpg2
@@ -1,42 +1,47 @@
# gpg2(1) completion -*- shell-script -*-
-_gpg2()
+_comp_cmd_gpg2()
{
- local cur prev words cword
- _init_completion || return
+ local cur prev words cword comp_args
+ _comp_initialize -- "$@" || return
+ local noargopts='!(-*|*[sr]*)'
+ # shellcheck disable=SC2254
case $prev in
--homedir)
- _filedir -d
+ _comp_compgen_filedir -d
return
;;
- --sign | --clearsign | --options | --decrypt | -!(-*)s)
- _filedir
+ --sign | --clearsign | --options | --decrypt | -${noargopts}s)
+ _comp_compgen_filedir
return
;;
- --export | --sign-key | --lsign-key | --nrsign-key | --nrlsign-key | --edit-key)
+ --export | --sign-key | --lsign-key | --nrsign-key | --nrlsign-key | \
+ --edit-key | --delete-keys | --delete-secret-and-public-keys | \
+ --locate-keys | --refresh-keys)
# return list of public keys
- COMPREPLY=($(compgen -W "$($1 --list-keys 2>/dev/null | command sed -ne \
- 's@^pub.*/\([^ ]*\).*$@\1@p' -ne \
- 's@^.*\(<\([^>]*\)>\).*$@\2@p')" -- "$cur"))
+ _comp_compgen_split -- "$("$1" --list-keys 2>/dev/null |
+ command sed -ne \
+ 's@^pub.*/\([^ ]*\).*$@\1@p' -ne \
+ 's@^.*\(<\([^>]*\)>\).*$@\2@p')"
return
;;
- --recipient | -!(-*)r)
- COMPREPLY=($(compgen -W "$($1 --list-keys 2>/dev/null |
- command sed -ne 's@^.*<\([^>]*\)>.*$@\1@p')" -- "$cur"))
+ --recipient | -${noargopts}r)
+ _comp_compgen_split -- "$("$1" --list-keys 2>/dev/null |
+ command sed -ne 's@^.*<\([^>]*\)>.*$@\1@p')"
if [[ -e ~/.gnupg/gpg.conf ]]; then
- COMPREPLY+=($(compgen -W "$(command sed -ne \
+ _comp_compgen -a split -- "$(command sed -ne \
's@^[ \t]*group[ \t][ \t]*\([^=]*\).*$@\1@p' \
- ~/.gnupg/gpg.conf)" -- "$cur"))
+ ~/.gnupg/gpg.conf)"
fi
return
;;
esac
if [[ $cur == -* ]]; then
- COMPREPLY=($(compgen -W '$($1 --dump-options)' -- "$cur"))
+ _comp_compgen_split -- "$("$1" --dump-options)"
fi
} &&
- complete -F _gpg2 -o default gpg2
+ complete -F _comp_cmd_gpg2 -o default gpg2
# ex: filetype=sh
diff --git a/completions/gpgv b/completions/gpgv
index 29315c9..7609a33 100644
--- a/completions/gpgv
+++ b/completions/gpgv
@@ -1,29 +1,30 @@
# gpgv(1) completion -*- shell-script -*-
-_gpgv()
+_comp_cmd_gpgv()
{
- local cur prev words cword
- _init_completion || return
+ local cur prev words cword comp_args
+ _comp_initialize -- "$@" || return
case $prev in
--help | --version | --weak-digest | --*-fd | -!(-*)[?h]*)
return
;;
--keyring)
- _filedir "@(gpg|kbx)"
+ _comp_compgen_filedir "@(gpg|kbx)"
return
;;
--homedir)
- _filedir -d
+ _comp_compgen_filedir -d
return
;;
esac
- local args
- _count_args "" "--@(weak-digest|*-fd|keyring|homedir)"
+ local REPLY
+ _comp_count_args -a "--@(weak-digest|*-fd|keyring|homedir)"
+ local args=$REPLY
if [[ $cur == -* && $args -eq 1 ]]; then
- COMPREPLY=($(compgen -W '$(_parse_help "$1")' -- "$cur"))
+ _comp_compgen_help
return
fi
@@ -31,16 +32,16 @@ _gpgv()
if [[ ${COMP_LINE,,} == *.@(asc|sig|sign)\ * ]]; then
# Detached signature, only complete one arbitrary file arg and -
if ((args == 2)); then
- COMPREPLY=($(compgen -W '-' -- "$cur"))
- _filedir
+ _comp_compgen -- -W '-'
+ _comp_compgen -a filedir
fi
else
- _filedir gpg
+ _comp_compgen_filedir gpg
fi
else
- _filedir "@(asc|gpg|sig|sign)"
+ _comp_compgen_filedir "@(asc|gpg|sig|sign)"
fi
} &&
- complete -F _gpgv gpgv gpgv2
+ complete -F _comp_cmd_gpgv gpgv gpgv2
# ex: filetype=sh