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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
|
#compdef -value-,PROMPT,-default- -value-,PROMPT2,-default- -value-,PROMPT3,-default- -value-,PROMPT4,-default- -value-,RPROMPT,-default- -value-,RPROMPT2,-default- -value-,PS1,-default- -value-,PS2,-default- -value-,PS3,-default- -value-,PS4,-default- -value-,RPS1,-default- -value-,RPS2,-default- -value-,SPROMPT,-default-
local -a specs
local expl grp cols bs suf pre changed=1 ret=1
local -A ansi
if [[ -z $compstate[quote] ]]; then
bs='\' # in patterns we use (\\|) widely as print -P handles backslashes first
fi
# first strip off any complete prompt specifications leaving only the
# current, incomplete, one
while (( changed )); do
changed=0
compset -P '%[DFK](\\|){[^}]#}' && changed=1 # formats with arg: %x{...}
compset -P '%[0-9-\\]#[^DFK(0-9-<>\\\[]' && changed=1 # normal formats
compset -P '%[0-9-\\]#(<[^<]#<|>[^>]#>|\[[^\]]#\])' && changed=1 # truncations
compset -P '%[0-9-\\]#(\\|)\([0-9]#[^0-9]?|[^%]' && changed=1 # start of ternary
compset -P '[^%]##' && changed=1 # sundry other characters
# %D/%F/%K without a following { ... }
[[ $PREFIX = %(-|)<->#[DFK](\\|)[^{\\]* ]] &&
compset -P '%[0-9\\-]#[DFK]' && changed=1
done
[[ $PREFIX = %(-|)<->[FK](#e) ]] && compset -P '*' # F/K with number
if compset -P '%[FK]'; then
# this should use -P but that somehow causes single quotes to be stripped
compset -P '(\\|){' || pre=( -p '{' )
compset -S '(\\|)}*' || suf=( -S "$bs}" )
ansi=(
black 30
red 31
green 32
yellow 33
blue 34
magenta 35
cyan 36
white 37
default 39
)
_description -V ansi-colors expl 'ansi color'
grp="$expl[expl[(i)-V]+1]"
_comp_colors+=( ${(ps.\0.)"$(printf "($grp)=%s=%s\0" ${(kv)ansi})"} )
compadd "$expl[@]" $suf $pre -k ansi && ret=0
if (( $#suf )) && compset -P "(<->|%v)"; then
_wanted ansi-colors expl 'closing brace' compadd -S '' \} && ret=0
elif (( $+terminfo[colors] )); then
(( cols = $terminfo[colors] - 1 ))
(( cols = cols > 255 ? 255 : cols ))
_description -V terminal-colors expl 'terminal color'
grp="$expl[expl[(i)-V]+1]"
compadd "$expl[@]" $suf $pre {0..$cols}
for c in {0..$cols}; do
_comp_colors+=( "($grp)=${c}=${${$(print -P "%F{$c}")#?\[}%m}" )
done
else
_message -e terminal-colors "number"
fi
fi
if compset -P '%[0-9-\\]#\([0-9]#[^0-9]'; then
compset -S '*'
_delimiters && ret=0
elif compset -P '%[0-9-\\]#[<>\]]'; then
_message -e replacements 'replacement string'
elif compset -P '%[0-9-\\]#(\\|)\([0-9]#'; then
compset -S '[.:+/-%]*' || suf=( -S . )
compset -S '*'
specs=(
'!:running with privileges'
'#:effective uid'
'?:exit status'
'_:at least n shell constructs started'
'C:at least n path elements'
'/:at least n path elements'
'.:at least n path elements'
'c:at least n path elements'
'~:at least n path elements'
'D:month'
'd:day of month'
'g:effective gid'
'j:number of jobs'
'L:SHLVL'
'l:number of characters already printed'
'S:SECONDS parameter at least n'
'T:current hour'
't:current minute'
'v:psvar has at least n elements'
'V:element n of psvar is set and non-empty'
'w:day of week (Sunday = 0)'
)
_describe -t ternary-prompt-expressions 'ternary prompt format test character' specs $suf && ret=0
elif compset -P '%D(\\|){'; then
compset -S '(\\|)}*'
_date_formats zsh && ret=0
elif [[ -prefix '%' ]] ||
! zstyle -t ":completion:${curcontext}:prompt-format-specifiers" prefix-needed
then
specs=(
'm:hostname up to first .'
'_:status of parser'
'^:reversed status of parser'
'd:current working directory'
'/:current working directory'
'~:current working directory, with ~ replacement'
'N:name of current script or shell function'
'x:name of file containing code being executed'
'c:deprecated'
'.:deprecated'
'C:deprecated'
'F:start using fg color'
'K:start using bg color'
'G:counts as extra character inside %{...%}'
'(:ternary expression %(x.true-string.false-string)'
)
compset -P '%' || pre=( -p '%' )
if ! compset -P '(-|)<->'; then
if [[ $service == -value-,SPROMPT,* ]]; then
specs+=(
'r:suggested correction'
'R:corrected string'
)
fi
specs+=(
'%:A %'
'):A )'
'l:current line (tty) with /dev/tty stripped'
'M:full hostname'
'n:username'
'y:current line (tty)'
'#:a # when root, % otherwise'
'?:return status of last command'
'h:current history event number'
'!:current history event number'
'i:current line number'
'I:current source line number'
'j:number of jobs'
'L:$SHLVL'
'D:date in yy-mm-dd format'
'T:current time of day, 24-hour format'
't:current time of day, 12-hour am/pm format'
'@:current time of day, 12-hour am/pm format'
'*:current time of day, 24-hour format with seconds'
'w:the date in day-dd format'
'W:the date in mm/dd/yy format'
'D{:format string like strftime'
'B:start bold'
'b:stop bold'
'E:clear to end of line'
'U:start underline'
'u:stop underline'
'S:start standout'
's:stop standout'
'f:reset fg color'
'k:reset bg color'
'{:start literal escape sequence'
'}:stop literal escape sequence'
'v:value from $psvar array'
'<:truncation from left %len<string<'
'>:truncation from right %len>string>'
'[:truncation from who knows where'
)
fi
_describe -t prompt-format-specifiers 'prompt format specifier' \
specs -S '' $pre && ret=0
(( ! $#pre )) && [[ -prefix '(-|)<->' ]] &&
_message -e prompt-format-specifiers number
fi
return ret
|