commit 34b0a3ba7ff1932977672e12ad728441cf859aab parent b947ef162265060fc79933403968f0fa8d37e214 Author: Brian Mattern <rephorm@rephorm.com> Date: Fri, 21 Sep 2012 14:41:16 -0700 Better gpg key completion for `pass init` Diffstat:
M | contrib/pass.bash-completion | | | 17 | +++++++++++++++-- |
1 file changed, 15 insertions(+), 2 deletions(-)
diff --git a/contrib/pass.bash-completion b/contrib/pass.bash-completion @@ -33,6 +33,20 @@ _pass_complete_entries () { done } +_pass_complete_keys () { + local IFS=$'\n' + # Extract names and email addresses from gpg --list-keys + keys="$(gpg --list-keys | grep uid | sed -e 's/uid *\([^<]*\)\(<\(.*\)>\)\?/\1\n\3/' | sed -e 's/\(^ *\| *$\)//g')" + matches="$(compgen -W "${keys}" -- ${cur})" + local l=${#cur} + for key in ${matches}; do + key="$(printf "%q" "${key}")" + if [[ $l -eq 0 || "${key:0:$l}" == "${cur}" ]]; then + COMPREPLY+=("$key") + fi + done +} + _pass() { local cur prev opts base @@ -46,8 +60,7 @@ _pass() case "${COMP_WORDS[1]}" in init) COMPREPLY+=($(compgen -W "-e --reencrypt" -- ${cur})) - keys=$(gpg --list-keys |grep uid |sed 's/.*<\(.*\)>/\1/') - COMPREPLY+=($(compgen -W "${keys}" -- ${cur})) + _pass_complete_keys ;; ls|list) _pass_complete_entries