blob: bc23356483eca834a7f412a6e76af69c04057ee4 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
|
#compdef pass
# This file is under the GPLv2+ license.
# Heavily based on http://zsh.sf.net/Guide/zshguide06.html#l177
# And Frédéric Perrin article http://tar-jx.bz/notes/zsh-completion.html
# Johan Venant, September 2012
_pass () {
local cmd
if (( CURRENT > 2)); then
cmd=${words[2]}
# Set the context for the subcommand.
curcontext="${curcontext%:*:*}:pass-$cmd"
# Narrow the range of words we are looking at to exclude `pass'
(( CURRENT-- ))
shift words
# Run the completion for the subcommand
(( $+functions[_pass_cmd_$cmd] )) && _pass_cmd_$cmd
else
_values : \
"init[Initialize new password storage]" \
"ls[subfolder List names of passwords]" \
"show[Decrypt and print a password]" \
"insert[Insert a new password]" \
"generate[Generate a new password using pwgen]" \
"rm[Remove the password]" \
"push[push the latest changes using git-push(1)]" \
"pull[pull the latest changes using git-pull(1)]" \
"git[Call git]" \
"help[Help]"
fi
}
_pass_cmd_init () {
}
_pass_cmd_ls () {
_arguments : \
'::ls:_get_stored_pwd'
}
_pass_cmd_show () {
_arguments : \
"-c[put it on the clipboard]" \
'*::show:_get_stored_pwd'
#'::pass id:_files -W ~/.password-store -g "*.gpg(|.*)(-.)"'
}
_pass_cmd_insert () {
_arguments : \
"-n[no console output]" \
"-m[multiline]" \
'::show:_get_stored_pwd'
}
_pass_cmd_generate () {
_arguments : \
"-n[no symbols]" \
"-c[put password on the clipboard]" \
'::show:_get_stored_pwd'
}
_pass_cmd_rm () {
_arguments : \
'::ls:_get_stored_pwd'
}
_get_stored_pwd () {
compadd `find ~/.password-store \( -name .git -o -name .gpg-id \) -prune -o -print | sed 's#.*/.password-store/\?##' | sed 's#\.gpg##' | sort`
}
|