2020-02-12 18:15:12 +08:00
if [ [ $__p9k_sourced != 6 ] ] ; then
2020-01-27 16:33:01 +08:00
>& 2 print -P ""
>& 2 print -P "[%F{1}ERROR%f]: Corrupted powerlevel10k installation."
>& 2 print -P ""
if ( ( ${ +functions[antigen] } ) ) ; then
>& 2 print -P "If using %Bantigen%b, run the folowing command to fix:"
>& 2 print -P ""
>& 2 print -P " %F{2}antigen%f reset"
if [ [ -d ~/.antigen ] ] ; then
>& 2 print -P ""
>& 2 print -P "If it doesn't help, try this:"
>& 2 print -P ""
>& 2 print -P " %F{2}rm%f -rf %U~/.antigen%u"
fi
else
>& 2 print -P "Try resetting cache in your plugin manager or"
>& 2 print -P "reinstalling powerlevel10k from scratch."
fi
>& 2 print -P ""
return 1
fi
2019-11-29 18:21:34 +08:00
if ! autoload -Uz is-at-least || ! is-at-least 5.1; then
2019-06-01 23:54:53 +08:00
( ) {
>& 2 echo -E " You are using ZSH version $ZSH_VERSION . The minimum required version for Powerlevel10k is 5.1. "
>& 2 echo -E "Type 'echo \$ZSH_VERSION' to see your current zsh version."
local def = ${ SHELL : c : A }
local cur = ${ ${ ZSH_ARGZERO #- } : c : A }
2019-07-29 20:18:57 +08:00
local cur_v = " $( $cur -c 'echo -E $ZSH_VERSION' 2>/dev/null) "
2019-06-01 23:54:53 +08:00
if [ [ $cur_v = = $ZSH_VERSION && $cur != $def ] ] ; then
>& 2 echo -E " The shell you are currently running is likely $cur . "
fi
local other = ${ ${ :- zsh } : c }
2019-07-24 20:34:26 +08:00
if [ [ -n $other ] ] && $other -c 'autoload -Uz is-at-least && is-at-least 5.1' & >/dev/null; then
2019-07-29 20:18:57 +08:00
local other_v = " $( $other -c 'echo -E $ZSH_VERSION' 2>/dev/null) "
2019-06-01 23:54:53 +08:00
if [ [ -n $other_v && $other_v != $ZSH_VERSION ] ] ; then
>& 2 echo -E " You have $other with version $other_v but this is not what you are using. "
if [ [ -n $def && $def != ${ other : A } ] ] ; then
>& 2 echo -E "To change your user shell, type the following command:"
>& 2 echo -E ""
2019-07-29 20:18:57 +08:00
if [ [ " $( grep -F $other /etc/shells 2>/dev/null) " != $other ] ] ; then
2019-06-01 23:54:53 +08:00
>& 2 echo -E " echo ${ (q-)other } | sudo tee -a /etc/shells "
fi
>& 2 echo -E " chsh -s ${ (q-)other } "
fi
fi
fi
}
return 1
fi
2019-07-29 00:54:02 +08:00
source " ${ __p9k_root_dir } /internal/configure.zsh "
2020-01-18 22:41:43 +08:00
source " ${ __p9k_root_dir } /internal/worker.zsh "
2020-01-27 18:11:20 +08:00
source " ${ __p9k_root_dir } /internal/parser.zsh "
2020-02-18 23:11:34 +08:00
source " ${ __p9k_root_dir } /internal/icons.zsh "
2019-07-24 21:06:36 +08:00
2019-07-24 21:01:26 +08:00
# For compatibility with Powerlevel9k. It's not recommended to use mnemonic color
# names in the configuration except for colors 0-7 as these are standard.
typeset -grA __p9k_colors = (
black 000 red 001 green 002 yellow 003
blue 004 magenta 005 cyan 006 white 007
grey 008 maroon 009 lime 010 olive 011
navy 012 fuchsia 013 aqua 014 teal 014
silver 015 grey0 016 navyblue 017 darkblue 018
blue3 020 blue1 021 darkgreen 022 deepskyblue4 025
dodgerblue3 026 dodgerblue2 027 green4 028 springgreen4 029
turquoise4 030 deepskyblue3 032 dodgerblue1 033 darkcyan 036
lightseagreen 037 deepskyblue2 038 deepskyblue1 039 green3 040
springgreen3 041 cyan3 043 darkturquoise 044 turquoise2 045
green1 046 springgreen2 047 springgreen1 048 mediumspringgreen 049
cyan2 050 cyan1 051 purple4 055 purple3 056
blueviolet 057 grey37 059 mediumpurple4 060 slateblue3 062
royalblue1 063 chartreuse4 064 paleturquoise4 066 steelblue 067
steelblue3 068 cornflowerblue 069 darkseagreen4 071 cadetblue 073
skyblue3 074 chartreuse3 076 seagreen3 078 aquamarine3 079
mediumturquoise 080 steelblue1 081 seagreen2 083 seagreen1 085
darkslategray2 087 darkred 088 darkmagenta 091 orange4 094
lightpink4 095 plum4 096 mediumpurple3 098 slateblue1 099
wheat4 101 grey53 102 lightslategrey 103 mediumpurple 104
lightslateblue 105 yellow4 106 darkseagreen 108 lightskyblue3 110
skyblue2 111 chartreuse2 112 palegreen3 114 darkslategray3 116
skyblue1 117 chartreuse1 118 lightgreen 120 aquamarine1 122
darkslategray1 123 deeppink4 125 mediumvioletred 126 darkviolet 128
purple 129 mediumorchid3 133 mediumorchid 134 darkgoldenrod 136
rosybrown 138 grey63 139 mediumpurple2 140 mediumpurple1 141
darkkhaki 143 navajowhite3 144 grey69 145 lightsteelblue3 146
lightsteelblue 147 darkolivegreen3 149 darkseagreen3 150 lightcyan3 152
lightskyblue1 153 greenyellow 154 darkolivegreen2 155 palegreen1 156
darkseagreen2 157 paleturquoise1 159 red3 160 deeppink3 162
magenta3 164 darkorange3 166 indianred 167 hotpink3 168
hotpink2 169 orchid 170 orange3 172 lightsalmon3 173
lightpink3 174 pink3 175 plum3 176 violet 177
gold3 178 lightgoldenrod3 179 tan 180 mistyrose3 181
thistle3 182 plum2 183 yellow3 184 khaki3 185
lightyellow3 187 grey84 188 lightsteelblue1 189 yellow2 190
darkolivegreen1 192 darkseagreen1 193 honeydew2 194 lightcyan1 195
red1 196 deeppink2 197 deeppink1 199 magenta2 200
magenta1 201 orangered1 202 indianred1 204 hotpink 206
mediumorchid1 207 darkorange 208 salmon1 209 lightcoral 210
palevioletred1 211 orchid2 212 orchid1 213 orange1 214
sandybrown 215 lightsalmon1 216 lightpink1 217 pink1 218
plum1 219 gold1 220 lightgoldenrod2 222 navajowhite1 223
mistyrose1 224 thistle1 225 yellow1 226 lightgoldenrod1 227
khaki1 228 wheat1 229 cornsilk1 230 grey100 231
grey3 232 grey7 233 grey11 234 grey15 235
grey19 236 grey23 237 grey27 238 grey30 239
grey35 240 grey39 241 grey42 242 grey46 243
grey50 244 grey54 245 grey58 246 grey62 247
grey66 248 grey70 249 grey74 250 grey78 251
grey82 252 grey85 253 grey89 254 grey93 255)
# For compatibility with Powerlevel9k.
#
# Type `getColorCode background` or `getColorCode foreground` to see the list of predefined colors.
function getColorCode( ) {
2020-02-02 05:03:42 +08:00
eval " $__p9k_intro "
2019-07-24 21:01:26 +08:00
if ( ( ARGC = = 1 ) ) ; then
2019-10-19 13:40:27 +08:00
case $1 in
2019-07-24 21:01:26 +08:00
foreground)
local k
for k in " ${ (k@)__p9k_colors } " ; do
local v = ${ __p9k_colors [ $k ] }
2019-08-05 16:37:04 +08:00
print -rP -- " %F{ $v } $v - $k %f "
2019-07-24 21:01:26 +08:00
done
2019-11-04 16:07:06 +08:00
return 0
2019-07-24 21:01:26 +08:00
; ;
background)
local k
for k in " ${ (k@)__p9k_colors } " ; do
local v = ${ __p9k_colors [ $k ] }
2019-08-05 16:37:04 +08:00
print -rP -- " %K{ $v } $v - $k %k "
2019-07-24 21:01:26 +08:00
done
2019-11-04 16:07:06 +08:00
return 0
2019-07-24 21:01:26 +08:00
; ;
esac
fi
echo "Usage: getColorCode background|foreground" >& 2
return 1
}
# _p9k_declare <type> <uppercase-name> [default]...
function _p9k_declare( ) {
local -i set = $+parameters[ $2 ]
( ( ARGC > 2 || set ) ) || return 0
case $1 in
-b)
if ( ( set ) ) ; then
[ [ ${ (P)2 } = = true ] ] && typeset -gi _$2 = 1 || typeset -gi _$2 = 0
else
typeset -gi _$2 = $3
fi
; ;
-a)
local -a v = ( ${ (P)2 } )
if ( ( set ) ) ; then
eval " typeset -ga _ ${ (q)2 } =( ${ (@qq)v } ) " ;
else
if [ [ $3 != '--' ] ] ; then
echo "internal error in _p9k_declare " " ${ (qqq)@ } " >& 2
fi
eval " typeset -ga _ ${ (q)2 } =( ${ (@qq)*[4,-1] } ) "
fi
; ;
-i)
( ( set ) ) && typeset -gi _$2 = $2 || typeset -gi _$2 = $3
; ;
-F)
( ( set ) ) && typeset -gF _$2 = $2 || typeset -gF _$2 = $3
; ;
-s)
( ( set ) ) && typeset -g _$2 = ${ (P)2 } || typeset -g _$2 = $3
; ;
-e)
if ( ( set ) ) ; then
local v = ${ (P)2 }
typeset -g _$2 = ${ (g : : )v }
else
typeset -g _$2 = ${ (g : : )3 }
fi
; ;
*)
echo "internal error in _p9k_declare " " ${ (qqq)@ } " >& 2
esac
}
2020-01-28 02:23:56 +08:00
function _p9k_read_word( ) {
local -a stat
zstat -A stat +mtime -- $1 2>/dev/null || stat = ( -1)
local cached = $_p9k__read_word_cache [ $1 ]
if [ [ $cached = = $stat [ 1] :* ] ] ; then
2020-02-10 19:59:37 +08:00
_p9k__ret = ${ cached #* : }
2020-01-28 02:23:56 +08:00
else
local rest
2020-02-10 19:59:37 +08:00
_p9k__ret =
{ read _p9k__ret rest <$1 } 2>/dev/null
_p9k__read_word_cache[ $1 ] = $stat [ 1] :$_p9k__ret
2020-01-28 02:23:56 +08:00
fi
2020-02-10 19:59:37 +08:00
[ [ -n $_p9k__ret ] ]
2020-01-28 02:23:56 +08:00
}
2020-01-27 22:04:34 +08:00
function _p9k_fetch_cwd( ) {
_p9k__cwd = ${ (%) :- %/ }
_p9k__cwd_a = ${ _p9k__cwd : A }
case $_p9k__cwd in
~| /)
_p9k__parent_dirs = ( )
_p9k__parent_mtimes = ( )
2020-01-28 18:41:49 +08:00
_p9k__parent_mtimes_i = ( )
_p9k__parent_mtimes_s =
return
2020-01-27 22:04:34 +08:00
; ;
~/*)
local parent = ~/
local parts = ( ${ (s./.)_p9k__cwd# $parent } )
; ;
*)
local parent = /
local parts = ( ${ (s./.)_p9k__cwd } )
; ;
esac
local MATCH
2020-01-28 02:23:56 +08:00
_p9k__parent_dirs = ( ${ (@) ${ :- { $# parts ..1 } } /( #m)*/$parent${(pj./.)parts[1,MATCH]}})
2020-01-27 22:04:34 +08:00
if ! zstat -A _p9k__parent_mtimes +mtime -- $_p9k__parent_dirs 2>/dev/null; then
_p9k__parent_mtimes = ( ${ (@)parts/*/-1 } )
fi
2020-01-28 02:23:56 +08:00
_p9k__parent_mtimes_i = ( ${ (@) ${ :- {1.. $# parts } } /( #m)*/$MATCH:$_p9k__parent_mtimes[MATCH]})
_p9k__parent_mtimes_s = " $_p9k__parent_mtimes_i "
2020-01-27 22:04:34 +08:00
}
# Usage: _p9k_glob parent_dir_index pattern
#
# parent_dir_index indexes _p9k__parent_dirs.
#
2020-01-28 02:23:56 +08:00
# Returns the number of matches.
2020-01-27 22:04:34 +08:00
#
# Pattern cannot have slashes.
#
# Example: _p9k_glob 3 '*.csproj'
function _p9k_glob( ) {
local dir = $_p9k__parent_dirs [ $1 ]
local cached = $_p9k__glob_cache [ $dir /$2 ]
if [ [ $cached = = $_p9k__parent_mtimes [ $1 ] :* ] ] ; then
return ${ cached ##* : }
fi
local -a stat
2020-01-28 02:23:56 +08:00
zstat -A stat +mtime -- $dir 2>/dev/null || stat = ( -1)
2020-01-27 22:04:34 +08:00
local files = ( $dir /$~2( N:t) )
2020-01-28 02:23:56 +08:00
_p9k__glob_cache[ $dir /$2 ] = " $stat [1]: $# files "
return $# files
2020-01-27 22:04:34 +08:00
}
2020-01-28 14:39:47 +08:00
# Usage: _p9k_upglob pattern
2020-01-27 22:04:34 +08:00
#
2020-01-28 02:23:56 +08:00
# Returns index within _p9k__parent_dirs or 0 if there is no match.
2020-01-27 22:04:34 +08:00
#
# Pattern cannot have slashes. Never matches in / or ~. Search stops before reaching / or ~.
#
2020-01-28 14:39:47 +08:00
# Example: _p9k_upglob '*.csproj'
function _p9k_upglob( ) {
2020-01-28 02:23:56 +08:00
local cached = $_p9k__upsearch_cache [ $_p9k__cwd /$1 ]
2020-01-27 22:04:34 +08:00
if [ [ -n $cached ] ] ; then
2020-01-28 02:23:56 +08:00
if [ [ $_p9k__parent_mtimes_s = = ${ cached % * } ( | *) ] ] ; then
return ${ cached ##* }
fi
cached = ( ${ (s : : )cached } )
local last_idx = $cached [ -1]
cached[ -1] = ( )
2020-01-27 22:04:34 +08:00
local -i i
2020-01-28 02:23:56 +08:00
for i in ${ (@) ${ cached : |_p9k__parent_mtimes_i } % : * } ; do
2020-01-27 22:04:34 +08:00
_p9k_glob $i $1 && continue
2020-01-28 02:23:56 +08:00
_p9k__upsearch_cache[ $_p9k__cwd /$1 ] = " ${ _p9k__parent_mtimes_i [1,i] } $i "
return i
2020-01-27 22:04:34 +08:00
done
2020-01-28 02:23:56 +08:00
if ( ( i != last_idx ) ) ; then
_p9k__upsearch_cache[ $_p9k__cwd /$1 ] = " ${ _p9k__parent_mtimes_i [1, $# cached ] } $last_idx "
return last_idx
fi
i = $(( $# cached + 1 ))
else
local -i i = 1
2020-01-27 22:04:34 +08:00
fi
2020-01-28 02:23:56 +08:00
for ( ( ; i <= $# _p9k__parent_mtimes; ++i) ) ; do
_p9k_glob $i $1 && continue
_p9k__upsearch_cache[ $_p9k__cwd /$1 ] = " ${ _p9k__parent_mtimes_i [1,i] } $i "
return i
done
_p9k__upsearch_cache[ $_p9k__cwd /$1 ] = " $_p9k__parent_mtimes_s 0 "
return 0
2020-01-27 22:04:34 +08:00
}
2019-07-24 21:01:26 +08:00
# If we execute `print -P $1`, how many characters will be printed on the last line?
# Assumes that `%{%}` and `%G` don't lie.
#
# _p9k_prompt_length '' => 0
# _p9k_prompt_length 'abc' => 3
# _p9k_prompt_length $'abc\nxy' => 2
# _p9k_prompt_length $'\t' => 8
# _p9k_prompt_length '%F{red}abc' => 3
# _p9k_prompt_length $'%{a\b%Gb%}' => 1
function _p9k_prompt_length( ) {
local COLUMNS = 1024
local -i x y = $# 1 m
if ( ( y ) ) ; then
while ( ( ${ ${ (%) :- $1 % $y (l.1.0) } [-1] } ) ) ; do
x = y
( ( y *= 2 ) ) ;
done
local xy
while ( ( y > x + 1 ) ) ; do
m = $(( x + ( y - x) / 2 ))
typeset ${ ${ (%) :- $1 % $m (l.x.y) } [-1] } = $m
done
fi
2020-02-10 19:59:37 +08:00
_p9k__ret = $x
2019-07-24 21:01:26 +08:00
}
2020-01-28 14:41:42 +08:00
typeset -gr __p9k_byte_suffix = ( 'B' 'K' 'M' 'G' 'T' 'P' 'E' 'Z' 'Y' )
2019-07-24 21:01:26 +08:00
# 42 => 42B
# 1536 => 1.5K
function _p9k_human_readable_bytes( ) {
typeset -F 2 n = $1
local suf
for suf in $__p9k_byte_suffix ; do
( ( n < 100 ) ) && break
( ( n /= 1024 ) )
done
2020-02-10 19:59:37 +08:00
_p9k__ret = ${ ${ n %%0# } %. } $suf
2019-07-24 21:01:26 +08:00
}
2020-01-26 21:46:50 +08:00
if is-at-least 5.4; then
function _p9k_print_params( ) { typeset -p -- " $@ " }
else
# Cannot use `typeset -p` unconditionally because of bugs in zsh.
function _p9k_print_params( ) {
local name
for name; do
case $parameters [ $name ] in
array*)
print -r -- " $name =( " " ${ (@q) ${ (@P)name } } " ")"
; ;
association*)
# Cannot use "${(@q)${(@kvP)name}}" because of bugs in zsh.
local kv = ( " ${ (@kvP)name } " )
print -r -- " $name =( " " ${ (@q)kv } " ")"
; ;
*)
print -r -- " $name = ${ (q) ${ (P)name } } "
; ;
esac
done
}
fi
2019-07-24 21:01:26 +08:00
# Determine if the passed segment is used in the prompt
#
# Pass the name of the segment to this function to test for its presence in
# either the LEFT or RIGHT prompt arrays.
# * $1: The segment to be tested.
2019-07-25 03:07:28 +08:00
_p9k_segment_in_use( ) {
2019-07-24 21:01:26 +08:00
( ( $_POWERLEVEL9K_LEFT_PROMPT_ELEMENTS [ ( I) $1 ( | _joined) ] ||
$_POWERLEVEL9K_RIGHT_PROMPT_ELEMENTS [ ( I) $1 ( | _joined) ] ) )
}
2019-06-01 23:54:53 +08:00
# Caching allows storing array-to-array associations. It should be used like this:
#
# if ! _p9k_cache_get "$key1" "$key2"; then
# # Compute val1 and val2 and then store them in the cache.
# _p9k_cache_set "$val1" "$val2"
# fi
2020-02-10 19:59:37 +08:00
# # Here ${_p9k__cache_val[1]} and ${_p9k__cache_val[2]} are $val1 and $val2 respectively.
2019-06-01 23:54:53 +08:00
#
# Limitations:
#
# * Calling _p9k_cache_set without arguments clears the cache entry. Subsequent calls to
# _p9k_cache_get for the same key will return an error.
# * There must be no intervening _p9k_cache_get calls between the associated _p9k_cache_get
# and _p9k_cache_set.
_p9k_cache_set( ) {
# Uncomment to see cache misses.
2020-02-10 19:59:37 +08:00
# echo "caching: ${(@0q)_p9k__cache_key} => (${(q)@})" >&2
_p9k_cache[ $_p9k__cache_key ] = " ${ (pj : \0 : )* } 0 "
_p9k__cache_val = ( " $@ " )
2019-10-25 19:22:50 +08:00
_p9k__state_dump_scheduled = 1
2019-06-01 23:54:53 +08:00
}
_p9k_cache_get( ) {
2020-02-10 19:59:37 +08:00
_p9k__cache_key = " ${ (pj : \0 : )* } "
local v = $_p9k_cache [ $_p9k__cache_key ]
[ [ -n $v ] ] && _p9k__cache_val = ( " ${ (@0) ${ v [1,-2] } } " )
2019-06-01 23:54:53 +08:00
}
2019-10-16 23:36:54 +08:00
_p9k_cache_ephemeral_set( ) {
# Uncomment to see cache misses.
2020-02-10 19:59:37 +08:00
# echo "caching: ${(@0q)_p9k__cache_key} => (${(q)@})" >&2
_p9k__cache_ephemeral[ $_p9k__cache_key ] = " ${ (pj : \0 : )* } 0 "
_p9k__cache_val = ( " $@ " )
2019-10-16 23:36:54 +08:00
}
_p9k_cache_ephemeral_get( ) {
2020-02-10 19:59:37 +08:00
_p9k__cache_key = " ${ (pj : \0 : )* } "
local v = $_p9k__cache_ephemeral [ $_p9k__cache_key ]
[ [ -n $v ] ] && _p9k__cache_val = ( " ${ (@0) ${ v [1,-2] } } " )
2019-10-16 23:36:54 +08:00
}
2019-10-10 01:57:18 +08:00
_p9k_cache_stat_get( ) {
local -H stat
local label = $1 f
shift
2019-10-25 19:22:50 +08:00
_p9k__cache_stat_meta =
_p9k__cache_stat_fprint =
2019-10-10 01:57:18 +08:00
for f; do
if zstat -H stat -- $f 2>/dev/null; then
2019-10-25 19:22:50 +08:00
_p9k__cache_stat_meta += " ${ (q)f } $stat [inode] $stat [mtime] $stat [size] $stat [mode]; "
2019-10-10 01:57:18 +08:00
fi
done
2020-02-10 21:33:09 +08:00
if _p9k_cache_get $0 $label meta " $@ " ; then
if [ [ $_p9k__cache_val [ 1] = = $_p9k__cache_stat_meta ] ] ; then
_p9k__cache_stat_fprint = $_p9k__cache_val [ 2]
local -a key = ( $0 $label fprint " $@ " " $_p9k__cache_stat_fprint " )
_p9k__cache_fprint_key = " ${ (pj : \0 : )key } "
shift 2 _p9k__cache_val
return 0
else
local -a key = ( $0 $label fprint " $@ " " $_p9k__cache_val [2] " )
_p9k__cache_ephemeral[ ${ (pj : \0 : )key } ] = " ${ (pj : \0 : )_p9k__cache_val[3,-1] } 0 "
fi
2019-10-10 01:57:18 +08:00
fi
if ( ( $+commands[ md5] ) ) ; then
2019-10-10 02:04:09 +08:00
local -a md5 = ( md5)
2019-10-10 01:57:18 +08:00
elif ( ( $+commands[ md5sum] ) ) ; then
local -a md5 = ( md5sum -b)
else
return 1
fi
local fprint
for f; do
if fprint = " $( $md5 $f 2>/dev/null) " ; then
2019-10-25 19:22:50 +08:00
_p9k__cache_stat_fprint += " ${ (q)fprint } "
2019-10-10 01:57:18 +08:00
fi
done
2020-02-10 19:59:37 +08:00
local meta_key = $_p9k__cache_key
2020-02-10 21:33:09 +08:00
if _p9k_cache_ephemeral_get $0 $label fprint " $@ " " $_p9k__cache_stat_fprint " ; then
2020-02-10 19:59:37 +08:00
_p9k__cache_fprint_key = $_p9k__cache_key
_p9k__cache_key = $meta_key
_p9k_cache_set " $_p9k__cache_stat_meta " " $_p9k__cache_stat_fprint " " $_p9k__cache_val [@] "
shift 2 _p9k__cache_val
2019-11-04 16:07:06 +08:00
return 0
2019-10-10 01:57:18 +08:00
fi
2020-02-10 19:59:37 +08:00
_p9k__cache_fprint_key = $_p9k__cache_key
_p9k__cache_key = $meta_key
2019-10-10 01:57:18 +08:00
return 1
}
_p9k_cache_stat_set( ) {
2019-10-25 19:22:50 +08:00
_p9k_cache_set " $_p9k__cache_stat_meta " " $_p9k__cache_stat_fprint " " $@ "
2020-02-10 19:59:37 +08:00
_p9k__cache_key = $_p9k__cache_fprint_key
2020-02-10 21:33:09 +08:00
_p9k_cache_ephemeral_set " $@ "
2019-10-10 01:57:18 +08:00
}
2019-07-09 18:40:31 +08:00
# _p9k_param prompt_foo_BAR BACKGROUND red
_p9k_param( ) {
local key = " _p9k_param ${ (pj : \0 : )* } "
2020-02-10 19:59:37 +08:00
_p9k__ret = $_p9k_cache [ $key ]
if [ [ -n $_p9k__ret ] ] ; then
_p9k__ret[ -1,-1] = ''
2019-07-09 18:40:31 +08:00
else
if [ [ $1 = = ( #b)prompt_([a-z0-9_]#)(*) ]]; then
2019-11-06 17:22:51 +08:00
local var = _POWERLEVEL9K_${ (U)match[1] } $match [ 2] _$2
2019-07-09 18:40:31 +08:00
if ( ( $+parameters[ $var ] ) ) ; then
2020-02-10 19:59:37 +08:00
_p9k__ret = ${ (P)var }
2019-07-09 18:40:31 +08:00
else
2019-11-06 17:22:51 +08:00
var = _POWERLEVEL9K_${ (U)match[1]%_ } _$2
2019-07-09 18:40:31 +08:00
if ( ( $+parameters[ $var ] ) ) ; then
2020-02-10 19:59:37 +08:00
_p9k__ret = ${ (P)var }
2019-07-09 18:40:31 +08:00
else
2019-11-06 17:22:51 +08:00
var = _POWERLEVEL9K_$2
2019-07-09 18:40:31 +08:00
if ( ( $+parameters[ $var ] ) ) ; then
2020-02-10 19:59:37 +08:00
_p9k__ret = ${ (P)var }
2019-07-09 18:40:31 +08:00
else
2020-02-10 19:59:37 +08:00
_p9k__ret = $3
2019-07-09 18:40:31 +08:00
fi
fi
fi
else
2019-11-06 17:22:51 +08:00
local var = _POWERLEVEL9K_$2
2019-07-09 18:40:31 +08:00
if ( ( $+parameters[ $var ] ) ) ; then
2020-02-10 19:59:37 +08:00
_p9k__ret = ${ (P)var }
2019-07-09 18:40:31 +08:00
else
2020-02-10 19:59:37 +08:00
_p9k__ret = $3
2019-07-09 18:40:31 +08:00
fi
fi
2020-02-10 19:59:37 +08:00
_p9k_cache[ $key ] = ${ _p9k__ret } .
2019-07-09 18:40:31 +08:00
fi
}
2019-07-02 02:20:59 +08:00
2019-07-09 20:42:13 +08:00
# _p9k_get_icon prompt_foo_BAR BAZ_ICON quix
2019-06-01 23:54:53 +08:00
_p9k_get_icon( ) {
2020-02-03 14:55:54 +08:00
local key = " _p9k_get_icon ${ (pj : \0 : )* } "
2020-02-10 19:59:37 +08:00
_p9k__ret = $_p9k_cache [ $key ]
if [ [ -n $_p9k__ret ] ] ; then
_p9k__ret[ -1,-1] = ''
2019-07-02 02:20:59 +08:00
else
2019-07-09 18:40:31 +08:00
if [ [ $2 = = $'\1' * ] ] ; then
2020-02-10 19:59:37 +08:00
_p9k__ret = ${ 2 [2,-1] }
2019-07-02 02:20:59 +08:00
else
2020-02-06 23:10:53 +08:00
_p9k_param " $1 " " $2 " ${ icons [ $2 ]- $'\1' $3 }
2020-02-10 19:59:37 +08:00
if [ [ $_p9k__ret = = $'\1' * ] ] ; then
_p9k__ret = ${ _p9k__ret [2,-1] }
2019-07-09 20:42:13 +08:00
else
2020-02-10 19:59:37 +08:00
_p9k__ret = ${ (g : : )_p9k__ret }
[ [ $_p9k__ret != $'\b' ? ] ] || _p9k__ret = " %{ $_p9k__ret %} " # penance for past sins
2019-07-09 20:42:13 +08:00
fi
2019-07-02 02:20:59 +08:00
fi
2020-02-10 19:59:37 +08:00
_p9k_cache[ $key ] = ${ _p9k__ret } .
2019-07-02 02:20:59 +08:00
fi
2019-06-01 23:54:53 +08:00
}
_p9k_translate_color( ) {
2019-07-09 18:40:31 +08:00
if [ [ $1 = = <-> ] ] ; then # decimal color code: 255
2020-02-10 19:59:37 +08:00
_p9k__ret = ${ (l.3..0.)1 }
2019-07-09 18:40:31 +08:00
elif [ [ $1 = = '#' [ [ :xdigit:] ] ## ]]; then # hexademical color code: #ffffff
2020-02-10 19:59:37 +08:00
_p9k__ret = ${ (L)1 }
2019-07-09 18:40:31 +08:00
else # named color: red
2019-06-01 23:54:53 +08:00
# Strip prifixes if there are any.
2020-02-10 19:59:37 +08:00
_p9k__ret = $__p9k_colors [ ${ ${ ${ 1 #bg- } #fg- } #br } ]
2019-06-01 23:54:53 +08:00
fi
}
2019-11-06 16:21:12 +08:00
# _p9k_color prompt_foo_BAR BACKGROUND red
2019-06-01 23:54:53 +08:00
_p9k_color( ) {
2019-07-09 18:40:31 +08:00
local key = " _p9k_color ${ (pj : \0 : )* } "
2020-02-10 19:59:37 +08:00
_p9k__ret = $_p9k_cache [ $key ]
if [ [ -n $_p9k__ret ] ] ; then
_p9k__ret[ -1,-1] = ''
2019-07-09 18:40:31 +08:00
else
_p9k_param " $@ "
2020-02-10 19:59:37 +08:00
_p9k_translate_color $_p9k__ret
_p9k_cache[ $key ] = ${ _p9k__ret } .
2019-07-09 18:40:31 +08:00
fi
2019-06-01 23:54:53 +08:00
}
2020-02-10 19:59:37 +08:00
# _p9k_vcs_style CLEAN REMOTE_BRANCH
2019-07-09 19:32:45 +08:00
_p9k_vcs_style( ) {
2020-02-10 19:59:37 +08:00
local key = " $0 ${ (pj : \0 : )* } "
_p9k__ret = $_p9k_cache [ $key ]
if [ [ -n $_p9k__ret ] ] ; then
_p9k__ret[ -1,-1] = ''
2019-07-09 19:32:45 +08:00
else
local style = %b # TODO: support bold
2019-07-24 20:34:26 +08:00
_p9k_color prompt_vcs_$1 BACKGROUND " ${ __p9k_vcs_states [ $1 ] } "
2020-02-10 19:59:37 +08:00
_p9k_background $_p9k__ret
style += $_p9k__ret
2019-07-09 19:32:45 +08:00
2019-11-06 17:22:51 +08:00
local var = _POWERLEVEL9K_VCS_${ 1 } _${ 2 } FORMAT_FOREGROUND
2019-07-09 19:32:45 +08:00
if ( ( $+parameters[ $var ] ) ) ; then
2019-08-01 21:09:39 +08:00
_p9k_translate_color " ${ (P)var } "
2019-07-09 19:32:45 +08:00
else
2019-11-06 17:22:51 +08:00
var = _POWERLEVEL9K_VCS_${ 2 } FORMAT_FOREGROUND
2019-07-09 19:32:45 +08:00
if ( ( $+parameters[ $var ] ) ) ; then
2019-08-01 21:09:39 +08:00
_p9k_translate_color " ${ (P)var } "
2019-07-09 19:32:45 +08:00
else
2019-07-24 20:34:26 +08:00
_p9k_color prompt_vcs_$1 FOREGROUND " $_p9k_color1 "
2019-07-09 19:32:45 +08:00
fi
fi
2019-08-01 21:09:39 +08:00
2020-02-10 19:59:37 +08:00
_p9k_foreground $_p9k__ret
_p9k__ret = $style $_p9k__ret
_p9k_cache[ $key ] = ${ _p9k__ret } .
2019-07-09 19:32:45 +08:00
fi
}
2019-06-01 23:54:53 +08:00
_p9k_background( ) {
2020-02-10 19:59:37 +08:00
[ [ -n $1 ] ] && _p9k__ret = " %K{ $1 } " || _p9k__ret = "%k"
2019-06-01 23:54:53 +08:00
}
_p9k_foreground( ) {
2019-10-19 13:40:27 +08:00
# Note: This code used to produce `%1F` instead of `%F{1}` because it's more efficient.
# Unfortunately, this triggers a bug in zsh. Namely, `%1F{2}` gets percent-expanded as if
# it was `%F{2}`.
2020-02-10 19:59:37 +08:00
[ [ -n $1 ] ] && _p9k__ret = " %F{ $1 } " || _p9k__ret = "%f"
2019-06-01 23:54:53 +08:00
}
2019-07-25 05:05:41 +08:00
_p9k_escape_style( ) {
2020-02-10 19:59:37 +08:00
[ [ $1 = = *'}' * ] ] && _p9k__ret = '${:-"' $1 '"}' || _p9k__ret = $1
2019-06-01 23:54:53 +08:00
}
2019-07-09 01:33:42 +08:00
_p9k_escape( ) {
2020-02-10 19:59:37 +08:00
[ [ $1 = = *[ "~!#\`\$^&*()\\\"'<>?{}[]" ] * ] ] && _p9k__ret = " \${(Q)\${:- ${ (qqq) ${ (q)1 } } }} " || _p9k__ret = $1
2019-07-09 01:33:42 +08:00
}
2019-07-09 22:00:05 +08:00
# * $1: Name of the function that was originally invoked.
# Necessary, to make the dynamic color-overwrite mechanism work.
2019-07-25 03:07:28 +08:00
# * $2: Background color.
# * $3: Foreground color.
# * $4: An identifying icon.
# * $5: 1 to to perform parameter expansion and process substitution.
# * $6: If not empty but becomes empty after parameter expansion and process substitution,
2019-07-09 22:00:05 +08:00
# the segment isn't rendered.
2019-07-25 03:07:28 +08:00
# * $7: Content.
_p9k_left_prompt_segment( ) {
2020-02-10 19:59:37 +08:00
if ! _p9k_cache_get " $0 " " $1 " " $2 " " $3 " " $4 " " $_p9k__segment_index " ; then
2019-07-25 03:07:28 +08:00
_p9k_color $1 BACKGROUND $2
2020-02-10 19:59:37 +08:00
local bg_color = $_p9k__ret
2019-06-01 23:54:53 +08:00
_p9k_background $bg_color
2020-02-10 19:59:37 +08:00
local bg = $_p9k__ret
2019-06-01 23:54:53 +08:00
2019-07-25 03:07:28 +08:00
_p9k_color $1 FOREGROUND $3
2020-02-10 19:59:37 +08:00
local fg_color = $_p9k__ret
2019-06-01 23:54:53 +08:00
_p9k_foreground $fg_color
2020-02-10 19:59:37 +08:00
local fg = $_p9k__ret
2019-06-01 23:54:53 +08:00
2019-07-09 20:42:13 +08:00
_p9k_get_icon $1 LEFT_SEGMENT_SEPARATOR
2020-02-10 19:59:37 +08:00
local sep = $_p9k__ret
_p9k_escape $_p9k__ret
local sep_ = $_p9k__ret
2019-07-09 20:42:13 +08:00
2019-07-09 18:40:31 +08:00
_p9k_get_icon $1 LEFT_SUBSEGMENT_SEPARATOR
2020-02-10 19:59:37 +08:00
_p9k_escape $_p9k__ret
local subsep_ = $_p9k__ret
2019-06-01 23:54:53 +08:00
2019-07-09 16:09:50 +08:00
local icon_
2019-07-25 03:07:28 +08:00
if [ [ -n $4 ] ] ; then
_p9k_get_icon $1 $4
2020-02-10 19:59:37 +08:00
_p9k_escape $_p9k__ret
icon_ = $_p9k__ret
2019-07-09 16:09:50 +08:00
fi
2019-07-09 20:42:13 +08:00
_p9k_get_icon $1 LEFT_PROMPT_FIRST_SEGMENT_START_SYMBOL
2020-02-10 19:59:37 +08:00
local start_sep = $_p9k__ret
2019-07-12 00:45:53 +08:00
[ [ -n $start_sep ] ] && start_sep = " %b%k%F{ $bg_color } $start_sep "
2019-07-09 20:42:13 +08:00
_p9k_get_icon $1 LEFT_PROMPT_LAST_SEGMENT_END_SYMBOL $sep
2020-02-10 19:59:37 +08:00
_p9k_escape $_p9k__ret
local end_sep_ = $_p9k__ret
2019-07-04 23:40:54 +08:00
2019-07-09 01:33:42 +08:00
local style = %b$bg $fg
2019-07-25 05:05:41 +08:00
local style_ = ${ style // \} / \\ \} }
2019-07-09 01:33:42 +08:00
2019-07-23 21:47:25 +08:00
_p9k_get_icon $1 WHITESPACE_BETWEEN_LEFT_SEGMENTS ' '
2020-02-10 19:59:37 +08:00
local space = $_p9k__ret
2019-07-09 20:42:13 +08:00
_p9k_get_icon $1 LEFT_LEFT_WHITESPACE $space
2020-02-10 19:59:37 +08:00
local left_space = $_p9k__ret
2019-07-09 20:42:13 +08:00
[ [ $left_space = = *%* ] ] && left_space += $style
_p9k_get_icon $1 LEFT_RIGHT_WHITESPACE $space
2020-02-10 19:59:37 +08:00
_p9k_escape $_p9k__ret
local right_space_ = $_p9k__ret
2019-07-09 20:42:13 +08:00
[ [ $right_space_ = = *%* ] ] && right_space_ += $style_
2019-07-09 16:09:50 +08:00
2020-02-10 19:59:37 +08:00
local s = '<_p9k__s>' ss = '<_p9k__ss>'
2019-06-01 23:54:53 +08:00
2019-10-19 22:47:19 +08:00
local -i non_hermetic = 0
2019-06-01 23:54:53 +08:00
# Segment separator logic:
#
2020-02-10 19:59:37 +08:00
# if [[ $_p9k__bg == NONE ]]; then
2019-06-01 23:54:53 +08:00
# 1
# elif (( joined )); then
# 2
2020-02-10 19:59:37 +08:00
# elif [[ $bg_color == (${_p9k__bg}|${_p9k__bg:-0}) ]]; then
2019-06-01 23:54:53 +08:00
# 3
# else
# 4
# fi
2019-09-20 17:22:14 +08:00
local t = $(( $# _p9k_t - __p9k_ksh_arrays))
2019-07-24 20:34:26 +08:00
_p9k_t += $start_sep $style $left_space # 1
_p9k_t += $style # 2
2019-07-12 03:11:38 +08:00
if [ [ -n $fg_color && $fg_color = = $bg_color ] ] ; then
2019-07-24 20:34:26 +08:00
if [ [ $fg_color = = $_p9k_color1 ] ] ; then
_p9k_foreground $_p9k_color2
2019-07-12 03:11:38 +08:00
else
2019-07-24 20:34:26 +08:00
_p9k_foreground $_p9k_color1
2019-07-12 03:11:38 +08:00
fi
2020-02-10 19:59:37 +08:00
_p9k_t += %b$bg $_p9k__ret $ss $style $left_space # 3
2019-06-01 23:54:53 +08:00
else
2019-07-24 20:34:26 +08:00
_p9k_t += %b$bg $fg $ss $style $left_space # 3
2019-06-01 23:54:53 +08:00
fi
2019-07-24 20:34:26 +08:00
_p9k_t += %b$bg $s $style $left_space # 4
2019-06-01 23:54:53 +08:00
2020-02-10 19:59:37 +08:00
local join = " _p9k__i>= $_p9k_left_join [ $_p9k__segment_index ] "
2019-07-11 02:06:19 +08:00
_p9k_param $1 SELF_JOINED false
2020-02-10 19:59:37 +08:00
if [ [ $_p9k__ret = = false ] ] ; then
if ( ( _p9k__segment_index > $_p9k_left_join [ $_p9k__segment_index ] ) ) ; then
join += " &&_p9k__i< $_p9k__segment_index "
2019-10-16 23:36:54 +08:00
else
join =
fi
fi
2019-07-11 02:06:19 +08:00
2019-07-09 01:33:42 +08:00
local p =
2020-02-10 19:59:37 +08:00
p += "\${_p9k__n::=}"
p += " \${\${\${_p9k__bg:-0}:#NONE}:-\${_p9k__n::= $(( t+1)) }} " # 1
2019-10-16 23:36:54 +08:00
if [ [ -n $join ] ] ; then
2020-02-10 19:59:37 +08:00
p += " \${_p9k__n:=\${\${\$(( $join )):#0}:+ $(( t+2)) }} " # 2
2019-10-16 23:36:54 +08:00
fi
2019-09-20 17:22:14 +08:00
if ( ( __p9k_sh_glob ) ) ; then
2020-02-10 19:59:37 +08:00
p += " \${_p9k__n:=\${\${(M)\${:-x $bg_color }:#x\$_p9k__bg}:+ $(( t+3)) }} " # 3
p += " \${_p9k__n:=\${\${(M)\${:-x $bg_color }:#x\$ ${ _p9k__bg :- 0 } }:+ $(( t+3)) }} " # 3
2019-09-20 17:22:14 +08:00
else
2020-02-10 19:59:37 +08:00
p += " \${_p9k__n:=\${\${(M)\${:-x $bg_color }:#x(\$_p9k__bg|\${_p9k__bg:-0})}:+ $(( t+3)) }} " # 3
2019-09-20 17:22:14 +08:00
fi
2020-02-10 19:59:37 +08:00
p += " \${_p9k__n:= $(( t+4)) } " # 4
2019-07-09 16:09:50 +08:00
2019-07-09 18:40:31 +08:00
_p9k_param $1 VISUAL_IDENTIFIER_EXPANSION '${P9K_VISUAL_IDENTIFIER}'
2020-02-10 19:59:37 +08:00
[ [ $_p9k__ret = = ( | *[ ^\\ ] ) '$(' * ] ] && non_hermetic = 1
local icon_exp_ = ${ _p9k__ret : + \" $_p9k__ret \" }
2019-07-09 18:40:31 +08:00
_p9k_param $1 CONTENT_EXPANSION '${P9K_CONTENT}'
2020-02-10 19:59:37 +08:00
[ [ $_p9k__ret = = ( | *[ ^\\ ] ) '$(' * ] ] && non_hermetic = 1
local content_exp_ = ${ _p9k__ret : + \" $_p9k__ret \" }
2019-07-09 16:09:50 +08:00
2019-07-23 15:16:47 +08:00
if [ [ ( $icon_exp_ != '"${P9K_VISUAL_IDENTIFIER}"' && $icon_exp_ = = *'$' * ) ||
( $content_exp_ != '"${P9K_CONTENT}"' && $content_exp_ = = *'$' * ) ] ] ; then
2019-07-17 15:52:37 +08:00
p += " \${P9K_VISUAL_IDENTIFIER::= $icon_ } "
fi
local -i has_icon = -1 # maybe
2019-07-23 15:16:47 +08:00
if [ [ $icon_exp_ != '"${P9K_VISUAL_IDENTIFIER}"' && $icon_exp_ = = *'$' * ] ] ; then
2020-02-10 19:59:37 +08:00
p += '${_p9k__v::=' $icon_exp_ $style_ '}'
2019-07-09 16:09:50 +08:00
else
2020-02-10 19:59:37 +08:00
[ [ $icon_exp_ = = '"${P9K_VISUAL_IDENTIFIER}"' ] ] && _p9k__ret = $icon_ || _p9k__ret = $icon_exp_
if [ [ -n $_p9k__ret ] ] ; then
p += " \${_p9k__v::= $_p9k__ret "
[ [ $_p9k__ret = = *%* ] ] && p += $style_
2019-07-17 15:52:37 +08:00
p += "}"
has_icon = 1 # definitely yes
else
has_icon = 0 # definitely no
fi
2019-07-09 01:33:42 +08:00
fi
2020-02-10 19:59:37 +08:00
p += " \${_p9k__c::= $content_exp_ } "
p += '${_p9k__e::=${${_p9k__' ${ _p9k__line_index } l${ ${ 1 #prompt_ } %%[A-Z_]# } '+00}:-'
2019-07-17 15:52:37 +08:00
if ( ( has_icon = = -1 ) ) ; then
2020-02-10 19:59:37 +08:00
p += '${${(%):-$_p9k__c%1(l.1.0)}[-1]}${${(%):-$_p9k__v%1(l.1.0)}[-1]}}'
2019-07-17 15:52:37 +08:00
else
2020-02-10 19:59:37 +08:00
p += '${${(%):-$_p9k__c%1(l.1.0)}[-1]}' $has_icon '}'
2019-07-17 15:52:37 +08:00
fi
2019-07-09 01:33:42 +08:00
2019-10-28 01:18:15 +08:00
p += '}}+}'
2019-06-01 23:54:53 +08:00
2020-02-10 19:59:37 +08:00
p += '${${_p9k__e:#00}:+${${_p9k_t[$_p9k__n]/' $ss '/$_p9k__ss}/' $s '/$_p9k__s}'
2019-07-12 00:45:53 +08:00
2019-07-22 01:43:14 +08:00
_p9k_param $1 ICON_BEFORE_CONTENT ''
2020-02-10 19:59:37 +08:00
if [ [ $_p9k__ret != false ] ] ; then
2019-07-22 01:43:14 +08:00
_p9k_param $1 PREFIX ''
2020-02-10 19:59:37 +08:00
_p9k__ret = ${ (g : : )_p9k__ret }
_p9k_escape $_p9k__ret
p += $_p9k__ret
[ [ $_p9k__ret = = *%* ] ] && local -i need_style = 1 || local -i need_style = 0
2019-07-22 01:43:14 +08:00
if ( ( has_icon != 0 ) ) ; then
_p9k_color $1 VISUAL_IDENTIFIER_COLOR $fg_color
2020-02-10 19:59:37 +08:00
_p9k_foreground $_p9k__ret
_p9k__ret = %b$bg $_p9k__ret
_p9k__ret = ${ _p9k__ret // \} / \\ \} }
[ [ $_p9k__ret != $style_ || $need_style = = 1 ] ] && p += $_p9k__ret
p += '${_p9k__v}'
2019-07-22 01:43:14 +08:00
_p9k_get_icon $1 LEFT_MIDDLE_WHITESPACE ' '
2020-02-10 19:59:37 +08:00
if [ [ -n $_p9k__ret ] ] ; then
_p9k_escape $_p9k__ret
[ [ _p9k__ret = = *%* ] ] && _p9k__ret += $style_
p += '${${(M)_p9k__e:#11}:+' $_p9k__ret '}'
2019-07-22 01:43:14 +08:00
fi
elif ( ( need_style ) ) ; then
p += $style_
fi
2019-07-09 01:33:42 +08:00
2020-02-10 19:59:37 +08:00
p += '${_p9k__c}' $style_
2019-07-22 01:43:14 +08:00
else
_p9k_param $1 PREFIX ''
2020-02-10 19:59:37 +08:00
_p9k__ret = ${ (g : : )_p9k__ret }
_p9k_escape $_p9k__ret
p += $_p9k__ret
[ [ $_p9k__ret = = *%* ] ] && p += $style_
2019-07-22 01:43:14 +08:00
2020-02-10 19:59:37 +08:00
p += '${_p9k__c}' $style_
2019-07-22 01:43:14 +08:00
if ( ( has_icon != 0 ) ) ; then
local -i need_style = 0
_p9k_get_icon $1 LEFT_MIDDLE_WHITESPACE ' '
2020-02-10 19:59:37 +08:00
if [ [ -n $_p9k__ret ] ] ; then
_p9k_escape $_p9k__ret
[ [ $_p9k__ret = = *%* ] ] && need_style = 1
p += '${${(M)_p9k__e:#11}:+' $_p9k__ret '}'
2019-07-22 01:43:14 +08:00
fi
2019-07-17 15:52:37 +08:00
2019-07-22 01:43:14 +08:00
_p9k_color $1 VISUAL_IDENTIFIER_COLOR $fg_color
2020-02-10 19:59:37 +08:00
_p9k_foreground $_p9k__ret
_p9k__ret = %b$bg $_p9k__ret
_p9k__ret = ${ _p9k__ret // \} / \\ \} }
[ [ $_p9k__ret != $style_ || $need_style = = 1 ] ] && p += $_p9k__ret
p += '$_p9k__v'
2019-07-17 15:52:37 +08:00
fi
2019-07-09 18:40:31 +08:00
fi
2019-07-07 01:55:08 +08:00
2019-07-09 18:40:31 +08:00
_p9k_param $1 SUFFIX ''
2020-02-10 19:59:37 +08:00
_p9k__ret = ${ (g : : )_p9k__ret }
_p9k_escape $_p9k__ret
p += $_p9k__ret
[ [ $_p9k__ret = = *%* && -n $right_space_ ] ] && p += $style_
2019-07-09 20:42:13 +08:00
p += $right_space_
2019-07-19 20:59:44 +08:00
p += '${${:-'
2020-02-10 19:59:37 +08:00
p += " \${_p9k__s::=%F{ $bg_color \} $sep_ }\${_p9k__ss::= $subsep_ }\${_p9k__sss::=%F{ $bg_color \} $end_sep_ } "
p += " \${_p9k__i::= $_p9k__segment_index }\${_p9k__bg::= $bg_color } "
2019-07-19 20:59:44 +08:00
p += '}+}'
2019-07-12 00:45:53 +08:00
p += '}'
2019-07-07 01:55:08 +08:00
2020-02-12 22:45:23 +08:00
_p9k_param $1 SHOW_ON_UPGLOB ''
_p9k_cache_set " $p " $non_hermetic $_p9k__ret
fi
if [ [ -n $_p9k__cache_val [ 3] ] ] ; then
_p9k__has_upglob = 1
_p9k_upglob $_p9k__cache_val [ 3] && return
2019-06-01 23:54:53 +08:00
fi
2020-02-10 19:59:37 +08:00
_p9k__non_hermetic_expansion = $_p9k__cache_val [ 2]
2019-10-19 22:47:19 +08:00
2020-02-10 19:59:37 +08:00
( ( $5 ) ) && _p9k__ret = \" $7 \" || _p9k_escape $7
2019-07-25 03:07:28 +08:00
if [ [ -z $6 ] ] ; then
2020-02-10 19:59:37 +08:00
_p9k__prompt += " \${\${:-\${P9K_CONTENT::= $_p9k__ret } $_p9k__cache_val [1] "
2019-07-09 16:09:50 +08:00
else
2020-02-10 19:59:37 +08:00
_p9k__prompt += " \${\${:-\" $6 \"}:+\${\${:-\${P9K_CONTENT::= $_p9k__ret } $_p9k__cache_val [1]} "
2019-07-09 16:09:50 +08:00
fi
2019-06-01 23:54:53 +08:00
}
2019-07-25 03:07:28 +08:00
# The same as _p9k_left_prompt_segment above but for the right prompt.
_p9k_right_prompt_segment( ) {
2020-02-10 19:59:37 +08:00
if ! _p9k_cache_get " $0 " " $1 " " $2 " " $3 " " $4 " " $_p9k__segment_index " ; then
2019-07-25 03:07:28 +08:00
_p9k_color $1 BACKGROUND $2
2020-02-10 19:59:37 +08:00
local bg_color = $_p9k__ret
2019-06-01 23:54:53 +08:00
_p9k_background $bg_color
2020-02-10 19:59:37 +08:00
local bg = $_p9k__ret
local bg_ = ${ _p9k__ret // \} / \\ \} }
2019-06-01 23:54:53 +08:00
2019-07-25 03:07:28 +08:00
_p9k_color $1 FOREGROUND $3
2020-02-10 19:59:37 +08:00
local fg_color = $_p9k__ret
2019-06-01 23:54:53 +08:00
_p9k_foreground $fg_color
2020-02-10 19:59:37 +08:00
local fg = $_p9k__ret
2019-06-01 23:54:53 +08:00
2019-07-12 00:45:53 +08:00
_p9k_get_icon $1 RIGHT_SEGMENT_SEPARATOR
2020-02-10 19:59:37 +08:00
local sep = $_p9k__ret
_p9k_escape $_p9k__ret
local sep_ = $_p9k__ret
2019-07-12 00:45:53 +08:00
2019-07-09 18:40:31 +08:00
_p9k_get_icon $1 RIGHT_SUBSEGMENT_SEPARATOR
2020-02-10 19:59:37 +08:00
local subsep = $_p9k__ret
2019-06-01 23:54:53 +08:00
2019-07-12 00:45:53 +08:00
local icon_
2019-07-25 03:07:28 +08:00
if [ [ -n $4 ] ] ; then
_p9k_get_icon $1 $4
2020-02-10 19:59:37 +08:00
_p9k_escape $_p9k__ret
icon_ = $_p9k__ret
2019-06-01 23:54:53 +08:00
fi
2019-07-12 00:45:53 +08:00
_p9k_get_icon $1 RIGHT_PROMPT_FIRST_SEGMENT_START_SYMBOL $sep
2020-02-10 19:59:37 +08:00
local start_sep = $_p9k__ret
2019-07-12 00:45:53 +08:00
[ [ -n $start_sep ] ] && start_sep = " %b%k%F{ $bg_color } $start_sep "
_p9k_get_icon $1 RIGHT_PROMPT_LAST_SEGMENT_END_SYMBOL
2020-02-10 19:59:37 +08:00
_p9k_escape $_p9k__ret
local end_sep_ = $_p9k__ret
2019-07-12 00:45:53 +08:00
local style = %b$bg $fg
2019-07-25 05:05:41 +08:00
local style_ = ${ style // \} / \\ \} }
2019-07-12 00:45:53 +08:00
2019-07-23 21:47:25 +08:00
_p9k_get_icon $1 WHITESPACE_BETWEEN_RIGHT_SEGMENTS ' '
2020-02-10 19:59:37 +08:00
local space = $_p9k__ret
2019-07-12 00:45:53 +08:00
_p9k_get_icon $1 RIGHT_LEFT_WHITESPACE $space
2020-02-10 19:59:37 +08:00
local left_space = $_p9k__ret
2019-07-12 00:45:53 +08:00
[ [ $left_space = = *%* ] ] && left_space += $style
_p9k_get_icon $1 RIGHT_RIGHT_WHITESPACE $space
2020-02-10 19:59:37 +08:00
_p9k_escape $_p9k__ret
local right_space_ = $_p9k__ret
2019-07-12 00:45:53 +08:00
[ [ $right_space_ = = *%* ] ] && right_space_ += $style_
2020-02-10 19:59:37 +08:00
local w = '<_p9k__w>' s = '<_p9k__s>'
2019-07-12 00:45:53 +08:00
2019-10-19 22:47:19 +08:00
local -i non_hermetic = 0
2019-07-12 00:45:53 +08:00
# Segment separator logic:
#
2020-02-10 19:59:37 +08:00
# if [[ $_p9k__bg == NONE ]]; then
2019-07-12 00:45:53 +08:00
# 1
# elif (( joined )); then
# 2
2020-02-10 19:59:37 +08:00
# elif [[ $_p9k__bg == (${bg_color}|${bg_color:-0}) ]]; then
2019-07-12 00:45:53 +08:00
# 3
# else
# 4
# fi
2019-09-20 17:22:14 +08:00
local t = $(( $# _p9k_t - __p9k_ksh_arrays))
2019-07-24 20:34:26 +08:00
_p9k_t += $start_sep $style $left_space # 1
_p9k_t += $w $style # 2
_p9k_t += $w $subsep $style $left_space # 3
_p9k_t += $w %F{ $bg_color } $sep $style $left_space # 4
2019-07-12 00:45:53 +08:00
2020-02-10 19:59:37 +08:00
local join = " _p9k__i>= $_p9k_right_join [ $_p9k__segment_index ] "
2019-07-12 00:45:53 +08:00
_p9k_param $1 SELF_JOINED false
2020-02-10 19:59:37 +08:00
if [ [ $_p9k__ret = = false ] ] ; then
if ( ( _p9k__segment_index > $_p9k_right_join [ $_p9k__segment_index ] ) ) ; then
join += " &&_p9k__i< $_p9k__segment_index "
2019-10-16 23:36:54 +08:00
else
join =
fi
fi
2019-07-12 00:45:53 +08:00
local p =
2020-02-10 19:59:37 +08:00
p += "\${_p9k__n::=}"
p += " \${\${\${_p9k__bg:-0}:#NONE}:-\${_p9k__n::= $(( t+1)) }} " # 1
2019-10-28 01:18:15 +08:00
if [ [ -n $join ] ] ; then
2020-02-10 19:59:37 +08:00
p += " \${_p9k__n:=\${\${\$(( $join )):#0}:+ $(( t+2)) }} " # 2
2019-10-28 01:18:15 +08:00
fi
2019-09-20 17:22:14 +08:00
if ( ( __p9k_sh_glob ) ) ; then
2020-02-10 19:59:37 +08:00
p += " \${_p9k__n:=\${\${(M)\${:-x\$_p9k__bg}:#x ${ (b)bg_color } }:+ $(( t+3)) }} " # 3
p += " \${_p9k__n:=\${\${(M)\${:-x\$_p9k__bg}:#x ${ (b)bg_color :- 0 } }:+ $(( t+3)) }} " # 3
2019-09-20 17:22:14 +08:00
else
2020-02-10 19:59:37 +08:00
p += " \${_p9k__n:=\${\${(M)\${:-x\$_p9k__bg}:#x( ${ (b)bg_color } | ${ (b)bg_color :- 0 } )}:+ $(( t+3)) }} " # 3
2019-09-20 17:22:14 +08:00
fi
2020-02-10 19:59:37 +08:00
p += " \${_p9k__n:= $(( t+4)) } " # 4
2019-07-12 00:45:53 +08:00
_p9k_param $1 VISUAL_IDENTIFIER_EXPANSION '${P9K_VISUAL_IDENTIFIER}'
2020-02-10 19:59:37 +08:00
[ [ $_p9k__ret = = ( | *[ ^\\ ] ) '$(' * ] ] && non_hermetic = 1
local icon_exp_ = ${ _p9k__ret : + \" $_p9k__ret \" }
2019-07-12 00:45:53 +08:00
_p9k_param $1 CONTENT_EXPANSION '${P9K_CONTENT}'
2020-02-10 19:59:37 +08:00
[ [ $_p9k__ret = = ( | *[ ^\\ ] ) '$(' * ] ] && non_hermetic = 1
local content_exp_ = ${ _p9k__ret : + \" $_p9k__ret \" }
2019-07-12 00:45:53 +08:00
2019-07-23 15:16:47 +08:00
if [ [ ( $icon_exp_ != '"${P9K_VISUAL_IDENTIFIER}"' && $icon_exp_ = = *'$' * ) ||
( $content_exp_ != '"${P9K_CONTENT}"' && $content_exp_ = = *'$' * ) ] ] ; then
2019-07-17 15:52:37 +08:00
p += " \${P9K_VISUAL_IDENTIFIER::= $icon_ } "
fi
local -i has_icon = -1 # maybe
2019-07-23 15:16:47 +08:00
if [ [ $icon_exp_ != '"${P9K_VISUAL_IDENTIFIER}"' && $icon_exp_ = = *'$' * ] ] ; then
2020-02-10 19:59:37 +08:00
p += " \${_p9k__v::= $icon_exp_ $style_ } "
2019-07-12 00:45:53 +08:00
else
2020-02-10 19:59:37 +08:00
[ [ $icon_exp_ = = '"${P9K_VISUAL_IDENTIFIER}"' ] ] && _p9k__ret = $icon_ || _p9k__ret = $icon_exp_
if [ [ -n $_p9k__ret ] ] ; then
p += " \${_p9k__v::= $_p9k__ret "
[ [ $_p9k__ret = = *%* ] ] && p += $style_
2019-07-17 15:52:37 +08:00
p += "}"
has_icon = 1 # definitely yes
else
has_icon = 0 # definitely no
fi
2019-07-12 00:45:53 +08:00
fi
2020-02-10 19:59:37 +08:00
p += " \${_p9k__c::= $content_exp_ } "
p += '${_p9k__e::=${${_p9k__' ${ _p9k__line_index } r${ ${ 1 #prompt_ } %%[A-Z_]# } '+00}:-'
2019-07-17 15:52:37 +08:00
if ( ( has_icon = = -1 ) ) ; then
2020-02-10 19:59:37 +08:00
p += '${${(%):-$_p9k__c%1(l.1.0)}[-1]}${${(%):-$_p9k__v%1(l.1.0)}[-1]}}'
2019-07-17 15:52:37 +08:00
else
2020-02-10 19:59:37 +08:00
p += '${${(%):-$_p9k__c%1(l.1.0)}[-1]}' $has_icon '}'
2019-07-17 15:52:37 +08:00
fi
2019-07-12 00:45:53 +08:00
2019-10-28 01:18:15 +08:00
p += '}}+}'
2019-07-12 00:45:53 +08:00
2020-02-10 19:59:37 +08:00
p += '${${_p9k__e:#00}:+${_p9k_t[$_p9k__n]/' $w '/$_p9k__w}'
2019-07-12 00:45:53 +08:00
2019-07-22 01:43:14 +08:00
_p9k_param $1 ICON_BEFORE_CONTENT ''
2020-02-10 19:59:37 +08:00
if [ [ $_p9k__ret != true ] ] ; then
2019-07-22 01:43:14 +08:00
_p9k_param $1 PREFIX ''
2020-02-10 19:59:37 +08:00
_p9k__ret = ${ (g : : )_p9k__ret }
_p9k_escape $_p9k__ret
p += $_p9k__ret
[ [ $_p9k__ret = = *%* ] ] && p += $style_
2019-07-22 01:43:14 +08:00
2020-02-10 19:59:37 +08:00
p += '${_p9k__c}' $style_
2019-07-22 01:43:14 +08:00
if ( ( has_icon != 0 ) ) ; then
local -i need_style = 0
_p9k_get_icon $1 RIGHT_MIDDLE_WHITESPACE ' '
2020-02-10 19:59:37 +08:00
if [ [ -n $_p9k__ret ] ] ; then
_p9k_escape $_p9k__ret
[ [ $_p9k__ret = = *%* ] ] && need_style = 1
p += '${${(M)_p9k__e:#11}:+' $_p9k__ret '}'
2019-07-22 01:43:14 +08:00
fi
2019-07-12 00:45:53 +08:00
2019-07-22 01:43:14 +08:00
_p9k_color $1 VISUAL_IDENTIFIER_COLOR $fg_color
2020-02-10 19:59:37 +08:00
_p9k_foreground $_p9k__ret
_p9k__ret = %b$bg $_p9k__ret
_p9k__ret = ${ _p9k__ret // \} / \\ \} }
[ [ $_p9k__ret != $style_ || $need_style = = 1 ] ] && p += $_p9k__ret
p += '$_p9k__v'
2019-07-22 01:43:14 +08:00
fi
else
_p9k_param $1 PREFIX ''
2020-02-10 19:59:37 +08:00
_p9k__ret = ${ (g : : )_p9k__ret }
_p9k_escape $_p9k__ret
p += $_p9k__ret
[ [ $_p9k__ret = = *%* ] ] && local -i need_style = 1 || local -i need_style = 0
2019-07-22 01:43:14 +08:00
if ( ( has_icon != 0 ) ) ; then
_p9k_color $1 VISUAL_IDENTIFIER_COLOR $fg_color
2020-02-10 19:59:37 +08:00
_p9k_foreground $_p9k__ret
_p9k__ret = %b$bg $_p9k__ret
_p9k__ret = ${ _p9k__ret // \} / \\ \} }
[ [ $_p9k__ret != $style_ || $need_style = = 1 ] ] && p += $_p9k__ret
p += '${_p9k__v}'
2019-07-22 01:43:14 +08:00
_p9k_get_icon $1 RIGHT_MIDDLE_WHITESPACE ' '
2020-02-10 19:59:37 +08:00
if [ [ -n $_p9k__ret ] ] ; then
_p9k_escape $_p9k__ret
[ [ _p9k__ret = = *%* ] ] && _p9k__ret += $style_
p += '${${(M)_p9k__e:#11}:+' $_p9k__ret '}'
2019-07-22 01:43:14 +08:00
fi
elif ( ( need_style ) ) ; then
p += $style_
2019-07-17 15:52:37 +08:00
fi
2019-07-12 00:45:53 +08:00
2020-02-10 19:59:37 +08:00
p += '${_p9k__c}' $style_
2019-07-17 15:52:37 +08:00
fi
2019-07-12 00:45:53 +08:00
_p9k_param $1 SUFFIX ''
2020-02-10 19:59:37 +08:00
_p9k__ret = ${ (g : : )_p9k__ret }
_p9k_escape $_p9k__ret
p += $_p9k__ret
2019-07-12 00:45:53 +08:00
2019-07-19 20:59:44 +08:00
p += '${${:-'
2019-07-12 15:19:20 +08:00
if [ [ -n $fg_color && $fg_color = = $bg_color ] ] ; then
2019-07-24 20:34:26 +08:00
if [ [ $fg_color = = $_p9k_color1 ] ] ; then
_p9k_foreground $_p9k_color2
2019-07-12 15:19:20 +08:00
else
2019-07-24 20:34:26 +08:00
_p9k_foreground $_p9k_color1
2019-07-12 15:19:20 +08:00
fi
else
2020-02-10 19:59:37 +08:00
_p9k__ret = $fg
2019-07-12 15:19:20 +08:00
fi
2020-02-10 19:59:37 +08:00
_p9k__ret = ${ _p9k__ret // \} / \\ \} }
p += " \${_p9k__w::= ${ right_space_ : + $style_ } $right_space_ %b $bg_ $_p9k__ret } "
2019-07-12 00:45:53 +08:00
2020-02-10 19:59:37 +08:00
p += '${_p9k__sss::='
2019-07-16 22:19:16 +08:00
p += $style_ $right_space_
[ [ $right_space_ = = *%* ] ] && p += $style_
2019-07-30 18:49:36 +08:00
if [ [ -n $end_sep_ ] ] ; then
p += " %k%F{ $bg_color \} $end_sep_ $style_ "
fi
2019-07-19 20:59:44 +08:00
p += '}'
2019-07-12 00:45:53 +08:00
2020-02-10 19:59:37 +08:00
p += " \${_p9k__i::= $_p9k__segment_index }\${_p9k__bg::= $bg_color } "
2019-07-19 20:59:44 +08:00
p += '}+}'
2019-07-12 00:45:53 +08:00
p += '}'
2020-02-12 22:45:23 +08:00
_p9k_param $1 SHOW_ON_UPGLOB ''
_p9k_cache_set " $p " $non_hermetic $_p9k__ret
fi
if [ [ -n $_p9k__cache_val [ 3] ] ] ; then
_p9k__has_upglob = 1
_p9k_upglob $_p9k__cache_val [ 3] && return
2019-07-12 00:45:53 +08:00
fi
2020-02-10 19:59:37 +08:00
_p9k__non_hermetic_expansion = $_p9k__cache_val [ 2]
2019-10-19 22:47:19 +08:00
2020-02-10 19:59:37 +08:00
( ( $5 ) ) && _p9k__ret = \" $7 \" || _p9k_escape $7
2019-07-25 03:07:28 +08:00
if [ [ -z $6 ] ] ; then
2020-02-10 19:59:37 +08:00
_p9k__prompt += " \${\${:-\${P9K_CONTENT::= $_p9k__ret } $_p9k__cache_val [1] "
2019-07-12 00:45:53 +08:00
else
2020-02-10 19:59:37 +08:00
_p9k__prompt += " \${\${:-\" $6 \"}:+\${\${:-\${P9K_CONTENT::= $_p9k__ret } $_p9k__cache_val [1]} "
2019-07-12 00:45:53 +08:00
fi
2019-06-01 23:54:53 +08:00
}
2020-02-10 19:59:37 +08:00
function _p9k_prompt_segment( ) { " _p9k_ ${ _p9k__prompt_side } _prompt_segment " " $@ " }
2019-08-01 01:41:14 +08:00
function p9k_prompt_segment( ) { p10k segment " $@ " }
2019-07-11 02:06:19 +08:00
2019-06-20 15:14:09 +08:00
function _p9k_python_version( ) {
_p9k_cached_cmd_stdout_stderr python --version || return
2020-02-10 19:59:37 +08:00
[ [ $_p9k__ret = = ( #b)Python\ ([[:digit:].]##)* ]] && _p9k__ret=$match[1]
2019-06-20 15:14:09 +08:00
}
2019-06-01 23:54:53 +08:00
################################################################
# Prompt Segment Definitions
################################################################
################################################################
# Anaconda Environment
prompt_anaconda( ) {
local p = ${ CONDA_PREFIX :- $CONDA_ENV_PATH }
2019-06-20 15:14:09 +08:00
local msg = ''
2019-07-23 21:47:25 +08:00
if ( ( _POWERLEVEL9K_ANACONDA_SHOW_PYTHON_VERSION ) ) && _p9k_python_version; then
2020-02-10 19:59:37 +08:00
msg = " ${ _p9k__ret // \% //%% } "
2019-06-01 23:54:53 +08:00
fi
2019-07-23 21:47:25 +08:00
msg += " $_POWERLEVEL9K_ANACONDA_LEFT_DELIMITER ${ ${ p : t } // \% /%% } $_POWERLEVEL9K_ANACONDA_RIGHT_DELIMITER "
2019-07-25 03:07:28 +08:00
_p9k_prompt_segment " $0 " "blue" " $_p9k_color1 " 'PYTHON_ICON' 0 '' " $msg "
2019-06-01 23:54:53 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_anaconda_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '${CONDA_PREFIX:-$CONDA_ENV_PATH}'
2020-01-26 01:04:06 +08:00
}
2019-06-01 23:54:53 +08:00
################################################################
# AWS Profile
prompt_aws( ) {
2019-10-16 18:03:22 +08:00
local aws_profile = " ${ AWS_VAULT :- ${ AWSUME_PROFILE :- ${ AWS_PROFILE :- $AWS_DEFAULT_PROFILE } } } "
2020-01-28 02:23:56 +08:00
local pat class
for pat class in " ${ _POWERLEVEL9K_AWS_CLASSES [@] } " ; do
if [ [ $aws_profile = = ${ ~pat } ] ] ; then
[ [ -n $class ] ] && state = _${ (U)class }
break
fi
done
_p9k_prompt_segment " $0 $state " red white 'AWS_ICON' 0 '' " ${ aws_profile // \% /%% } "
2019-06-01 23:54:53 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_aws_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '${AWS_VAULT:-${AWSUME_PROFILE:-${AWS_PROFILE:-$AWS_DEFAULT_PROFILE}}}'
2020-01-26 01:04:06 +08:00
}
2019-06-01 23:54:53 +08:00
################################################################
# Current Elastic Beanstalk environment
prompt_aws_eb_env( ) {
2020-01-28 14:39:47 +08:00
_p9k_upglob .elasticbeanstalk && return
2020-01-28 02:23:56 +08:00
local dir = $_p9k__parent_dirs [ $? ]
2019-10-08 22:03:39 +08:00
2019-10-10 01:57:18 +08:00
if ! _p9k_cache_stat_get $0 $dir /.elasticbeanstalk/config.yml; then
2019-10-08 22:03:39 +08:00
local env
env = " $( command eb list 2>/dev/null) " || env =
env = " ${ ${ (@M) ${ (@f)env } : # \* * } # \* } "
2019-10-10 01:57:18 +08:00
_p9k_cache_stat_set " $env "
2019-10-08 22:03:39 +08:00
fi
2020-02-10 19:59:37 +08:00
[ [ -n $_p9k__cache_val [ 1] ] ] || return
_p9k_prompt_segment " $0 " black green 'AWS_EB_ICON' 0 '' " ${ _p9k__cache_val [1]// \% /%% } "
2019-06-01 23:54:53 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_aws_eb_env_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$commands[eb]'
2020-01-26 01:04:06 +08:00
}
2019-06-01 23:54:53 +08:00
################################################################
# Segment to indicate background jobs with an icon.
prompt_background_jobs( ) {
2020-02-12 22:45:23 +08:00
local -i len = $# _p9k__prompt _p9k__has_upglob
2019-06-01 23:54:53 +08:00
local msg
2019-07-23 21:47:25 +08:00
if ( ( _POWERLEVEL9K_BACKGROUND_JOBS_VERBOSE ) ) ; then
if ( ( _POWERLEVEL9K_BACKGROUND_JOBS_VERBOSE_ALWAYS ) ) ; then
2019-06-01 23:54:53 +08:00
msg = '${(%):-%j}'
else
msg = '${${(%):-%j}:#1}'
fi
fi
2019-07-25 03:07:28 +08:00
_p9k_prompt_segment $0 " $_p9k_color1 " cyan BACKGROUND_JOBS_ICON 1 '${${(%):-%j}:#0}' " $msg "
2020-02-12 22:45:23 +08:00
( ( _p9k__has_upglob ) ) || typeset -g " _p9k__segment_val_ ${ _p9k__prompt_side } [_p9k__segment_index] " = $_p9k__prompt [ len+1,-1]
2019-06-01 23:54:53 +08:00
}
################################################################
# Segment that indicates usage level of current partition.
prompt_disk_usage( ) {
2020-02-12 22:45:23 +08:00
local -i len = $# _p9k__prompt _p9k__has_upglob
2020-01-18 22:41:43 +08:00
_p9k_prompt_segment $0 _CRITICAL red white DISK_ICON 1 '$_p9k__disk_usage_critical' '$_p9k__disk_usage_pct%%'
_p9k_prompt_segment $0 _WARNING yellow $_p9k_color1 DISK_ICON 1 '$_p9k__disk_usage_warning' '$_p9k__disk_usage_pct%%'
2020-01-26 01:04:06 +08:00
if ( ( ! _POWERLEVEL9K_DISK_USAGE_ONLY_WARNING ) ) ; then
_p9k_prompt_segment $0 _NORMAL $_p9k_color1 yellow DISK_ICON 1 '$_p9k__disk_usage_normal' '$_p9k__disk_usage_pct%%'
fi
2020-02-12 22:45:23 +08:00
( ( _p9k__has_upglob ) ) || typeset -g " _p9k__segment_val_ ${ _p9k__prompt_side } [_p9k__segment_index] " = $_p9k__prompt [ len+1,-1]
2020-01-18 22:41:43 +08:00
}
_p9k_prompt_disk_usage_init( ) {
typeset -g _p9k__disk_usage_pct =
typeset -g _p9k__disk_usage_normal =
typeset -g _p9k__disk_usage_warning =
typeset -g _p9k__disk_usage_critical =
2020-01-27 22:04:34 +08:00
_p9k__async_segments_compute += '_p9k_prompt_disk_usage_compute ${(q)_p9k__cwd_a}'
2020-01-18 22:41:43 +08:00
}
_p9k_prompt_disk_usage_compute( ) {
2020-01-25 18:01:14 +08:00
( ( $+commands[ df] ) ) || return
_p9k_worker_async " _p9k_prompt_disk_usage_async ${ (q)1 } " _p9k_prompt_disk_usage_sync
2020-01-18 22:41:43 +08:00
}
2020-01-21 06:37:03 +08:00
_p9k_prompt_disk_usage_async( ) {
local pct = ${ ${ = ${ (f) " $( df -P $1 2>/dev/null) " } [2] } [5]%%% }
2020-01-25 18:01:14 +08:00
[ [ $pct = = <0-100> && $pct != $_p9k__disk_usage_pct ] ] || return
2020-01-21 06:37:03 +08:00
_p9k__disk_usage_pct = $pct
2020-01-18 22:41:43 +08:00
_p9k__disk_usage_normal =
_p9k__disk_usage_warning =
_p9k__disk_usage_critical =
if ( ( _p9k__disk_usage_pct >= _POWERLEVEL9K_DISK_USAGE_CRITICAL_LEVEL ) ) ; then
_p9k__disk_usage_critical = 1
elif ( ( _p9k__disk_usage_pct >= _POWERLEVEL9K_DISK_USAGE_WARNING_LEVEL ) ) ; then
_p9k__disk_usage_warning = 1
elif ( ( ! _POWERLEVEL9K_DISK_USAGE_ONLY_WARNING ) ) ; then
_p9k__disk_usage_normal = 1
2019-06-01 23:54:53 +08:00
fi
2020-01-26 21:46:50 +08:00
_p9k_print_params \
2020-01-18 22:41:43 +08:00
_p9k__disk_usage_pct \
_p9k__disk_usage_normal \
_p9k__disk_usage_warning \
_p9k__disk_usage_critical
2020-01-25 18:01:14 +08:00
echo -E - 'reset=1'
}
_p9k_prompt_disk_usage_sync( ) {
eval $REPLY
_p9k_worker_reply $REPLY
2019-06-01 23:54:53 +08:00
}
function _p9k_read_file( ) {
2020-02-10 19:59:37 +08:00
_p9k__ret = ''
[ [ -n $1 ] ] && IFS = '' read -r _p9k__ret <$1
[ [ -n $_p9k__ret ] ]
2019-06-01 23:54:53 +08:00
}
2019-12-06 00:45:30 +08:00
prompt_fvm( ) {
2020-01-28 14:39:47 +08:00
_p9k_upglob fvm && return
2020-01-28 02:23:56 +08:00
local link = $_p9k__parent_dirs [ $? ] /fvm
if [ [ -L $link ] ] ; then
if [ [ ${ link : A } = = ( #b)*/versions/([^/]##)/bin/flutter ]]; then
_p9k_prompt_segment $0 blue $_p9k_color1 FLUTTER_ICON 0 '' ${ match [1]// \% /%% }
2019-12-06 00:45:30 +08:00
fi
2020-01-28 02:23:56 +08:00
fi
2019-12-06 00:45:30 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_fvm_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$commands[fvm]'
2020-01-26 01:04:06 +08:00
}
2019-07-23 21:47:25 +08:00
################################################################
# Segment that displays the battery status in levels and colors
2019-06-01 23:54:53 +08:00
prompt_battery( ) {
2020-01-25 18:01:14 +08:00
[ [ $_p9k_os = = ( Linux| Android) ] ] && _p9k_prompt_battery_set_args
( ( $# _p9k__battery_args ) ) && _p9k_prompt_segment " ${ _p9k__battery_args [@] } "
}
_p9k_prompt_battery_init( ) {
typeset -ga _p9k__battery_args = ( )
2020-01-26 01:04:06 +08:00
if [ [ $_p9k_os = = OSX && $+commands[ pmset] = = 1 ] ] ; then
_p9k__async_segments_compute += _p9k_prompt_battery_compute
return
fi
if [ [ $_p9k_os != ( Linux| Android) || -z /sys/class/power_supply/( BAT*| battery) /( #qFN) ]]; then
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '${:-}'
2020-01-26 01:04:06 +08:00
fi
2020-01-25 18:01:14 +08:00
}
_p9k_prompt_battery_compute( ) {
_p9k_worker_async _p9k_prompt_battery_async _p9k_prompt_battery_sync
}
_p9k_prompt_battery_async( ) {
local prev = " ${ (pj : \0 : )_p9k__battery_args } "
_p9k_prompt_battery_set_args
[ [ " ${ (pj : \0 : )_p9k__battery_args } " = = $prev ] ] && return 1
2020-01-26 21:46:50 +08:00
_p9k_print_params _p9k__battery_args
2020-01-25 18:01:14 +08:00
echo -E - 'reset=2'
}
_p9k_prompt_battery_sync( ) {
eval $REPLY
_p9k_worker_reply $REPLY
}
_p9k_prompt_battery_set_args( ) {
_p9k__battery_args = ( )
2019-06-01 23:54:53 +08:00
local state remain
local -i bat_percent
2019-07-24 20:34:26 +08:00
case $_p9k_os in
2019-06-01 23:54:53 +08:00
OSX)
( ( $+commands[ pmset] ) ) || return
2020-01-26 22:18:25 +08:00
local raw_data = ${ ${ (Af) " $( pmset -g batt 2>/dev/null) " } [2] }
2019-06-01 23:54:53 +08:00
[ [ $raw_data = = *InternalBattery* ] ] || return
remain = ${ ${ (s : : ) ${ ${ (s : ; : )raw_data } [3] } } [1] }
[ [ $remain = = *no* ] ] && remain = "..."
[ [ $raw_data = ~ '([0-9]+)%' ] ] && bat_percent = $match [ 1]
case " ${ ${ (s : ; : )raw_data } [2] } " in
'charging' | 'finishing charge' | 'AC attached' )
2019-09-09 20:48:32 +08:00
if ( ( bat_percent = = 100 ) ) ; then
state = CHARGED
remain = ''
else
state = CHARGING
fi
2019-06-01 23:54:53 +08:00
; ;
'discharging' )
2019-07-23 21:47:25 +08:00
( ( bat_percent < _POWERLEVEL9K_BATTERY_LOW_THRESHOLD ) ) && state = LOW || state = DISCONNECTED
2019-06-01 23:54:53 +08:00
; ;
*)
2019-07-20 21:40:15 +08:00
state = CHARGED
2019-06-01 23:54:53 +08:00
remain = ''
; ;
esac
; ;
Linux| Android)
2020-02-05 16:52:53 +08:00
# See https://sourceforge.net/projects/acpiclient.
2019-06-01 23:54:53 +08:00
local -a bats = ( /sys/class/power_supply/( BAT*| battery) /( FN) )
( ( $# bats ) ) || return
2019-11-14 19:40:28 +08:00
local -i energy_now energy_full power_now
2019-06-01 23:54:53 +08:00
local -i is_full = 1 is_calculating is_charching
local dir
for dir in $bats ; do
2019-06-16 17:28:13 +08:00
local -i pow = 0 full = 0
if _p9k_read_file $dir /( energy_full| charge_full| charge_counter) ( N) ; then
2020-02-10 19:59:37 +08:00
( ( energy_full += ${ full : : =_p9k__ret } ) )
2019-06-16 17:28:13 +08:00
fi
2020-02-10 19:59:37 +08:00
if _p9k_read_file $dir /( power| current) _now( N) && ( ( $# _p9k__ret < 9 ) ) ; then
( ( power_now += ${ pow : : = $_p9k__ret } ) )
2019-06-16 17:28:13 +08:00
fi
if _p9k_read_file $dir /( energy| charge) _now( N) ; then
2020-02-10 19:59:37 +08:00
( ( energy_now += _p9k__ret ) )
2019-06-16 17:28:13 +08:00
elif _p9k_read_file $dir /capacity( N) ; then
2020-02-10 19:59:37 +08:00
( ( energy_now += _p9k__ret * full / 100. + 0.5 ) )
2019-06-16 17:28:13 +08:00
fi
2020-02-10 19:59:37 +08:00
_p9k_read_file $dir /status( N) && local bat_status = $_p9k__ret || continue
2019-06-01 23:54:53 +08:00
[ [ $bat_status != Full ] ] && is_full = 0
[ [ $bat_status = = Charging ] ] && is_charching = 1
[ [ $bat_status = = ( Charging| Discharging) && $pow = = 0 ] ] && is_calculating = 1
done
2019-06-16 17:28:13 +08:00
( ( energy_full ) ) || return
2019-06-16 18:31:07 +08:00
bat_percent = $(( 100 . * energy_now / energy_full + 0 .5 ))
2019-06-16 17:28:13 +08:00
( ( bat_percent > 100 ) ) && bat_percent = 100
2019-06-01 23:54:53 +08:00
2019-07-20 21:40:15 +08:00
if ( ( is_full || ( bat_percent = = 100 && is_charching) ) ) ; then
state = CHARGED
2019-06-01 23:54:53 +08:00
else
if ( ( is_charching ) ) ; then
2019-07-20 21:40:15 +08:00
state = CHARGING
2019-07-23 21:47:25 +08:00
elif ( ( bat_percent < _POWERLEVEL9K_BATTERY_LOW_THRESHOLD ) ) ; then
2019-07-20 21:40:15 +08:00
state = LOW
2019-06-01 23:54:53 +08:00
else
2019-07-20 21:40:15 +08:00
state = DISCONNECTED
2019-06-01 23:54:53 +08:00
fi
if ( ( power_now > 0 ) ) ; then
( ( is_charching ) ) && local -i e = $(( energy_full - energy_now)) || local -i e = energy_now
local -i minutes = $(( 60 * e / power_now ))
( ( minutes > 0 ) ) && remain = $(( minutes/60)) :${ (l#2##0#) $(( minutes%60)) }
elif ( ( is_calculating ) ) ; then
remain = "..."
fi
fi
; ;
*)
2019-11-04 16:07:06 +08:00
return 0
2019-06-01 23:54:53 +08:00
; ;
esac
2019-07-23 21:47:25 +08:00
( ( bat_percent >= _POWERLEVEL9K_BATTERY_HIDE_ABOVE_THRESHOLD ) ) && return
2019-06-01 23:54:53 +08:00
local msg = " $bat_percent %% "
2019-07-23 21:47:25 +08:00
[ [ $_POWERLEVEL9K_BATTERY_VERBOSE = = 1 && -n $remain ] ] && msg += " ( $remain ) "
2019-06-01 23:54:53 +08:00
2019-06-15 22:10:51 +08:00
local icon = BATTERY_ICON
2020-02-03 14:30:45 +08:00
local var = _POWERLEVEL9K_BATTERY_${ state } _STAGES
local -i idx = " ${# ${ (@P)var } } "
if ( ( idx ) ) ; then
( ( bat_percent < 100 ) ) && idx = $(( bat_percent * idx / 100 + 1 ))
icon = $'\1' " ${ ${ (@P)var } [idx] } "
2019-06-15 22:10:51 +08:00
fi
2019-07-24 20:34:26 +08:00
local bg = $_p9k_color1
2020-02-03 14:30:45 +08:00
local var = _POWERLEVEL9K_BATTERY_${ state } _LEVEL_BACKGROUND
local -i idx = " ${# ${ (@P)var } } "
if ( ( idx ) ) ; then
( ( bat_percent < 100 ) ) && idx = $(( bat_percent * idx / 100 + 1 ))
bg = " ${ ${ (@P)var } [idx] } "
2019-06-01 23:54:53 +08:00
fi
2019-10-11 16:33:49 +08:00
local fg = $_p9k_battery_states [ $state ]
2020-02-03 14:30:45 +08:00
local var = _POWERLEVEL9K_BATTERY_${ state } _LEVEL_FOREGROUND
local -i idx = " ${# ${ (@P)var } } "
if ( ( idx ) ) ; then
( ( bat_percent < 100 ) ) && idx = $(( bat_percent * idx / 100 + 1 ))
fg = " ${ ${ (@P)var } [idx] } "
2019-10-11 16:33:49 +08:00
fi
2020-01-25 18:01:14 +08:00
_p9k__battery_args = ( prompt_battery_$state " $bg " " $fg " $icon 0 '' $msg )
2019-06-01 23:54:53 +08:00
}
################################################################
# Public IP segment
prompt_public_ip( ) {
2020-02-12 22:45:23 +08:00
local -i len = $# _p9k__prompt _p9k__has_upglob
2020-01-18 22:41:43 +08:00
local ip = '${_p9k__public_ip:-$_POWERLEVEL9K_PUBLIC_IP_NONE}'
2019-07-23 21:47:25 +08:00
if [ [ -n $_POWERLEVEL9K_PUBLIC_IP_VPN_INTERFACE ] ] ; then
2020-01-18 22:41:43 +08:00
_p9k_prompt_segment " $0 " " $_p9k_color1 " " $_p9k_color2 " PUBLIC_IP_ICON 1 '${_p9k__public_ip_not_vpn:+' $ip '}' $ip
_p9k_prompt_segment " $0 " " $_p9k_color1 " " $_p9k_color2 " VPN_ICON 1 '${_p9k__public_ip_vpn:+' $ip '}' $ip
else
_p9k_prompt_segment " $0 " " $_p9k_color1 " " $_p9k_color2 " PUBLIC_IP_ICON 1 $ip $ip
2019-06-01 23:54:53 +08:00
fi
2020-02-12 22:45:23 +08:00
( ( _p9k__has_upglob ) ) || typeset -g " _p9k__segment_val_ ${ _p9k__prompt_side } [_p9k__segment_index] " = $_p9k__prompt [ len+1,-1]
2020-01-18 22:41:43 +08:00
}
2019-06-01 23:54:53 +08:00
2020-01-18 22:41:43 +08:00
_p9k_prompt_public_ip_init( ) {
typeset -g _p9k__public_ip =
typeset -gF _p9k__public_ip_next_time = 0
2020-01-25 18:01:14 +08:00
_p9k__async_segments_compute += _p9k_prompt_public_ip_compute
2020-01-18 22:41:43 +08:00
}
2020-01-25 18:01:14 +08:00
_p9k_prompt_public_ip_compute( ) {
( ( EPOCHREALTIME >= _p9k__public_ip_next_time ) ) || return
_p9k_worker_async _p9k_prompt_public_ip_async _p9k_prompt_public_ip_sync
2020-01-18 22:41:43 +08:00
}
_p9k_prompt_public_ip_async( ) {
local ip method
local -F start = EPOCHREALTIME
local -F next = 'start + 5'
for method in $_POWERLEVEL9K_PUBLIC_IP_METHODS $_POWERLEVEL9K_PUBLIC_IP_METHODS ; do
case $method in
dig)
if ( ( $+commands[ dig] ) ) ; then
ip = " $( dig +tries= 1 +short -4 A myip.opendns.com @resolver1.opendns.com 2>/dev/null) "
[ [ $ip = = ';' * ] ] && ip =
if [ [ -z $ip ] ] ; then
ip = " $( dig +tries= 1 +short -6 AAAA myip.opendns.com @resolver1.opendns.com 2>/dev/null) "
[ [ $ip = = ';' * ] ] && ip =
fi
fi
; ;
curl)
if ( ( $+commands[ curl] ) ) ; then
2020-01-26 21:46:50 +08:00
ip = " $( curl --max-time 5 -w '\n' " $_POWERLEVEL9K_PUBLIC_IP_HOST " 2>/dev/null) "
2020-01-18 22:41:43 +08:00
fi
; ;
wget)
if ( ( $+commands[ wget] ) ) ; then
2020-01-26 21:46:50 +08:00
ip = " $( wget -T 5 -qO- " $_POWERLEVEL9K_PUBLIC_IP_HOST " 2>/dev/null) "
2020-01-18 22:41:43 +08:00
fi
; ;
esac
[ [ $ip = ~ '^[0-9a-f.:]+$' ] ] || ip = ''
if [ [ -n $ip ] ] ; then
next = $(( start + _POWERLEVEL9K_PUBLIC_IP_TIMEOUT))
break
fi
done
2020-01-21 06:37:03 +08:00
_p9k__public_ip_next_time = $next
2020-01-26 21:46:50 +08:00
_p9k_print_params _p9k__public_ip_next_time
2020-01-25 18:01:14 +08:00
[ [ $_p9k__public_ip = = $ip ] ] && return
_p9k__public_ip = $ip
2020-01-26 21:46:50 +08:00
_p9k_print_params _p9k__public_ip
2020-01-25 18:01:14 +08:00
echo -E - 'reset=1'
2020-01-18 22:41:43 +08:00
}
_p9k_prompt_public_ip_sync( ) {
2020-01-25 18:01:14 +08:00
eval $REPLY
_p9k_worker_reply $REPLY
2019-06-01 23:54:53 +08:00
}
################################################################
# Context: user@hostname (who am I and where am I)
prompt_context( ) {
2020-02-12 22:45:23 +08:00
local -i len = $# _p9k__prompt _p9k__has_upglob
2020-01-26 01:04:06 +08:00
local content
if [ [ $_POWERLEVEL9K_ALWAYS_SHOW_CONTEXT = = 0 && -n $DEFAULT_USER && $P9K_SSH = = 0 ] ] ; then
local user = " ${ (%) :- %n } "
if [ [ $user = = $DEFAULT_USER ] ] ; then
content = " ${ user // \% /%% } "
2019-06-01 23:54:53 +08:00
fi
2020-01-26 01:04:06 +08:00
fi
2019-06-01 23:54:53 +08:00
2020-01-26 01:04:06 +08:00
local state
if ( ( P9K_SSH ) ) ; then
if [ [ -n " $SUDO_COMMAND " ] ] ; then
state = "REMOTE_SUDO"
else
state = "REMOTE"
fi
elif [ [ -n " $SUDO_COMMAND " ] ] ; then
state = "SUDO"
else
state = "DEFAULT"
fi
2019-07-29 20:36:21 +08:00
2020-01-26 01:04:06 +08:00
local cond
for state cond in $state '${${(%):-%#}:#\#}' ROOT '${${(%):-%#}:#\%}' ; do
local text = $content
if [ [ -z $text ] ] ; then
local var = _POWERLEVEL9K_CONTEXT_${ state } _TEMPLATE
if ( ( $+parameters[ $var ] ) ) ; then
text = ${ (P)var }
text = ${ (g : : )text }
else
text = $_POWERLEVEL9K_CONTEXT_TEMPLATE
2019-07-29 20:36:21 +08:00
fi
2019-06-01 23:54:53 +08:00
fi
2020-01-26 01:04:06 +08:00
_p9k_prompt_segment " $0 _ $state " " $_p9k_color1 " yellow '' 0 " $cond " " $text "
done
2019-07-07 17:49:58 +08:00
2020-02-12 22:45:23 +08:00
( ( _p9k__has_upglob ) ) || typeset -g " _p9k__segment_val_ ${ _p9k__prompt_side } [_p9k__segment_index] " = $_p9k__prompt [ len+1,-1]
2020-01-26 01:04:06 +08:00
}
2019-06-01 23:54:53 +08:00
2020-01-26 01:04:06 +08:00
instant_prompt_context( ) {
if [ [ $_POWERLEVEL9K_ALWAYS_SHOW_CONTEXT = = 0 && -n $DEFAULT_USER && $P9K_SSH = = 0 ] ] ; then
if [ [ ${ (%) :- %n } = = $DEFAULT_USER ] ] ; then
if ( ( ! _POWERLEVEL9K_ALWAYS_SHOW_USER ) ) ; then
return
fi
fi
fi
prompt_context
2019-06-01 23:54:53 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_context_init( ) {
if [ [ $_POWERLEVEL9K_ALWAYS_SHOW_CONTEXT = = 0 && -n $DEFAULT_USER && $P9K_SSH = = 0 ] ] ; then
if [ [ ${ (%) :- %n } = = $DEFAULT_USER ] ] ; then
if ( ( ! _POWERLEVEL9K_ALWAYS_SHOW_USER ) ) ; then
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '${:-}'
2020-01-26 01:04:06 +08:00
fi
fi
fi
}
2019-10-16 23:36:54 +08:00
2019-06-01 23:54:53 +08:00
################################################################
# User: user (who am I)
prompt_user( ) {
2020-02-12 22:45:23 +08:00
local -i len = $# _p9k__prompt _p9k__has_upglob
2020-01-26 01:04:06 +08:00
_p9k_prompt_segment " ${ 0 } _ROOT " " ${ _p9k_color1 } " yellow ROOT_ICON 0 '${${(%):-%#}:#\%}' " $_POWERLEVEL9K_USER_TEMPLATE "
if [ [ -n " $SUDO_COMMAND " ] ] ; then
_p9k_prompt_segment " ${ 0 } _SUDO " " ${ _p9k_color1 } " yellow SUDO_ICON 0 '${${(%):-%#}:#\#}' " $_POWERLEVEL9K_USER_TEMPLATE "
else
_p9k_prompt_segment " ${ 0 } _DEFAULT " " ${ _p9k_color1 } " yellow USER_ICON 0 '${${(%):-%#}:#\#}' "%n"
2019-06-01 23:54:53 +08:00
fi
2020-02-12 22:45:23 +08:00
( ( _p9k__has_upglob ) ) || typeset -g " _p9k__segment_val_ ${ _p9k__prompt_side } [_p9k__segment_index] " = $_p9k__prompt [ len+1,-1]
2019-06-01 23:54:53 +08:00
}
2020-01-26 01:04:06 +08:00
instant_prompt_user( ) {
if [ [ $_POWERLEVEL9K_ALWAYS_SHOW_USER = = 0 && " ${ (%) :- %n } " = = $DEFAULT_USER ] ] ; then
return
fi
prompt_user
}
_p9k_prompt_user_init( ) {
if [ [ $_POWERLEVEL9K_ALWAYS_SHOW_USER = = 0 && " ${ (%) :- %n } " = = $DEFAULT_USER ] ] ; then
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '${:-}'
2020-01-26 01:04:06 +08:00
fi
}
2019-10-16 23:36:54 +08:00
2019-06-01 23:54:53 +08:00
################################################################
# Host: machine (where am I)
prompt_host( ) {
2020-02-12 22:45:23 +08:00
local -i len = $# _p9k__prompt _p9k__has_upglob
2019-08-20 17:19:11 +08:00
if ( ( P9K_SSH ) ) ; then
2019-07-25 03:07:28 +08:00
_p9k_prompt_segment " $0 _REMOTE " " ${ _p9k_color1 } " yellow SSH_ICON 0 '' " $_POWERLEVEL9K_HOST_TEMPLATE "
2019-06-01 23:54:53 +08:00
else
2019-07-25 03:07:28 +08:00
_p9k_prompt_segment " $0 _LOCAL " " ${ _p9k_color1 } " yellow HOST_ICON 0 '' " $_POWERLEVEL9K_HOST_TEMPLATE "
2019-06-01 23:54:53 +08:00
fi
2020-02-12 22:45:23 +08:00
( ( _p9k__has_upglob ) ) || typeset -g " _p9k__segment_val_ ${ _p9k__prompt_side } [_p9k__segment_index] " = $_p9k__prompt [ len+1,-1]
2019-06-01 23:54:53 +08:00
}
2019-10-16 23:36:54 +08:00
instant_prompt_host( ) { prompt_host; }
2019-06-01 23:54:53 +08:00
################################################################
# The 'custom` prompt provides a way for users to invoke commands and display
# the output in a segment.
2019-07-25 03:07:28 +08:00
_p9k_custom_prompt( ) {
local segment_name = ${ 1 : u }
2019-11-06 17:22:51 +08:00
local command = _POWERLEVEL9K_CUSTOM_${ segment_name }
2019-08-24 18:58:55 +08:00
command = ${ (P)command }
2019-08-27 14:53:28 +08:00
local cmd = " ${ (Q) ${ (Az)command } [1] } "
2019-08-24 18:58:55 +08:00
( ( $+functions[ $cmd ] || $+commands[ $cmd ] ) ) || return
local content = " $( eval $command ) "
2019-06-01 23:54:53 +08:00
[ [ -n $content ] ] || return
2020-02-12 18:16:03 +08:00
_p9k_prompt_segment " prompt_custom_ $1 " $_p9k_color2 $_p9k_color1 " CUSTOM_ ${ segment_name } _ICON " 0 '' " $content "
2019-06-01 23:54:53 +08:00
}
################################################################
# Display the duration the command needed to run.
prompt_command_execution_time( ) {
2019-08-17 02:26:28 +08:00
( ( $+P9K_COMMAND_DURATION_SECONDS ) ) || return
2019-07-25 00:34:29 +08:00
( ( P9K_COMMAND_DURATION_SECONDS >= _POWERLEVEL9K_COMMAND_EXECUTION_TIME_THRESHOLD ) ) || return
2019-06-14 18:26:40 +08:00
2019-07-20 18:41:52 +08:00
if ( ( P9K_COMMAND_DURATION_SECONDS < 60 ) ) ; then
2019-07-23 21:47:25 +08:00
if ( ( !_POWERLEVEL9K_COMMAND_EXECUTION_TIME_PRECISION ) ) ; then
2019-07-20 18:41:52 +08:00
local -i sec = $(( P9K_COMMAND_DURATION_SECONDS + 0 .5))
2019-07-17 02:35:18 +08:00
else
2019-07-23 21:47:25 +08:00
local -F $_POWERLEVEL9K_COMMAND_EXECUTION_TIME_PRECISION sec = P9K_COMMAND_DURATION_SECONDS
2019-07-20 18:41:52 +08:00
fi
local text = ${ sec } s
else
local -i d = $(( P9K_COMMAND_DURATION_SECONDS + 0 .5))
2019-07-23 21:47:25 +08:00
if [ [ $_POWERLEVEL9K_COMMAND_EXECUTION_TIME_FORMAT = = "H:M:S" ] ] ; then
2019-07-17 02:35:18 +08:00
local text = ${ (l.2..0.) $(( d % 60 )) }
if ( ( d >= 60 ) ) ; then
text = ${ (l.2..0.) $(( d / 60 % 60 )) } :$text
if ( ( d >= 36000 ) ) ; then
text = $(( d / 3600 )) :$text
elif ( ( d >= 3600 ) ) ; then
text = 0$(( d / 3600 )) :$text
fi
2019-06-14 18:26:40 +08:00
fi
2019-07-20 18:41:52 +08:00
else
local text = " $(( d % 60 )) s "
if ( ( d >= 60 ) ) ; then
text = " $(( d / 60 % 60 )) m $text "
if ( ( d >= 3600 ) ) ; then
text = " $(( d / 3600 % 24 )) h $text "
if ( ( d >= 86400 ) ) ; then
text = " $(( d / 86400 )) d $text "
fi
fi
fi
2019-06-01 23:54:53 +08:00
fi
fi
2019-07-25 03:07:28 +08:00
_p9k_prompt_segment " $0 " "red" "yellow1" 'EXECUTION_TIME_ICON' 0 '' $text
2019-06-01 23:54:53 +08:00
}
function _p9k_shorten_delim_len( ) {
local def = $1
2020-02-10 19:59:37 +08:00
_p9k__ret = ${ _POWERLEVEL9K_SHORTEN_DELIMITER_LENGTH :- -1 }
( ( _p9k__ret >= 0 ) ) || _p9k_prompt_length $1
2019-06-01 23:54:53 +08:00
}
################################################################
# Dir: current working directory
prompt_dir( ) {
2019-09-04 14:40:24 +08:00
if ( ( _POWERLEVEL9K_DIR_PATH_ABSOLUTE ) ) ; then
2020-01-27 22:04:34 +08:00
local p = $_p9k__cwd
2019-09-04 14:40:24 +08:00
local -a parts = ( " ${ (s : / : )p } " )
elif [ [ -o auto_name_dirs ] ] ; then
2020-01-27 22:04:34 +08:00
local p = ${ _p9k__cwd /#(#b) $HOME (| \/ *)/ '~' $match [1] }
2019-09-04 14:40:24 +08:00
local -a parts = ( " ${ (s : / : )p } " )
else
local p = ${ (%) :- %~ }
if [ [ $p = = '~[' * ] ] ; then
# If "${(%):-%~}" expands to "~[a]/]/b", is the first component "~[a]" or "~[a]/]"?
# One would expect "${(%):-%-1~}" to give the right answer but alas it always simply
# gives the segment before the first slash, which would be "~[a]" in this case. Worse,
# for "~[a/b]" it'll give the nonsensical "~[a". To solve this problem we have to
# repeat what "${(%):-%~}" does and hope that it produces the same result.
local func = ''
2020-01-26 23:54:52 +08:00
local -a parts = ( )
2019-09-04 14:40:24 +08:00
for func in zsh_directory_name $zsh_directory_name_functions ; do
2020-01-26 23:54:52 +08:00
local reply = ( )
2020-01-27 22:04:34 +08:00
if ( ( $+functions[ $func ] ) ) && $func d $_p9k__cwd && [ [ $p = = '~[' $reply [ 1] ']' * ] ] ; then
2019-09-04 14:40:24 +08:00
parts += '~[' $reply [ 1] ']'
break
fi
done
if ( ( $# parts ) ) ; then
parts += ( ${ (s : / : ) ${ p # $parts [1] } } )
else
2020-01-27 22:04:34 +08:00
p = $_p9k__cwd
2019-09-04 14:40:24 +08:00
parts = ( " ${ (s : / : )p } " )
2019-06-01 23:54:53 +08:00
fi
else
2019-09-04 14:40:24 +08:00
local -a parts = ( " ${ (s : / : )p } " )
2019-06-01 23:54:53 +08:00
fi
fi
2019-07-18 18:21:54 +08:00
local -i fake_first = 0 expand = 0
2019-07-23 21:47:25 +08:00
local delim = ${ _POWERLEVEL9K_SHORTEN_DELIMITER - $'\u2026' }
local -i shortenlen = ${ _POWERLEVEL9K_SHORTEN_DIR_LENGTH :- -1 }
2019-06-01 23:54:53 +08:00
2019-07-23 21:47:25 +08:00
case $_POWERLEVEL9K_SHORTEN_STRATEGY in
2019-06-01 23:54:53 +08:00
truncate_absolute| truncate_absolute_chars)
if ( ( shortenlen > 0 && $# p > shortenlen ) ) ; then
_p9k_shorten_delim_len $delim
2020-02-10 19:59:37 +08:00
if ( ( $# p > shortenlen + $_p9k__ret ) ) ; then
2019-06-01 23:54:53 +08:00
local -i n = shortenlen
local -i i = $# parts
while true; do
local dir = $parts [ i]
local -i len = $(( $# dir + ( i > 1 ) ))
if ( ( len <= n ) ) ; then
( ( n -= len ) )
( ( --i ) )
else
2019-07-04 23:40:54 +08:00
parts[ i] = $'\1' $dir [ -n,-1]
2019-06-01 23:54:53 +08:00
parts[ 1,i-1] = ( )
break
fi
done
fi
fi
; ;
truncate_with_package_name| truncate_middle| truncate_from_right)
( ) {
2019-07-23 21:47:25 +08:00
[ [ $_POWERLEVEL9K_SHORTEN_STRATEGY = = truncate_with_package_name &&
$+commands[ jq] = = 1 && $# _POWERLEVEL9K_DIR_PACKAGE_FILES > 0 ] ] || return
2019-08-29 01:32:10 +08:00
local pats = " ( ${ (j : | : )_POWERLEVEL9K_DIR_PACKAGE_FILES } ) "
2019-06-01 23:54:53 +08:00
local -i i = $# parts
2020-01-27 22:04:34 +08:00
local dir = $_p9k__cwd
2019-06-01 23:54:53 +08:00
for ( ( ; i > 0; --i ) ) ; do
2019-08-29 01:32:10 +08:00
local markers = ( $dir /${ ~pats } ( N) )
if ( ( $# markers ) ) ; then
local pat = pkg_file =
for pat in $_POWERLEVEL9K_DIR_PACKAGE_FILES ; do
for pkg_file in $markers ; do
[ [ $pkg_file = = $dir /${ ~pat } ] ] || continue
2019-10-10 01:57:18 +08:00
if ! _p9k_cache_stat_get $0 _pkg $pkg_file ; then
2019-08-29 01:32:10 +08:00
local pkg_name = ''
pkg_name = " $( jq -j '.name | select(. != null)' <$pkg_file 2>/dev/null) " || pkg_name = ''
2019-10-10 01:57:18 +08:00
_p9k_cache_stat_set " $pkg_name "
2019-08-29 01:32:10 +08:00
fi
2020-02-10 19:59:37 +08:00
[ [ -n $_p9k__cache_val [ 1] ] ] || continue
parts[ 1,i] = ( $_p9k__cache_val [ 1] )
2019-08-29 01:32:10 +08:00
fake_first = 1
2019-11-04 16:07:06 +08:00
return 0
2019-08-29 01:32:10 +08:00
done
done
fi
2019-06-01 23:54:53 +08:00
dir = ${ dir : h }
done
}
if ( ( shortenlen > 0 ) ) ; then
_p9k_shorten_delim_len $delim
2020-02-10 19:59:37 +08:00
local -i d = _p9k__ret pref = shortenlen suf = 0 i = 2
2019-07-23 21:47:25 +08:00
[ [ $_POWERLEVEL9K_SHORTEN_STRATEGY = = truncate_middle ] ] && suf = pref
2019-06-01 23:54:53 +08:00
for ( ( ; i < $# parts; ++i ) ) ; do
local dir = $parts [ i]
if ( ( $# dir > pref + suf + d ) ) ; then
2019-07-04 23:40:54 +08:00
dir[ pref+1,-suf-1] = $'\1'
2019-06-01 23:54:53 +08:00
parts[ i] = $dir
fi
done
fi
; ;
truncate_to_last)
2020-02-16 00:51:26 +08:00
if [ [ $# parts -gt 2 || $p [ 1] != / && $# parts -gt 1 ] ] ; then
fake_first = 1
parts[ 1,-2] = ( )
fi
2019-06-01 23:54:53 +08:00
; ;
truncate_to_first_and_last)
if ( ( shortenlen > 0 ) ) ; then
local -i i = $(( shortenlen + 1 ))
[ [ $p = = /* ] ] && ( ( ++i ) )
for ( ( ; i <= $# parts - shortenlen; ++i ) ) ; do
2019-07-04 23:40:54 +08:00
parts[ i] = $'\1'
2019-06-01 23:54:53 +08:00
done
fi
; ;
truncate_to_unique)
2019-07-18 18:21:54 +08:00
expand = 1
2019-07-23 21:47:25 +08:00
delim = ${ _POWERLEVEL9K_SHORTEN_DELIMITER - '*' }
2019-10-28 22:54:53 +08:00
shortenlen = ${ _POWERLEVEL9K_SHORTEN_DIR_LENGTH :- 1 }
( ( shortenlen >= 0 ) ) || shortenlen = 1
local -i i = 2 e = $(( $# parts - shortenlen))
2020-01-23 22:25:13 +08:00
if ( ( _POWERLEVEL9K_DIR_TRUNCATE_BEFORE_MARKER ) ) ; then
( ( e += shortenlen ) )
local orig = ( " $parts [2] " " ${ (@)parts[ $(( shortenlen > $# parts ? - $# parts : - shortenlen)) ,-1] } " )
elif [ [ $p [ 1] = = / ] ] ; then
( ( ++i ) )
fi
2019-10-28 22:54:53 +08:00
if ( ( i <= e ) ) ; then
2020-01-28 18:09:51 +08:00
local mtimes = ( ${ (Oa)_p9k__parent_mtimes : $(( $# parts-e)) : $(( e-i+1)) } )
2019-10-29 00:54:50 +08:00
local key = " ${ (pj. : .)mtimes } "
2019-07-19 20:19:24 +08:00
else
2020-01-28 18:09:51 +08:00
local key =
2019-07-19 20:19:24 +08:00
fi
2020-02-10 19:59:37 +08:00
if ! _p9k_cache_ephemeral_get $0 $e $i $_p9k__cwd || [ [ $key != $_p9k__cache_val [ 1] ] ] ; then
2020-01-28 18:41:49 +08:00
local tail = ${ (j./.)parts[i,-1] }
local parent = $_p9k__cwd [ 1,-2-$# tail]
2019-07-19 20:19:24 +08:00
_p9k_prompt_length $delim
2020-02-10 19:59:37 +08:00
local -i real_delim_len = _p9k__ret
2019-07-19 20:19:24 +08:00
[ [ -n $parts [ i-1] ] ] && parts[ i-1] = " \${(Q)\${:- ${ (qqq) ${ (q)parts[i-1] } } }} " $'\2'
2019-07-23 21:47:25 +08:00
local -i d = ${ _POWERLEVEL9K_SHORTEN_DELIMITER_LENGTH :- -1 }
2019-07-19 20:19:24 +08:00
( ( d >= 0 ) ) || d = real_delim_len
2019-10-29 00:54:50 +08:00
local -i m = 1
for ( ( ; i <= e; ++i, ++m ) ) ; do
local sub = $parts [ i]
local dir = $parent /$sub mtime = $mtimes [ m]
local pair = $_p9k__dir_stat_cache [ $dir ]
if [ [ $pair = = ${ mtime :- x } :* ] ] ; then
parts[ i] = ${ pair #* : }
else
2020-01-02 01:07:40 +08:00
[ [ $sub != *[ "~!#\`\$^&*()\\\"'<>?{}[]" ] * ] ]
2019-10-29 00:54:50 +08:00
local -i q = $?
if [ [ -n $_POWERLEVEL9K_SHORTEN_FOLDER_MARKER &&
-n $parent /$sub /${ ~_POWERLEVEL9K_SHORTEN_FOLDER_MARKER } ( #qN) ]]; then
( ( q ) ) && parts[ i] = " \${(Q)\${:- ${ (qqq) ${ (q)sub } } }} "
parts[ i] += $'\2'
2019-07-19 20:19:24 +08:00
else
2019-10-29 00:54:50 +08:00
local -i j = 1
for ( ( ; j + d < $# sub; ++j ) ) ; do
local -a matching = ( $parent /$sub [ 1,j] */( N) )
( ( $# matching = = 1 ) ) && break
done
local -i saved = $(( $# sub - j - d))
if ( ( saved > 0 ) ) ; then
if ( ( q ) ) ; then
2020-02-10 19:59:37 +08:00
parts[ i] = '${${${_p9k__d:#-*}:+${(Q)${:-' ${ (qqq) ${ (q)sub } } '}}}:-${(Q)${:-'
parts[ i] += $'\3' ${ (qqq) ${ (q)sub[1,j] } } $'}}\1\3' '${$((_p9k__d+=' $saved '))+}}'
2019-10-29 00:54:50 +08:00
else
2020-02-10 19:59:37 +08:00
parts[ i] = '${${${_p9k__d:#-*}:+' $sub $'}:-\3' $sub [ 1,j] $'\1\3' '${$((_p9k__d+=' $saved '))+}}'
2019-10-29 00:54:50 +08:00
fi
else
( ( q ) ) && parts[ i] = " \${(Q)\${:- ${ (qqq) ${ (q)sub } } }} "
fi
2019-07-19 20:19:24 +08:00
fi
2019-10-29 00:54:50 +08:00
[ [ -n $mtime ] ] && _p9k__dir_stat_cache[ $dir ] = " $mtime : $parts [i] "
2019-07-19 20:19:24 +08:00
fi
2019-10-29 00:54:50 +08:00
parent += /$sub
2019-07-19 20:19:24 +08:00
done
2020-01-23 22:25:13 +08:00
if ( ( _POWERLEVEL9K_DIR_TRUNCATE_BEFORE_MARKER ) ) ; then
local _2 = $'\2'
( ( e = ${ parts [(I)* $_2 ] } ) )
if ( ( e > 1 ) ) ; then
parts[ 1,e-1] = ( )
fake_first = 1
elif [ [ $p = = /?* ] ] ; then
parts[ 2] = " \${(Q)\${:- ${ (qqq) ${ (q)orig[1] } } }} " $'\2'
fi
for ( ( i = $# parts < shortenlen ? $# parts : shortenlen; i > 0; --i) ) ; do
[ [ $# parts[ -i] = = *$'\2' ] ] && continue
if [ [ $orig [ -i] = = *[ "~!#\`\$^&*()\\\"'<>?{}[]" ] * ] ] ; then
parts[ -i] = '${(Q)${:-' ${ (qqq) ${ (q)orig[-i] } } '}}' $'\2'
else
parts[ -i] = ${ orig [-i] } $'\2'
fi
done
else
for ( ( ; i <= $# parts; ++i) ) ; do
[ [ $parts [ i] = = *[ "~!#\`\$^&*()\\\"'<>?{}[]" ] * ] ] && parts[ i] = '${(Q)${:-' ${ (qqq) ${ (q)parts[i] } } '}}'
parts[ i] += $'\2'
done
fi
2020-01-28 18:09:51 +08:00
_p9k_cache_ephemeral_set " $key " " ${ parts [@] } "
2019-07-19 20:19:24 +08:00
fi
2020-02-10 19:59:37 +08:00
parts = ( " ${ (@)_p9k__cache_val[2,-1] } " )
2019-06-01 23:54:53 +08:00
; ;
truncate_with_folder_marker)
2019-07-23 21:47:25 +08:00
if [ [ -n $_POWERLEVEL9K_SHORTEN_FOLDER_MARKER ] ] ; then
2020-01-27 22:04:34 +08:00
local dir = $_p9k__cwd
2019-06-01 23:54:53 +08:00
local -a m = ( )
local -i i = $(( $# parts - 1 ))
for ( ( ; i > 1; --i ) ) ; do
dir = ${ dir : h }
2019-07-23 21:47:25 +08:00
[ [ -n $dir /${ ~_POWERLEVEL9K_SHORTEN_FOLDER_MARKER } ( #qN) ]] && m+=$i
2019-06-01 23:54:53 +08:00
done
m += 1
for ( ( i = 1; i < $# m; ++i ) ) ; do
2019-07-04 23:40:54 +08:00
( ( m[ i] - m[ i+1] > 2 ) ) && parts[ m[ i+1] +1,m[ i] -1] = ( $'\1' )
2019-06-01 23:54:53 +08:00
done
fi
; ;
*)
if ( ( shortenlen > 0 ) ) ; then
local -i len = $# parts
[ [ -z $parts [ 1] ] ] && ( ( --len ) )
if ( ( len > shortenlen ) ) ; then
2019-07-04 23:40:54 +08:00
parts[ 1,-shortenlen-1] = ( $'\1' )
2019-06-01 23:54:53 +08:00
fi
fi
; ;
esac
2020-01-27 22:04:34 +08:00
[ [ $_POWERLEVEL9K_DIR_SHOW_WRITABLE = = 1 && ! -w $_p9k__cwd ] ]
2019-06-06 02:11:03 +08:00
local w = $?
2020-01-27 22:04:34 +08:00
if ! _p9k_cache_ephemeral_get $0 $_p9k__cwd $p $w $fake_first " ${ parts [@] } " ; then
2019-07-02 02:20:59 +08:00
local state = $0
local icon = ''
2019-06-06 02:11:03 +08:00
if ( ( ! w ) ) ; then
2019-07-02 02:20:59 +08:00
state += _NOT_WRITABLE
2019-06-06 02:11:03 +08:00
icon = LOCK_ICON
else
2019-07-02 02:20:59 +08:00
local a = '' b = '' c = ''
2019-07-23 21:47:25 +08:00
for a b c in " ${ _POWERLEVEL9K_DIR_CLASSES [@] } " ; do
2020-01-27 22:04:34 +08:00
if [ [ $_p9k__cwd = = ${ ~a } ] ] ; then
2019-07-02 02:20:59 +08:00
[ [ -n $b ] ] && state += _${ (U)b }
icon = $'\1' $c
break
fi
done
2019-06-06 02:11:03 +08:00
fi
2019-07-02 02:20:59 +08:00
2019-06-06 02:11:03 +08:00
local style = %b
2019-07-09 18:40:31 +08:00
_p9k_color $state BACKGROUND blue
2020-02-10 19:59:37 +08:00
_p9k_background $_p9k__ret
style += $_p9k__ret
2019-07-24 20:34:26 +08:00
_p9k_color $state FOREGROUND " $_p9k_color1 "
2020-02-10 19:59:37 +08:00
_p9k_foreground $_p9k__ret
style += $_p9k__ret
2019-07-18 18:21:54 +08:00
if ( ( expand ) ) ; then
2019-07-25 05:05:41 +08:00
_p9k_escape_style $style
2020-02-10 19:59:37 +08:00
style = $_p9k__ret
2019-07-18 18:21:54 +08:00
fi
2019-06-06 02:11:03 +08:00
2019-06-20 19:34:20 +08:00
parts = ( " ${ (@)parts// \% /%% } " )
2019-07-23 21:47:25 +08:00
if [ [ $_POWERLEVEL9K_HOME_FOLDER_ABBREVIATION != '~' && $fake_first = = 0 && $p = = ( '~' | '~/' *) ] ] ; then
2020-02-10 19:59:37 +08:00
( ( expand ) ) && _p9k_escape $_POWERLEVEL9K_HOME_FOLDER_ABBREVIATION || _p9k__ret = $_POWERLEVEL9K_HOME_FOLDER_ABBREVIATION
parts[ 1] = $_p9k__ret
[ [ $_p9k__ret = = *%* ] ] && parts[ 1] += $style
2019-07-18 18:21:54 +08:00
fi
2019-07-23 21:47:25 +08:00
[ [ $_POWERLEVEL9K_DIR_OMIT_FIRST_CHARACTER = = 1 && $# parts > 1 && -n $parts [ 2] ] ] && parts[ 1] = ( )
2019-06-06 02:11:03 +08:00
2019-07-18 20:20:04 +08:00
local last_style =
2019-07-23 21:47:25 +08:00
( ( _POWERLEVEL9K_DIR_PATH_HIGHLIGHT_BOLD ) ) && last_style += %B
if ( ( $+_POWERLEVEL9K_DIR_PATH_HIGHLIGHT_FOREGROUND ) ) ; then
_p9k_translate_color $_POWERLEVEL9K_DIR_PATH_HIGHLIGHT_FOREGROUND
2020-02-10 19:59:37 +08:00
_p9k_foreground $_p9k__ret
last_style += $_p9k__ret
2019-06-06 02:11:03 +08:00
fi
2019-07-18 20:20:04 +08:00
if [ [ -n $last_style ] ] ; then
2020-02-10 19:59:37 +08:00
( ( expand ) ) && _p9k_escape_style $last_style || _p9k__ret = $last_style
parts[ -1] = $_p9k__ret ${ parts [-1]// $'\1' / $'\1' $_p9k__ret } $style
2019-07-18 18:21:54 +08:00
fi
2019-07-18 20:20:04 +08:00
local anchor_style =
2019-07-23 21:47:25 +08:00
( ( _POWERLEVEL9K_DIR_ANCHOR_BOLD ) ) && anchor_style += %B
if ( ( $+_POWERLEVEL9K_DIR_ANCHOR_FOREGROUND ) ) ; then
_p9k_translate_color $_POWERLEVEL9K_DIR_ANCHOR_FOREGROUND
2020-02-10 19:59:37 +08:00
_p9k_foreground $_p9k__ret
anchor_style += $_p9k__ret
2019-07-18 20:20:04 +08:00
fi
if [ [ -n $anchor_style ] ] ; then
2020-02-10 19:59:37 +08:00
( ( expand ) ) && _p9k_escape_style $anchor_style || _p9k__ret = $anchor_style
2019-07-18 20:20:04 +08:00
if [ [ -z $last_style ] ] ; then
2020-02-10 19:59:37 +08:00
parts = ( " ${ (@)parts/%(#b)(*) $'\2' / $_p9k__ret $match [1] $style } " )
2019-07-18 20:20:04 +08:00
else
2020-02-10 19:59:37 +08:00
( ( $# parts > 1 ) ) && parts[ 1,-2] = ( " ${ (@)parts[1,-2]/%(#b)(*) $'\2' / $_p9k__ret $match [1] $style } " )
2019-07-18 20:20:04 +08:00
parts[ -1] = ${ parts [-1]/ $'\2' }
fi
else
parts = ( " ${ (@)parts/ $'\2' } " )
fi
2019-07-23 21:47:25 +08:00
if ( ( $+_POWERLEVEL9K_DIR_SHORTENED_FOREGROUND ) ) ; then
_p9k_translate_color $_POWERLEVEL9K_DIR_SHORTENED_FOREGROUND
2020-02-10 19:59:37 +08:00
_p9k_foreground $_p9k__ret
( ( expand ) ) && _p9k_escape_style $_p9k__ret
local shortened_fg = $_p9k__ret
( ( expand ) ) && _p9k_escape $delim || _p9k__ret = $delim
[ [ $_p9k__ret = = *%* ] ] && _p9k__ret += $style $shortened_fg
parts = ( " ${ (@)parts/(#b) $'\3' (*) $'\1' (*) $'\3' / $shortened_fg $match [1] $_p9k__ret $match [2] $style } " )
parts = ( " ${ (@)parts/(#b)(*) $'\1' (*)/ $shortened_fg $match [1] $_p9k__ret $match [2] $style } " )
2019-07-18 22:29:45 +08:00
else
2020-02-10 19:59:37 +08:00
( ( expand ) ) && _p9k_escape $delim || _p9k__ret = $delim
[ [ $_p9k__ret = = *%* ] ] && _p9k__ret += $style
parts = ( " ${ (@)parts/ $'\1' / $_p9k__ret } " )
2019-07-18 22:29:45 +08:00
parts = ( " ${ (@)parts// $'\3' } " )
fi
2019-06-06 02:11:03 +08:00
2019-07-18 18:21:54 +08:00
local sep = ''
2019-07-23 21:47:25 +08:00
if ( ( $+_POWERLEVEL9K_DIR_PATH_SEPARATOR_FOREGROUND ) ) ; then
_p9k_translate_color $_POWERLEVEL9K_DIR_PATH_SEPARATOR_FOREGROUND
2020-02-10 19:59:37 +08:00
_p9k_foreground $_p9k__ret
( ( expand ) ) && _p9k_escape_style $_p9k__ret
sep = $_p9k__ret
2019-07-23 21:47:25 +08:00
fi
2020-02-10 19:59:37 +08:00
( ( expand ) ) && _p9k_escape $_POWERLEVEL9K_DIR_PATH_SEPARATOR || _p9k__ret = $_POWERLEVEL9K_DIR_PATH_SEPARATOR
sep += $_p9k__ret
2019-07-18 18:21:54 +08:00
[ [ $sep = = *%* ] ] && sep += $style
2019-06-01 23:54:53 +08:00
2019-06-20 19:37:21 +08:00
local content = " ${ (pj. $sep .)parts } "
2019-07-23 21:47:25 +08:00
if ( ( _POWERLEVEL9K_DIR_HYPERLINK ) ) ; then
2020-01-27 22:04:34 +08:00
local header = $'%{\e]8;;file://' ${ ${ _p9k__cwd // \% /%%25 } // '#' /%%23 } $'\a%}'
2020-01-16 18:06:25 +08:00
local footer = $'%{\e]8;;\a%}'
2019-07-18 18:21:54 +08:00
if ( ( expand ) ) ; then
2020-01-16 18:06:25 +08:00
_p9k_escape $header
2020-02-10 19:59:37 +08:00
header = $_p9k__ret
2020-01-16 18:06:25 +08:00
_p9k_escape $footer
2020-02-10 19:59:37 +08:00
footer = $_p9k__ret
2019-07-18 18:21:54 +08:00
fi
2020-01-16 18:06:25 +08:00
content = $header $content $footer
2019-06-20 19:37:21 +08:00
fi
2019-07-19 19:29:54 +08:00
2020-02-10 19:59:37 +08:00
( ( expand ) ) && _p9k_prompt_length " ${ (e) :- " \${\${_p9k__d::=0}+} $content " } " || _p9k__ret =
_p9k_cache_ephemeral_set " $state " " $icon " " $expand " " $content " $_p9k__ret
2019-06-01 23:54:53 +08:00
fi
2019-07-19 19:29:54 +08:00
2020-02-10 19:59:37 +08:00
if ( ( _p9k__cache_val[ 3] ) ) ; then
if ( ( $+_p9k__dir ) ) ; then
_p9k__cache_val[ 4] = '${${_p9k__d::=-1024}+}' $_p9k__cache_val [ 4]
2019-07-18 18:21:54 +08:00
else
2020-02-10 19:59:37 +08:00
_p9k__dir = $_p9k__cache_val [ 4]
_p9k__dir_len = $_p9k__cache_val [ 5]
_p9k__cache_val[ 4] = '%{d%}' $_p9k__cache_val [ 4] '%{d%}'
2019-07-18 18:21:54 +08:00
fi
fi
2020-02-10 19:59:37 +08:00
_p9k_prompt_segment " $_p9k__cache_val [1] " "blue" " $_p9k_color1 " " $_p9k__cache_val [2] " " $_p9k__cache_val [3] " "" " $_p9k__cache_val [4] "
2019-06-01 23:54:53 +08:00
}
2019-10-16 23:36:54 +08:00
instant_prompt_dir( ) { prompt_dir; }
2019-06-01 23:54:53 +08:00
################################################################
# Docker machine
prompt_docker_machine( ) {
2020-01-28 02:23:56 +08:00
_p9k_prompt_segment " $0 " "magenta" " $_p9k_color1 " 'SERVER_ICON' 0 '' " ${ DOCKER_MACHINE_NAME // \% /%% } "
2019-06-01 23:54:53 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_docker_machine_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$DOCKER_MACHINE_NAME'
2020-01-26 01:04:06 +08:00
}
2019-06-01 23:54:53 +08:00
################################################################
# GO prompt
prompt_go_version( ) {
_p9k_cached_cmd_stdout go version || return
2020-02-10 19:59:37 +08:00
[ [ $_p9k__ret = = ( #b)*go([[:digit:].]##)* ]] || return
2019-06-01 23:54:53 +08:00
local v = $match [ 1]
2019-08-12 14:56:47 +08:00
if ( ( _POWERLEVEL9K_GO_VERSION_PROJECT_ONLY ) ) ; then
local p = $GOPATH
if [ [ -z $p ] ] ; then
if [ [ -d $HOME /go ] ] ; then
p = $HOME /go
else
p = " $( go env GOPATH 2>/dev/null) " && [ [ -n $p ] ] || return
fi
fi
2020-01-27 22:04:34 +08:00
if [ [ $_p9k__cwd / != $p /* && $_p9k__cwd_a / != $p /* ] ] ; then
2020-01-28 14:39:47 +08:00
_p9k_upglob go.mod && return
2019-06-01 23:54:53 +08:00
fi
fi
2019-07-25 03:07:28 +08:00
_p9k_prompt_segment " $0 " "green" "grey93" "GO_ICON" 0 '' " ${ v // \% /%% } "
2019-06-01 23:54:53 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_go_version_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$commands[go]'
2020-01-26 01:04:06 +08:00
}
2019-06-01 23:54:53 +08:00
################################################################
# Command number (in local history)
prompt_history( ) {
2020-02-12 22:45:23 +08:00
local -i len = $# _p9k__prompt _p9k__has_upglob
2019-07-25 03:07:28 +08:00
_p9k_prompt_segment " $0 " "grey50" " $_p9k_color1 " '' 0 '' '%h'
2020-02-12 22:45:23 +08:00
( ( _p9k__has_upglob ) ) || typeset -g " _p9k__segment_val_ ${ _p9k__prompt_side } [_p9k__segment_index] " = $_p9k__prompt [ len+1,-1]
2019-06-01 23:54:53 +08:00
}
################################################################
# Detection for virtualization (systemd based systems only)
prompt_detect_virt( ) {
2019-07-29 20:18:57 +08:00
local virt = " $( systemd-detect-virt 2>/dev/null) "
2019-06-01 23:54:53 +08:00
if [ [ " $virt " = = "none" ] ] ; then
2019-07-24 21:52:54 +08:00
[ [ " $( ls -di /) " != "2 /" ] ] && virt = "chroot"
2019-06-01 23:54:53 +08:00
fi
if [ [ -n " ${ virt } " ] ] ; then
2019-07-25 03:07:28 +08:00
_p9k_prompt_segment " $0 " " $_p9k_color1 " "yellow" '' 0 '' " ${ virt // \% /%% } "
2019-06-01 23:54:53 +08:00
fi
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_detect_virt_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$commands[systemd-detect-virt]'
2020-01-26 01:04:06 +08:00
}
2019-06-01 23:54:53 +08:00
################################################################
# Segment to display the current IP address
prompt_ip( ) {
2020-02-12 22:45:23 +08:00
local -i len = $# _p9k__prompt _p9k__has_upglob
2020-02-05 23:22:44 +08:00
_p9k_prompt_segment " $0 " "cyan" " $_p9k_color1 " 'NETWORK_ICON' 1 '$P9K_IP_IP' '$P9K_IP_IP'
2020-02-12 22:45:23 +08:00
( ( _p9k__has_upglob ) ) || typeset -g " _p9k__segment_val_ ${ _p9k__prompt_side } [_p9k__segment_index] " = $_p9k__prompt [ len+1,-1]
2019-06-01 23:54:53 +08:00
}
################################################################
# Segment to display if VPN is active
prompt_vpn_ip( ) {
2020-02-12 22:45:23 +08:00
local -i len = $# _p9k__prompt _p9k__has_upglob
2020-01-18 23:42:00 +08:00
_p9k_prompt_segment " $0 " "cyan" " $_p9k_color1 " 'VPN_ICON' 1 '$_p9k__vpn_ip_ip' '$_p9k__vpn_ip_ip'
2020-02-12 22:45:23 +08:00
( ( _p9k__has_upglob ) ) || typeset -g " _p9k__segment_val_ ${ _p9k__prompt_side } [_p9k__segment_index] " = $_p9k__prompt [ len+1,-1]
2019-06-01 23:54:53 +08:00
}
################################################################
# Segment to display laravel version
prompt_laravel_version( ) {
2020-02-15 21:35:09 +08:00
_p9k_upglob artisan && return
local dir = $_p9k__parent_dirs [ $? ]
local app = $dir /vendor/laravel/framework/src/Illuminate/Foundation/Application.php
[ [ -r $app ] ] || return
if ! _p9k_cache_stat_get $0 $dir /artisan $app ; then
local v = " $( php $dir /artisan --version 2> /dev/null) "
_p9k_cache_stat_set " ${ ${ (M)v : #Laravel Framework * } #Laravel Framework } "
2019-06-01 23:54:53 +08:00
fi
2020-02-15 21:35:09 +08:00
[ [ -n $_p9k__cache_val [ 1] ] ] || return
_p9k_prompt_segment " $0 " "maroon" "white" 'LARAVEL_ICON' 0 '' " ${ _p9k__cache_val [1]// \% /%% } "
2019-06-01 23:54:53 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_laravel_version_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$commands[php]'
2020-01-26 01:04:06 +08:00
}
2019-06-01 23:54:53 +08:00
################################################################
# Segment to display load
prompt_load( ) {
2020-01-18 23:42:00 +08:00
if [ [ $_p9k_os = = ( OSX| BSD) ] ] ; then
2020-02-12 22:45:23 +08:00
local -i len = $# _p9k__prompt _p9k__has_upglob
2020-01-18 23:42:00 +08:00
_p9k_prompt_segment $0 _CRITICAL red " $_p9k_color1 " LOAD_ICON 1 '$_p9k__load_critical' '$_p9k__load_value'
_p9k_prompt_segment $0 _WARNING yellow " $_p9k_color1 " LOAD_ICON 1 '$_p9k__load_warning' '$_p9k__load_value'
_p9k_prompt_segment $0 _NORMAL green " $_p9k_color1 " LOAD_ICON 1 '$_p9k__load_normal' '$_p9k__load_value'
2020-02-12 22:45:23 +08:00
( ( _p9k__has_upglob ) ) || typeset -g " _p9k__segment_val_ ${ _p9k__prompt_side } [_p9k__segment_index] " = $_p9k__prompt [ len+1,-1]
2020-01-18 23:42:00 +08:00
return
fi
[ [ -r /proc/loadavg ] ] || return
_p9k_read_file /proc/loadavg || return
2020-02-10 19:59:37 +08:00
local load = ${ ${ (A)=_p9k__ret } [_POWERLEVEL9K_LOAD_WHICH]//,/. }
2020-01-18 23:42:00 +08:00
local -F pct = '100. * load / _p9k_num_cpus'
if ( ( pct > 70 ) ) ; then
_p9k_prompt_segment $0 _CRITICAL red " $_p9k_color1 " LOAD_ICON 0 '' $load
elif ( ( pct > 50 ) ) ; then
_p9k_prompt_segment $0 _WARNING yellow " $_p9k_color1 " LOAD_ICON 0 '' $load
else
_p9k_prompt_segment $0 _NORMAL green " $_p9k_color1 " LOAD_ICON 0 '' $load
fi
}
2019-06-01 23:54:53 +08:00
2020-01-18 23:42:00 +08:00
_p9k_prompt_load_init( ) {
2020-01-26 01:04:06 +08:00
if [ [ $_p9k_os = = ( OSX| BSD) ] ] ; then
typeset -g _p9k__load_value =
typeset -g _p9k__load_normal =
typeset -g _p9k__load_warning =
typeset -g _p9k__load_critical =
_p9k__async_segments_compute += _p9k_prompt_load_compute
elif [ [ ! -r /proc/loadavg ] ] ; then
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '${:-}'
2020-01-26 01:04:06 +08:00
fi
2020-01-18 23:42:00 +08:00
}
2019-06-01 23:54:53 +08:00
2020-01-25 18:01:14 +08:00
_p9k_prompt_load_compute( ) {
( ( $+commands[ sysctl] ) ) || return
_p9k_worker_async _p9k_prompt_load_async _p9k_prompt_load_sync
2020-01-18 23:42:00 +08:00
}
2019-06-01 23:54:53 +08:00
2020-01-18 23:42:00 +08:00
_p9k_prompt_load_async( ) {
2020-01-21 06:37:03 +08:00
local load = " $( sysctl -n vm.loadavg 2>/dev/null) " || return
2020-01-21 03:12:05 +08:00
load = ${ ${ (A)=load } [_POWERLEVEL9K_LOAD_WHICH+1]//,/. }
2020-01-21 06:37:03 +08:00
[ [ $load = = <->( | .<->) && $load != $_p9k__load_value ] ] || return
2020-01-21 03:12:05 +08:00
_p9k__load_value = $load
2020-01-18 23:42:00 +08:00
_p9k__load_normal =
_p9k__load_warning =
_p9k__load_critical =
local -F pct = '100. * _p9k__load_value / _p9k_num_cpus'
if ( ( pct > 70 ) ) ; then
_p9k__load_critical = 1
elif ( ( pct > 50 ) ) ; then
_p9k__load_warning = 1
2019-06-01 23:54:53 +08:00
else
2020-01-18 23:42:00 +08:00
_p9k__load_normal = 1
2019-06-01 23:54:53 +08:00
fi
2020-01-26 21:46:50 +08:00
_p9k_print_params \
2020-01-21 03:12:05 +08:00
_p9k__load_value \
_p9k__load_normal \
_p9k__load_warning \
2020-01-18 23:42:00 +08:00
_p9k__load_critical
2020-01-25 18:01:14 +08:00
echo -E - 'reset=1'
}
_p9k_prompt_load_sync( ) {
eval $REPLY
_p9k_worker_reply $REPLY
2019-06-01 23:54:53 +08:00
}
function _p9k_cached_cmd_stdout( ) {
2019-09-24 16:17:54 +08:00
local cmd = ${ commands [ $1 ] : A }
2019-06-01 23:54:53 +08:00
[ [ -n $cmd ] ] || return
shift
2019-10-10 01:57:18 +08:00
if ! _p9k_cache_stat_get $0 " ${ (q)* } " $cmd ; then
2019-06-01 23:54:53 +08:00
local out
2019-07-29 20:18:57 +08:00
out = " $( $cmd " $@ " 2>/dev/null) "
2019-10-10 01:57:18 +08:00
_p9k_cache_stat_set $(( ! $? )) " $out "
2019-06-01 23:54:53 +08:00
fi
2020-02-10 19:59:37 +08:00
( ( $_p9k__cache_val [ 1] ) ) || return
_p9k__ret = $_p9k__cache_val [ 2]
2019-06-01 23:54:53 +08:00
}
function _p9k_cached_cmd_stdout_stderr( ) {
2019-09-24 16:17:54 +08:00
local cmd = ${ commands [ $1 ] : A }
2019-06-01 23:54:53 +08:00
[ [ -n $cmd ] ] || return
shift
2019-10-10 01:57:18 +08:00
if ! _p9k_cache_stat_get $0 " ${ (q)* } " $cmd ; then
2019-06-01 23:54:53 +08:00
local out
2019-07-29 20:18:57 +08:00
out = " $( $cmd " $@ " 2>& 1) " # this line is the only diff with _p9k_cached_cmd_stdout
2019-10-10 01:57:18 +08:00
_p9k_cache_stat_set $(( ! $? )) " $out "
2019-06-01 23:54:53 +08:00
fi
2020-02-10 19:59:37 +08:00
( ( $_p9k__cache_val [ 1] ) ) || return
_p9k__ret = $_p9k__cache_val [ 2]
2019-06-01 23:54:53 +08:00
}
################################################################
# Segment to diplay Node version
prompt_node_version( ) {
2019-07-24 20:34:26 +08:00
if ( ( _POWERLEVEL9K_NODE_VERSION_PROJECT_ONLY ) ) ; then
2020-01-28 14:39:47 +08:00
_p9k_upglob package.json && return
2019-06-01 23:54:53 +08:00
fi
2020-02-10 19:59:37 +08:00
_p9k_cached_cmd_stdout node --version && [ [ $_p9k__ret = = v?* ] ] || return
_p9k_prompt_segment " $0 " "green" "white" 'NODE_ICON' 0 '' " ${ _p9k__ret #v } "
2019-06-01 23:54:53 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_node_version_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$commands[node]'
2020-01-26 01:04:06 +08:00
}
2019-06-01 23:54:53 +08:00
# Almost the same as `nvm_version default` but faster. The differences shouldn't affect
# the observable behavior of Powerlevel10k.
function _p9k_nvm_ls_default( ) {
local v = default
local -a seen = ( $v )
2019-08-02 13:07:23 +08:00
while [ [ -r $NVM_DIR /alias/$v ] ] ; do
local target =
IFS = '' read -r target <$NVM_DIR /alias/$v
[ [ -z $target ] ] && break
( ( $seen [ ( I) $target ] ) ) && return
2019-06-01 23:54:53 +08:00
seen += $target
v = $target
done
case $v in
default| N/A)
return 1
; ;
system| v)
2020-02-10 19:59:37 +08:00
_p9k__ret = system
2019-11-04 16:07:06 +08:00
return 0
2019-06-01 23:54:53 +08:00
; ;
iojs-[ 0-9] *)
v = iojs-v${ v #iojs- }
; ;
[ 0-9] *)
v = v$v
; ;
esac
if [ [ $v = = v*.*.* ] ] ; then
if [ [ -x $NVM_DIR /versions/node/$v /bin/node || -x $NVM_DIR /$v /bin/node ] ] ; then
2020-02-10 19:59:37 +08:00
_p9k__ret = $v
2019-11-04 16:07:06 +08:00
return 0
2019-06-01 23:54:53 +08:00
elif [ [ -x $NVM_DIR /versions/io.js/$v /bin/node ] ] ; then
2020-02-10 19:59:37 +08:00
_p9k__ret = iojs-$v
2019-11-04 16:07:06 +08:00
return 0
2019-06-01 23:54:53 +08:00
else
return 1
fi
fi
local -a dirs = ( )
case $v in
node| node-| stable)
dirs = ( $NVM_DIR /versions/node $NVM_DIR )
v = '(v[1-9]*|v0.*[02468].*)'
; ;
unstable)
dirs = ( $NVM_DIR /versions/node $NVM_DIR )
v = 'v0.*[13579].*'
; ;
iojs*)
dirs = ( $NVM_DIR /versions/io.js)
v = v${ ${ ${ v #iojs } #- } #v } '*'
; ;
*)
dirs = ( $NVM_DIR /versions/node $NVM_DIR $NVM_DIR /versions/io.js)
v = v${ v #v } '*'
; ;
esac
local -a matches = ( ${ ^dirs } /${ ~v } ( /N) )
( ( $# matches ) ) || return
local max path
for path in ${ (Oa)matches } ; do
[ [ ${ path : t } = = ( #b)v(*).(*).(*) ]] || continue
v = ${ (j : : ) ${ (@l : 6 : : 0 : )match } }
[ [ $v > $max ] ] || continue
max = $v
2020-02-10 19:59:37 +08:00
_p9k__ret = ${ path : t }
[ [ ${ path : h : t } != io.js ] ] || _p9k__ret = iojs-$_p9k__ret
2019-06-01 23:54:53 +08:00
done
[ [ -n $max ] ]
}
# The same as `nvm_version current` but faster.
_p9k_nvm_ls_current( ) {
local node_path = ${ commands [node] : A }
[ [ -n $node_path ] ] || return
local nvm_dir = ${ NVM_DIR : A }
if [ [ -n $nvm_dir && $node_path = = $nvm_dir /versions/io.js/* ] ] ; then
_p9k_cached_cmd_stdout iojs --version || return
2020-02-10 19:59:37 +08:00
_p9k__ret = iojs-v${ _p9k__ret #v }
2019-06-01 23:54:53 +08:00
elif [ [ -n $nvm_dir && $node_path = = $nvm_dir /* ] ] ; then
_p9k_cached_cmd_stdout node --version || return
2020-02-10 19:59:37 +08:00
_p9k__ret = v${ _p9k__ret #v }
2019-06-01 23:54:53 +08:00
else
2020-02-10 19:59:37 +08:00
_p9k__ret = system
2019-06-01 23:54:53 +08:00
fi
}
################################################################
# Segment to display Node version from NVM
# Only prints the segment if different than the default value
prompt_nvm( ) {
[ [ -n $NVM_DIR ] ] && _p9k_nvm_ls_current || return
2020-02-10 19:59:37 +08:00
local current = $_p9k__ret
! _p9k_nvm_ls_default || [ [ $_p9k__ret != $current ] ] || return
2019-07-25 03:07:28 +08:00
_p9k_prompt_segment " $0 " "magenta" "black" 'NODE_ICON' 0 '' " ${ ${ current #v } // \% /%% } "
2019-06-01 23:54:53 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_nvm_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '${commands[nvm]:-${${+functions[nvm]}:#0}}'
2020-01-26 01:04:06 +08:00
}
2019-06-01 23:54:53 +08:00
################################################################
# Segment to display NodeEnv
prompt_nodeenv( ) {
2019-07-29 22:10:28 +08:00
local msg
if ( ( _POWERLEVEL9K_NODEENV_SHOW_NODE_VERSION ) ) && _p9k_cached_cmd_stdout node --version; then
2020-02-10 19:59:37 +08:00
msg = " ${ _p9k__ret // \% /%% } "
2019-06-01 23:54:53 +08:00
fi
2019-07-29 22:10:28 +08:00
msg += " $_POWERLEVEL9K_NODEENV_LEFT_DELIMITER ${ ${ NODE_VIRTUAL_ENV : t } // \% /%% } $_POWERLEVEL9K_NODEENV_RIGHT_DELIMITER "
_p9k_prompt_segment " $0 " "black" "green" 'NODE_ICON' 0 '' " $msg "
2019-06-01 23:54:53 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_nodeenv_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$NODE_VIRTUAL_ENV'
2020-01-26 01:04:06 +08:00
}
2019-07-17 05:03:49 +08:00
function _p9k_nodeenv_version_transform( ) {
local dir = ${ NODENV_ROOT :- $HOME /.nodenv } /versions
2020-02-10 19:59:37 +08:00
[ [ -z $1 || $1 = = system ] ] && _p9k__ret = $1 && return
[ [ -d $dir /$1 ] ] && _p9k__ret = $1 && return
[ [ -d $dir /${ 1 /v } ] ] && _p9k__ret = ${ 1 /v } && return
[ [ -d $dir /${ 1 #node- } ] ] && _p9k__ret = ${ 1 #node- } && return
[ [ -d $dir /${ 1 #node-v } ] ] && _p9k__ret = ${ 1 #node-v } && return
2019-07-17 05:03:49 +08:00
return 1
}
function _p9k_nodenv_global_version( ) {
2020-02-10 19:59:37 +08:00
_p9k_read_word ${ NODENV_ROOT :- $HOME /.nodenv } /version || _p9k__ret = system
2019-07-17 05:03:49 +08:00
}
################################################################
# Segment to display nodenv information
# https://github.com/nodenv/nodenv
prompt_nodenv( ) {
2020-02-10 19:59:37 +08:00
_p9k__ret = $NODENV_VERSION
if [ [ -z $_p9k__ret ] ] ; then
2020-01-28 02:23:56 +08:00
if [ [ $NODENV_DIR = = ( | .) ] ] ; then
2020-01-28 14:39:47 +08:00
_p9k_upglob .node-version
2020-01-28 02:23:56 +08:00
local -i idx = $?
2020-02-10 19:59:37 +08:00
( ( idx ) ) && _p9k_read_word $_p9k__parent_dirs [ idx] /.node-version || _p9k__ret =
2020-01-28 02:23:56 +08:00
else
[ [ $NODENV_DIR = = /* ] ] && local dir = $NODENV_DIR || local dir = " $_p9k__cwd_a / $NODENV_DIR "
while [ [ $dir != //[ ^/] # ]]; do
2020-01-28 16:59:54 +08:00
_p9k_read_word $dir /.node-version && break
2020-01-28 02:23:56 +08:00
[ [ $dir = = / ] ] && break
dir = ${ dir : h }
done
fi
2020-02-10 19:59:37 +08:00
if [ [ -z $_p9k__ret ] ] ; then
2019-07-23 21:47:25 +08:00
( ( _POWERLEVEL9K_NODENV_PROMPT_ALWAYS_SHOW ) ) || return
2019-07-17 05:03:49 +08:00
_p9k_nodenv_global_version
fi
fi
2020-02-10 19:59:37 +08:00
_p9k_nodeenv_version_transform $_p9k__ret || return
local v = $_p9k__ret
2019-07-17 05:03:49 +08:00
2019-07-23 21:47:25 +08:00
if ( ( !_POWERLEVEL9K_NODENV_PROMPT_ALWAYS_SHOW ) ) ; then
2019-07-17 05:03:49 +08:00
_p9k_nodenv_global_version
2020-02-10 19:59:37 +08:00
_p9k_nodeenv_version_transform $_p9k__ret && [ [ $v = = $_p9k__ret ] ] && return
2019-07-17 05:03:49 +08:00
fi
2019-07-25 03:07:28 +08:00
_p9k_prompt_segment " $0 " "black" "green" 'NODE_ICON' 0 '' " ${ v // \% /%% } "
2019-07-17 05:03:49 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_nodenv_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '${commands[nodenv]:-${${+functions[nodenv]}:#0}}'
2020-01-26 01:04:06 +08:00
}
2019-09-24 16:17:54 +08:00
prompt_dotnet_version( ) {
if ( ( _POWERLEVEL9K_DOTNET_VERSION_PROJECT_ONLY ) ) ; then
2020-01-28 14:39:47 +08:00
_p9k_upglob 'project.json|global.json|packet.dependencies|*.csproj|*.fsproj|*.xproj|*.sln' && return
2019-09-24 16:17:54 +08:00
fi
_p9k_cached_cmd_stdout dotnet --version || return
2020-02-10 19:59:37 +08:00
_p9k_prompt_segment " $0 " "magenta" "white" 'DOTNET_ICON' 0 '' " $_p9k__ret "
2019-09-24 16:17:54 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_dotnet_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$commands[dotnet]'
2020-01-26 01:04:06 +08:00
}
2019-09-24 20:29:21 +08:00
2019-06-01 23:54:53 +08:00
################################################################
# Segment to print a little OS icon
prompt_os_icon( ) {
2020-02-12 22:45:23 +08:00
local -i len = $# _p9k__prompt _p9k__has_upglob
2019-07-25 03:07:28 +08:00
_p9k_prompt_segment " $0 " "black" "white" '' 0 '' " $_p9k_os_icon "
2020-02-12 22:45:23 +08:00
( ( _p9k__has_upglob ) ) || typeset -g " _p9k__segment_val_ ${ _p9k__prompt_side } [_p9k__segment_index] " = $_p9k__prompt [ len+1,-1]
2019-06-01 23:54:53 +08:00
}
2019-10-16 23:36:54 +08:00
instant_prompt_os_icon( ) { prompt_os_icon; }
2019-06-01 23:54:53 +08:00
################################################################
# Segment to display PHP version number
prompt_php_version( ) {
2020-02-15 20:46:42 +08:00
if ( ( _POWERLEVEL9K_PHP_VERSION_PROJECT_ONLY ) ) ; then
_p9k_upglob 'composer.json|*.php' && return
fi
2019-06-01 23:54:53 +08:00
_p9k_cached_cmd_stdout php --version || return
2020-02-15 21:38:15 +08:00
[ [ $_p9k__ret = = ( #b)(*$'\n')#'PHP '([[:digit:].]##)* ]] || return
2019-06-01 23:54:53 +08:00
local v = $match [ 2]
2020-02-15 20:46:42 +08:00
_p9k_prompt_segment " $0 " "fuchsia" "grey93" 'PHP_ICON' 0 '' " ${ v // \% /%% } "
2019-06-01 23:54:53 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_php_version_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$commands[php]'
2020-01-26 01:04:06 +08:00
}
2019-06-01 23:54:53 +08:00
################################################################
# Segment to display free RAM and used Swap
prompt_ram( ) {
2020-02-12 22:45:23 +08:00
local -i len = $# _p9k__prompt _p9k__has_upglob
2020-01-19 21:38:13 +08:00
_p9k_prompt_segment $0 yellow " $_p9k_color1 " RAM_ICON 1 '$_p9k__ram_free' '$_p9k__ram_free'
2020-02-12 22:45:23 +08:00
( ( _p9k__has_upglob ) ) || typeset -g " _p9k__segment_val_ ${ _p9k__prompt_side } [_p9k__segment_index] " = $_p9k__prompt [ len+1,-1]
2020-01-19 21:38:13 +08:00
}
function _p9k_prompt_ram_init( ) {
2020-01-26 01:04:06 +08:00
if [ [ $_p9k_os = = OSX && $+commands[ vm_stat] = = 0 ||
$_p9k_os = = BSD && ! -r /var/run/dmesg.boot ||
$_p9k_os != ( OSX| BSD) && ! -r /proc/meminfo ] ] ; then
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '${:-}'
2020-01-26 01:04:06 +08:00
return
fi
2020-01-19 21:38:13 +08:00
typeset -g _p9k__ram_free =
2020-01-25 18:01:14 +08:00
_p9k__async_segments_compute += _p9k_prompt_ram_compute
}
_p9k_prompt_ram_compute( ) {
_p9k_worker_async _p9k_prompt_ram_async _p9k_prompt_ram_sync
2020-01-19 21:38:13 +08:00
}
_p9k_prompt_ram_async( ) {
2019-06-01 23:54:53 +08:00
local -F free_bytes
2019-07-24 20:34:26 +08:00
case $_p9k_os in
2019-06-01 23:54:53 +08:00
OSX)
( ( $+commands[ vm_stat] ) ) || return
2019-07-29 20:18:57 +08:00
local stat && stat = " $( vm_stat 2>/dev/null) " || return
2019-06-01 23:54:53 +08:00
[ [ $stat = ~ 'Pages free:[[:space:]]+([0-9]+)' ] ] || return
2020-01-21 06:37:03 +08:00
( ( free_bytes += match[ 1] ) )
2019-06-01 23:54:53 +08:00
[ [ $stat = ~ 'Pages inactive:[[:space:]]+([0-9]+)' ] ] || return
2020-01-21 06:37:03 +08:00
( ( free_bytes += match[ 1] ) )
2019-06-01 23:54:53 +08:00
( ( free_bytes *= 4096 ) )
; ;
BSD)
2019-07-29 20:18:57 +08:00
local stat && stat = " $( grep -F 'avail memory' /var/run/dmesg.boot 2>/dev/null) " || return
2019-06-01 23:54:53 +08:00
free_bytes = ${ ${ (A)=stat } [4] }
; ;
*)
2019-07-29 16:07:42 +08:00
[ [ -r /proc/meminfo ] ] || return
local stat && stat = " $( </proc/meminfo) " || return
2020-01-20 04:24:11 +08:00
[ [ $stat = = ( #b)*(MemAvailable:|MemFree:)[[:space:]]#(<->)* ]] || return
free_bytes = $(( $match [ 2 ] * 1024 ))
2019-06-01 23:54:53 +08:00
; ;
esac
_p9k_human_readable_bytes $free_bytes
2020-02-10 19:59:37 +08:00
[ [ $_p9k__ret != $_p9k__ram_free ] ] || return
_p9k__ram_free = $_p9k__ret
2020-01-26 21:46:50 +08:00
_p9k_print_params _p9k__ram_free
2020-01-25 18:01:14 +08:00
echo -E - 'reset=1'
}
_p9k_prompt_ram_sync( ) {
eval $REPLY
_p9k_worker_reply $REPLY
2019-06-01 23:54:53 +08:00
}
function _p9k_rbenv_global_version( ) {
2020-02-10 19:59:37 +08:00
_p9k_read_word ${ RBENV_ROOT :- $HOME /.rbenv } /version || _p9k__ret = system
2019-06-01 23:54:53 +08:00
}
################################################################
# Segment to display rbenv information
# https://github.com/rbenv/rbenv#choosing-the-ruby-version
prompt_rbenv( ) {
2019-11-18 18:32:53 +08:00
if [ [ -n $RBENV_VERSION ] ] ; then
( ( ${ _POWERLEVEL9K_RBENV_SOURCES [(I)shell] } ) ) || return
local v = $RBENV_VERSION
else
( ( ${ _POWERLEVEL9K_RBENV_SOURCES [(I)local|global] } ) ) || return
2020-01-28 02:23:56 +08:00
if [ [ $RBENV_DIR = = ( | .) ] ] ; then
2020-01-28 14:39:47 +08:00
_p9k_upglob .ruby-version
2020-01-28 02:23:56 +08:00
local -i idx = $?
if ( ( idx ) ) && _p9k_read_word $_p9k__parent_dirs [ idx] /.ruby-version; then
2019-11-18 18:32:53 +08:00
( ( ${ _POWERLEVEL9K_RBENV_SOURCES [(I)local] } ) ) || return
2020-01-28 02:23:56 +08:00
else
2020-02-10 19:59:37 +08:00
_p9k__ret =
2019-06-01 23:54:53 +08:00
fi
2020-01-28 02:23:56 +08:00
else
2020-02-10 19:59:37 +08:00
_p9k__ret =
2020-01-28 02:23:56 +08:00
[ [ $RBENV_DIR = = /* ] ] && local dir = $RBENV_DIR || local dir = " $_p9k__cwd_a / $RBENV_DIR "
while true; do
if _p9k_read_word $dir /.ruby-version; then
( ( ${ _POWERLEVEL9K_RBENV_SOURCES [(I)local] } ) ) || return
break
fi
[ [ $dir = = / ] ] && break
dir = ${ dir : h }
done
fi
2020-02-10 19:59:37 +08:00
if [ [ -z $_p9k__ret ] ] ; then
2020-01-28 02:23:56 +08:00
( ( _POWERLEVEL9K_RBENV_PROMPT_ALWAYS_SHOW ) ) || return
( ( ${ _POWERLEVEL9K_RBENV_SOURCES [(I)global] } ) ) || return
_p9k_rbenv_global_version
fi
2020-02-10 19:59:37 +08:00
local v = $_p9k__ret
2019-06-01 23:54:53 +08:00
fi
2019-07-23 21:47:25 +08:00
if ( ( !_POWERLEVEL9K_RBENV_PROMPT_ALWAYS_SHOW ) ) ; then
2019-06-01 23:54:53 +08:00
_p9k_rbenv_global_version
2020-02-10 19:59:37 +08:00
[ [ $v = = $_p9k__ret ] ] && return
2019-06-01 23:54:53 +08:00
fi
2019-07-25 03:07:28 +08:00
_p9k_prompt_segment " $0 " "red" " $_p9k_color1 " 'RUBY_ICON' 0 '' " ${ v // \% /%% } "
2019-06-01 23:54:53 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_rbenv_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '${commands[rbenv]:-${${+functions[rbenv]}:#0}}'
2020-01-26 01:04:06 +08:00
}
2020-02-15 20:38:44 +08:00
function _p9k_phpenv_global_version( ) {
_p9k_read_word ${ PHPENV_ROOT :- $HOME /.phpenv } /version || _p9k__ret = system
}
prompt_phpenv( ) {
if [ [ -n $PHPENV_VERSION ] ] ; then
( ( ${ _POWERLEVEL9K_PHPENV_SOURCES [(I)shell] } ) ) || return
local v = $PHPENV_VERSION
else
( ( ${ _POWERLEVEL9K_PHPENV_SOURCES [(I)local|global] } ) ) || return
if [ [ $PHPENV_DIR = = ( | .) ] ] ; then
_p9k_upglob .php-version
local -i idx = $?
if ( ( idx ) ) && _p9k_read_word $_p9k__parent_dirs [ idx] /.php-version; then
( ( ${ _POWERLEVEL9K_PHPENV_SOURCES [(I)local] } ) ) || return
else
_p9k__ret =
fi
else
_p9k__ret =
[ [ $PHPENV_DIR = = /* ] ] && local dir = $PHPENV_DIR || local dir = " $_p9k__cwd_a / $PHPENV_DIR "
while true; do
if _p9k_read_word $dir /.php-version; then
( ( ${ _POWERLEVEL9K_PHPENV_SOURCES [(I)local] } ) ) || return
break
fi
[ [ $dir = = / ] ] && break
dir = ${ dir : h }
done
fi
if [ [ -z $_p9k__ret ] ] ; then
( ( _POWERLEVEL9K_PHPENV_PROMPT_ALWAYS_SHOW ) ) || return
( ( ${ _POWERLEVEL9K_PHPENV_SOURCES [(I)global] } ) ) || return
_p9k_phpenv_global_version
fi
local v = $_p9k__ret
fi
if ( ( !_POWERLEVEL9K_PHPENV_PROMPT_ALWAYS_SHOW ) ) ; then
_p9k_phpenv_global_version
[ [ $v = = $_p9k__ret ] ] && return
fi
_p9k_prompt_segment " $0 " "magenta" " $_p9k_color1 " 'PHP_ICON' 0 '' " ${ v // \% /%% } "
}
_p9k_prompt_phpenv_init( ) {
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '${commands[phpenv]:-${${+functions[phpenv]}:#0}}'
}
2020-01-03 00:43:45 +08:00
function _p9k_luaenv_global_version( ) {
2020-02-10 19:59:37 +08:00
_p9k_read_word ${ LUAENV_ROOT :- $HOME /.luaenv } /version || _p9k__ret = system
2020-01-03 00:43:45 +08:00
}
################################################################
# Segment to display luaenv information
# https://github.com/cehoffman/luaenv
prompt_luaenv( ) {
if [ [ -n $LUAENV_VERSION ] ] ; then
( ( ${ _POWERLEVEL9K_LUAENV_SOURCES [(I)shell] } ) ) || return
local v = $LUAENV_VERSION
else
( ( ${ _POWERLEVEL9K_LUAENV_SOURCES [(I)local|global] } ) ) || return
2020-01-28 16:59:54 +08:00
if [ [ $LUAENV_DIR = = ( | .) ] ] ; then
_p9k_upglob .lua-version
local -i idx = $?
if ( ( idx ) ) && _p9k_read_word $_p9k__parent_dirs [ idx] /.lua-version; then
2020-01-03 00:43:45 +08:00
( ( ${ _POWERLEVEL9K_LUAENV_SOURCES [(I)local] } ) ) || return
2020-01-28 16:59:54 +08:00
else
2020-02-10 19:59:37 +08:00
_p9k__ret =
2020-01-03 00:43:45 +08:00
fi
2020-01-28 16:59:54 +08:00
else
2020-02-10 19:59:37 +08:00
_p9k__ret =
2020-01-28 16:59:54 +08:00
[ [ $LUAENV_DIR = = /* ] ] && local dir = $LUAENV_DIR || local dir = " $_p9k__cwd_a / $LUAENV_DIR "
while true; do
if _p9k_read_word $dir /.lua-version; then
( ( ${ _POWERLEVEL9K_LUAENV_SOURCES [(I)local] } ) ) || return
break
fi
[ [ $dir = = / ] ] && break
dir = ${ dir : h }
done
fi
2020-02-10 19:59:37 +08:00
if [ [ -z $_p9k__ret ] ] ; then
2020-01-28 16:59:54 +08:00
( ( _POWERLEVEL9K_LUAENV_PROMPT_ALWAYS_SHOW ) ) || return
( ( ${ _POWERLEVEL9K_LUAENV_SOURCES [(I)global] } ) ) || return
_p9k_luaenv_global_version
fi
2020-02-10 19:59:37 +08:00
local v = $_p9k__ret
2020-01-03 00:43:45 +08:00
fi
if ( ( !_POWERLEVEL9K_LUAENV_PROMPT_ALWAYS_SHOW ) ) ; then
_p9k_luaenv_global_version
2020-02-10 19:59:37 +08:00
[ [ $v = = $_p9k__ret ] ] && return
2020-01-03 00:43:45 +08:00
fi
_p9k_prompt_segment " $0 " blue " $_p9k_color1 " 'LUA_ICON' 0 '' " ${ v // \% /%% } "
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_luaenv_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '${commands[luaenv]:-${${+functions[luaenv]}:#0}}'
2020-01-26 01:04:06 +08:00
}
2020-01-28 16:59:54 +08:00
function _p9k_jenv_global_version( ) {
2020-02-10 19:59:37 +08:00
_p9k_read_word ${ JENV_ROOT :- $HOME /.jenv } /version || _p9k__ret = system
2020-01-03 01:03:59 +08:00
}
2020-01-28 16:59:54 +08:00
################################################################
# Segment to display jenv information
# https://github.com/jenv/jenv
prompt_jenv( ) {
if [ [ -n $JENV_VERSION ] ] ; then
( ( ${ _POWERLEVEL9K_JENV_SOURCES [(I)shell] } ) ) || return
local v = $JENV_VERSION
else
( ( ${ _POWERLEVEL9K_JENV_SOURCES [(I)local|global] } ) ) || return
if [ [ $JENV_DIR = = ( | .) ] ] ; then
_p9k_upglob .java-version
local -i idx = $?
if ( ( idx ) ) && _p9k_read_word $_p9k__parent_dirs [ idx] /.java-version; then
( ( ${ _POWERLEVEL9K_JENV_SOURCES [(I)local] } ) ) || return
else
2020-02-10 19:59:37 +08:00
_p9k__ret =
2020-01-28 16:59:54 +08:00
fi
else
2020-02-10 19:59:37 +08:00
_p9k__ret =
2020-01-28 16:59:54 +08:00
[ [ $JENV_DIR = = /* ] ] && local dir = $JENV_DIR || local dir = " $_p9k__cwd_a / $JENV_DIR "
while true; do
if _p9k_read_word $dir /.java-version; then
( ( ${ _POWERLEVEL9K_JENV_SOURCES [(I)local] } ) ) || return
break
fi
[ [ $dir = = / ] ] && break
dir = ${ dir : h }
done
fi
2020-02-10 19:59:37 +08:00
if [ [ -z $_p9k__ret ] ] ; then
2020-01-28 16:59:54 +08:00
( ( _POWERLEVEL9K_JENV_PROMPT_ALWAYS_SHOW ) ) || return
( ( ${ _POWERLEVEL9K_JENV_SOURCES [(I)global] } ) ) || return
_p9k_jenv_global_version
fi
2020-02-10 19:59:37 +08:00
local v = $_p9k__ret
2020-01-28 16:59:54 +08:00
fi
if ( ( !_POWERLEVEL9K_JENV_PROMPT_ALWAYS_SHOW ) ) ; then
_p9k_jenv_global_version
2020-02-10 19:59:37 +08:00
[ [ $v = = $_p9k__ret ] ] && return
2020-01-28 16:59:54 +08:00
fi
_p9k_prompt_segment " $0 " white red 'JAVA_ICON' 0 '' " ${ v // \% /%% } "
2020-01-03 01:03:59 +08:00
}
2020-01-28 16:59:54 +08:00
_p9k_prompt_jenv_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '${commands[jenv]:-${${+functions[jenv]}:#0}}'
2020-01-03 01:24:01 +08:00
}
function _p9k_plenv_global_version( ) {
2020-02-10 19:59:37 +08:00
_p9k_read_word ${ PLENV_ROOT :- $HOME /.plenv } /version || _p9k__ret = system
2020-01-03 01:24:01 +08:00
}
################################################################
# Segment to display plenv information
# https://github.com/plenv/plenv#choosing-the-perl-version
prompt_plenv( ) {
if [ [ -n $PLENV_VERSION ] ] ; then
( ( ${ _POWERLEVEL9K_PLENV_SOURCES [(I)shell] } ) ) || return
local v = $PLENV_VERSION
else
( ( ${ _POWERLEVEL9K_PLENV_SOURCES [(I)local|global] } ) ) || return
2020-01-28 16:59:54 +08:00
if [ [ $PLENV_DIR = = ( | .) ] ] ; then
_p9k_upglob .perl-version
local -i idx = $?
if ( ( idx ) ) && _p9k_read_word $_p9k__parent_dirs [ idx] /.perl-version; then
2020-01-03 01:24:01 +08:00
( ( ${ _POWERLEVEL9K_PLENV_SOURCES [(I)local] } ) ) || return
2020-01-28 16:59:54 +08:00
else
2020-02-10 19:59:37 +08:00
_p9k__ret =
2020-01-03 01:24:01 +08:00
fi
2020-01-28 16:59:54 +08:00
else
2020-02-10 19:59:37 +08:00
_p9k__ret =
2020-01-28 16:59:54 +08:00
[ [ $PLENV_DIR = = /* ] ] && local dir = $PLENV_DIR || local dir = " $_p9k__cwd_a / $PLENV_DIR "
while true; do
if _p9k_read_word $dir /.perl-version; then
( ( ${ _POWERLEVEL9K_PLENV_SOURCES [(I)local] } ) ) || return
break
fi
[ [ $dir = = / ] ] && break
dir = ${ dir : h }
done
fi
2020-02-10 19:59:37 +08:00
if [ [ -z $_p9k__ret ] ] ; then
2020-01-28 16:59:54 +08:00
( ( _POWERLEVEL9K_PLENV_PROMPT_ALWAYS_SHOW ) ) || return
( ( ${ _POWERLEVEL9K_PLENV_SOURCES [(I)global] } ) ) || return
_p9k_plenv_global_version
fi
2020-02-10 19:59:37 +08:00
local v = $_p9k__ret
2020-01-03 01:24:01 +08:00
fi
if ( ( !_POWERLEVEL9K_PLENV_PROMPT_ALWAYS_SHOW ) ) ; then
_p9k_plenv_global_version
2020-02-10 19:59:37 +08:00
[ [ $v = = $_p9k__ret ] ] && return
2020-01-03 01:24:01 +08:00
fi
_p9k_prompt_segment " $0 " "blue" " $_p9k_color1 " 'PERL_ICON' 0 '' " ${ v // \% /%% } "
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_plenv_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '${commands[plenv]:-${${+functions[plenv]}:#0}}'
2020-01-26 01:04:06 +08:00
}
2019-06-01 23:54:53 +08:00
################################################################
# Segment to display chruby information
# see https://github.com/postmodern/chruby/issues/245 for chruby_auto issue with ZSH
prompt_chruby( ) {
2020-01-28 18:41:49 +08:00
local v
2019-07-23 21:47:25 +08:00
( ( _POWERLEVEL9K_CHRUBY_SHOW_ENGINE ) ) && v = $RUBY_ENGINE
if [ [ $_POWERLEVEL9K_CHRUBY_SHOW_VERSION = = 1 && -n $RUBY_VERSION ] ] && v += ${ v : + } $RUBY_VERSION
2019-07-25 03:07:28 +08:00
_p9k_prompt_segment " $0 " "red" " $_p9k_color1 " 'RUBY_ICON' 0 '' " ${ v // \% /%% } "
2019-06-01 23:54:53 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_chruby_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$RUBY_ENGINE'
2020-01-26 01:04:06 +08:00
}
2019-06-01 23:54:53 +08:00
################################################################
# Segment to print an icon if user is root.
prompt_root_indicator( ) {
2020-02-12 22:45:23 +08:00
local -i len = $# _p9k__prompt _p9k__has_upglob
2020-01-26 01:04:06 +08:00
_p9k_prompt_segment " $0 " " $_p9k_color1 " "yellow" 'ROOT_ICON' 0 '${${(%):-%#}:#\%}' ''
2020-02-12 22:45:23 +08:00
( ( _p9k__has_upglob ) ) || typeset -g " _p9k__segment_val_ ${ _p9k__prompt_side } [_p9k__segment_index] " = $_p9k__prompt [ len+1,-1]
2019-06-01 23:54:53 +08:00
}
2019-10-19 18:33:39 +08:00
instant_prompt_root_indicator( ) { prompt_root_indicator; }
2019-06-01 23:54:53 +08:00
################################################################
# Segment to display Rust version number
prompt_rust_version( ) {
2020-01-13 22:17:29 +08:00
unset P9K_RUST_VERSION
2019-08-12 14:56:47 +08:00
if ( ( _POWERLEVEL9K_RUST_VERSION_PROJECT_ONLY ) ) ; then
2020-01-28 16:59:54 +08:00
_p9k_upglob Cargo.toml && return
2019-08-12 14:56:47 +08:00
fi
2020-01-14 00:21:51 +08:00
local rustc = $commands [ rustc] toolchain deps = ( )
2019-12-06 21:46:45 +08:00
if ( ( $+commands[ ldd] ) ) ; then
2020-01-13 22:13:44 +08:00
if ! _p9k_cache_stat_get $0 _so $rustc ; then
2020-01-26 23:54:52 +08:00
local line so
2019-12-06 21:46:45 +08:00
for line in " ${ (@f) $( ldd $rustc 2>/dev/null) } " ; do
[ [ $line = = ( #b)[[:space:]]#librustc_driver[^[:space:]]#.so' => '(*)' (0x'[[:xdigit:]]#')' ]] || continue
so = $match [ 1]
break
done
_p9k_cache_stat_set " $so "
fi
2020-02-10 19:59:37 +08:00
deps += $_p9k__cache_val [ 1]
2020-01-13 22:13:44 +08:00
fi
if ( ( $+commands[ rustup] ) ) ; then
2020-01-14 00:21:51 +08:00
local rustup = $commands [ rustup]
2020-01-13 22:13:44 +08:00
local rustup_home = ${ RUSTUP_HOME :- ~/.rustup }
local cfg = ( $rustup_home /settings.toml( .N) )
deps += ( $cfg $rustup_home /update-hashes/*( .N) )
if [ [ -z ${ toolchain : : = $RUSTUP_TOOLCHAIN } ] ] ; then
if ! _p9k_cache_stat_get $0 _overrides $rustup $cfg ; then
local lines = ( ${ (f) " $( rustup override list 2>/dev/null) " } )
2020-01-28 16:59:54 +08:00
if [ [ $lines [ 1] = = "no overrides" ] ] ; then
_p9k_cache_stat_set
else
local MATCH
2020-01-28 18:10:25 +08:00
local keys = ( ${ (@) ${ lines %%[[ : space : ]]#[^[ : space : ]]# } /(#m)*/ ${ (b)MATCH } / } )
2020-01-28 16:59:54 +08:00
local vals = ( ${ (@)lines/(#m)*/ $MATCH [(I)/] ${ MATCH ##*[[ : space : ]] } } )
_p9k_cache_stat_set ${ keys : ^vals }
fi
2020-01-13 22:13:44 +08:00
fi
2020-02-10 19:59:37 +08:00
local -A overrides = ( $_p9k__cache_val )
2020-01-28 16:59:54 +08:00
_p9k_upglob rust-toolchain
local dir = $_p9k__parent_dirs [ $? ]
local -i n m = ${ dir [(I)/] }
local pair
for pair in ${ overrides [(K) $_p9k__cwd /] } ; do
n = ${ pair %% * }
( ( n <= m ) ) && continue
m = n
toolchain = ${ pair #* }
2020-01-13 22:13:44 +08:00
done
2020-01-28 16:59:54 +08:00
if [ [ -z $toolchain && -n $dir ] ] ; then
_p9k_read_word $dir /rust-toolchain
2020-02-10 19:59:37 +08:00
toolchain = $_p9k__ret
2020-01-28 16:59:54 +08:00
fi
2020-01-13 22:13:44 +08:00
fi
2019-12-06 21:46:45 +08:00
fi
2020-01-13 22:13:44 +08:00
if ! _p9k_cache_stat_get $0 _v$toolchain $rustc $deps ; then
2019-12-06 21:46:45 +08:00
_p9k_cache_stat_set " $( $rustc --version 2>/dev/null) "
fi
2020-02-10 19:59:37 +08:00
local v = ${ ${ _p9k__cache_val [1]#rustc } %% * }
2019-12-06 21:46:45 +08:00
[ [ -n $v ] ] || return
2020-02-10 19:59:37 +08:00
typeset -g P9K_RUST_VERSION = $_p9k__cache_val [ 1]
2019-07-25 03:07:28 +08:00
_p9k_prompt_segment " $0 " "darkorange" " $_p9k_color1 " 'RUST_ICON' 0 '' " ${ v // \% /%% } "
2019-06-01 23:54:53 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_rust_version_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$commands[rustc]'
2020-01-26 01:04:06 +08:00
}
2019-06-01 23:54:53 +08:00
# RSpec test ratio
prompt_rspec_stats( ) {
if [ [ -d app && -d spec ] ] ; then
local -a code = ( app/**/*.rb( N) )
( ( $# code ) ) || return
local tests = ( spec/**/*.rb( N) )
2019-07-25 03:07:28 +08:00
_p9k_build_test_stats " $0 " " $# code " " $# tests " "RSpec" 'TEST_ICON'
2019-06-01 23:54:53 +08:00
fi
}
################################################################
# Segment to display Ruby Version Manager information
prompt_rvm( ) {
2019-06-20 18:52:05 +08:00
[ [ $GEM_HOME = = *rvm* && $ruby_string != $rvm_path /bin/ruby ] ] || return
2019-08-10 16:47:22 +08:00
local v = ${ GEM_HOME : t }
( ( _POWERLEVEL9K_RVM_SHOW_GEMSET ) ) || v = ${ v %% ${ rvm_gemset_separator :- @ } * }
( ( _POWERLEVEL9K_RVM_SHOW_PREFIX ) ) || v = ${ v #*- }
2019-06-20 18:52:05 +08:00
[ [ -n $v ] ] || return
2019-07-25 03:07:28 +08:00
_p9k_prompt_segment " $0 " "240" " $_p9k_color1 " 'RUBY_ICON' 0 '' " ${ v // \% /%% } "
2019-06-01 23:54:53 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_rvm_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '${commands[rvm-prompt]:-${${+functions[rvm-prompt]}:#0}}'
2020-01-26 01:04:06 +08:00
}
2019-06-01 23:54:53 +08:00
################################################################
# Segment to display SSH icon when connected
prompt_ssh( ) {
2020-02-12 22:45:23 +08:00
local -i len = $# _p9k__prompt _p9k__has_upglob
2020-01-26 01:04:06 +08:00
_p9k_prompt_segment " $0 " " $_p9k_color1 " "yellow" 'SSH_ICON' 0 '' ''
2020-02-12 22:45:23 +08:00
( ( _p9k__has_upglob ) ) || typeset -g " _p9k__segment_val_ ${ _p9k__prompt_side } [_p9k__segment_index] " = $_p9k__prompt [ len+1,-1]
2020-01-26 01:04:06 +08:00
}
_p9k_prompt_ssh_init( ) {
if ( ( ! P9K_SSH ) ) ; then
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '${:-}'
2019-06-01 23:54:53 +08:00
fi
}
2020-01-26 01:04:06 +08:00
instant_prompt_ssh( ) {
if ( ( ! P9K_SSH ) ) ; then
return
fi
prompt_ssh
}
2019-10-16 23:36:54 +08:00
2019-07-23 21:47:25 +08:00
################################################################
# Status: When an error occur, return the error code, or a cross icon if option is set
# Display an ok icon when no error occur, or hide the segment if option is set to false
2019-06-01 23:54:53 +08:00
prompt_status( ) {
2019-10-25 19:22:50 +08:00
if ! _p9k_cache_get $0 $_p9k__status $_p9k__pipestatus ; then
( ( _p9k__status ) ) && local state = ERROR || local state = OK
2019-07-26 21:35:46 +08:00
if ( ( _POWERLEVEL9K_STATUS_EXTENDED_STATES ) ) ; then
2019-10-25 19:22:50 +08:00
if ( ( _p9k__status ) ) ; then
if ( ( $# _p9k__pipestatus > 1 ) ) ; then
2019-07-26 21:35:46 +08:00
state += _PIPE
2019-10-25 19:22:50 +08:00
elif ( ( _p9k__status > 128 ) ) ; then
2019-07-26 21:35:46 +08:00
state += _SIGNAL
fi
2019-10-25 19:22:50 +08:00
elif [ [ " $_p9k__pipestatus " = = *[ 1-9] * ] ] ; then
2019-07-26 21:35:46 +08:00
state += _PIPE
2019-06-01 23:54:53 +08:00
fi
fi
2020-02-10 19:59:37 +08:00
_p9k__cache_val = ( :)
2019-07-26 21:35:46 +08:00
if ( ( _POWERLEVEL9K_STATUS_$state ) ) ; then
2019-07-27 18:09:09 +08:00
if ( ( _POWERLEVEL9K_STATUS_SHOW_PIPESTATUS ) ) ; then
2019-10-25 19:22:50 +08:00
local text = ${ (j : | : ) ${ (@)_p9k__pipestatus : /(#b)(*)/ $_p9k_exitcode2str [ $match [1]+1] } }
2019-07-27 18:09:09 +08:00
else
2019-10-25 19:22:50 +08:00
local text = $_p9k_exitcode2str [ _p9k__status+1]
2019-07-27 18:09:09 +08:00
fi
2019-10-25 19:22:50 +08:00
if ( ( _p9k__status ) ) ; then
2019-07-26 21:35:46 +08:00
if ( ( !_POWERLEVEL9K_STATUS_CROSS && _POWERLEVEL9K_STATUS_VERBOSE ) ) ; then
2020-02-10 19:59:37 +08:00
_p9k__cache_val = ( $0 _$state red yellow1 CARRIAGE_RETURN_ICON 0 '' " $text " )
2019-07-26 21:35:46 +08:00
else
2020-02-10 19:59:37 +08:00
_p9k__cache_val = ( $0 _$state $_p9k_color1 red FAIL_ICON 0 '' '' )
2019-07-26 21:35:46 +08:00
fi
elif ( ( _POWERLEVEL9K_STATUS_VERBOSE || _POWERLEVEL9K_STATUS_OK_IN_NON_VERBOSE ) ) ; then
[ [ $state = = OK ] ] && text = ''
2020-02-10 19:59:37 +08:00
_p9k__cache_val = ( $0 _$state " $_p9k_color1 " green OK_ICON 0 '' " $text " )
2019-06-01 23:54:53 +08:00
fi
fi
2019-10-25 19:22:50 +08:00
if ( ( $# _p9k__pipestatus < 3 ) ) ; then
2020-02-10 19:59:37 +08:00
_p9k_cache_set " ${ (@)_p9k__cache_val } "
2019-06-01 23:54:53 +08:00
fi
fi
2020-02-10 19:59:37 +08:00
_p9k_prompt_segment " ${ (@)_p9k__cache_val } "
2019-06-01 23:54:53 +08:00
}
2019-10-16 23:36:54 +08:00
instant_prompt_status( ) {
if ( ( _POWERLEVEL9K_STATUS_OK ) ) ; then
_p9k_prompt_segment prompt_status_OK " $_p9k_color1 " green OK_ICON 0 '' ''
fi
}
2019-07-12 21:46:53 +08:00
prompt_prompt_char( ) {
2020-02-17 05:23:57 +08:00
local saved = $_p9k__prompt_char_saved [ $_p9k__prompt_side $_p9k__segment_index $(( !_p9k__status)) ]
2020-01-26 23:54:52 +08:00
if [ [ -n $saved ] ] ; then
_p9k__prompt += $saved
return
fi
2020-02-12 22:45:23 +08:00
local -i len = $# _p9k__prompt _p9k__has_upglob
2019-09-20 17:22:14 +08:00
if ( ( __p9k_sh_glob ) ) ; then
2019-10-25 19:22:50 +08:00
if ( ( _p9k__status ) ) ; then
2019-09-20 17:22:14 +08:00
if ( ( _POWERLEVEL9K_PROMPT_CHAR_OVERWRITE_STATE ) ) ; then
2019-10-25 19:22:50 +08:00
_p9k_prompt_segment $0 _ERROR_VIINS " $_p9k_color1 " 196 '' 0 '${${${${${${:-$_p9k__keymap.$_p9k__zle_state}:#vicmd.*}:#vivis.*}:#vivli.*}:#*.*overwrite*}}' '❯ '
_p9k_prompt_segment $0 _ERROR_VIOWR " $_p9k_color1 " 196 '' 0 '${${${${${${:-$_p9k__keymap.$_p9k__zle_state}:#vicmd.*}:#vivis.*}:#vivli.*}:#*.*insert*}}' '▶'
2019-09-20 17:22:14 +08:00
else
2019-10-25 19:22:50 +08:00
_p9k_prompt_segment $0 _ERROR_VIINS " $_p9k_color1 " 196 '' 0 '${${${${_p9k__keymap:#vicmd}:#vivis}:#vivli}}' '❯ '
2019-09-20 17:22:14 +08:00
fi
2019-10-25 19:22:50 +08:00
_p9k_prompt_segment $0 _ERROR_VICMD " $_p9k_color1 " 196 '' 0 '${(M)${:-$_p9k__keymap$_p9k__region_active}:#vicmd0}' '❮ '
_p9k_prompt_segment $0 _ERROR_VIVIS " $_p9k_color1 " 196 '' 0 '${$((! ${#${${${${:-$_p9k__keymap$_p9k__region_active}:#vicmd1}:#vivis?}:#vivli?}})):#0}' 'Ⅴ '
2019-09-18 19:38:31 +08:00
else
2019-09-20 17:22:14 +08:00
if ( ( _POWERLEVEL9K_PROMPT_CHAR_OVERWRITE_STATE ) ) ; then
2019-10-25 19:22:50 +08:00
_p9k_prompt_segment $0 _OK_VIINS " $_p9k_color1 " 76 '' 0 '${${${${${${:-$_p9k__keymap.$_p9k__zle_state}:#vicmd.*}:#vivis.*}:#vivli.*}:#*.*overwrite*}}' '❯ '
_p9k_prompt_segment $0 _OK_VIOWR " $_p9k_color1 " 76 '' 0 '${${${${${${:-$_p9k__keymap.$_p9k__zle_state}:#vicmd.*}:#vivis.*}:#vivli.*}:#*.*insert*}}' '▶'
2019-09-20 17:22:14 +08:00
else
2019-10-25 19:22:50 +08:00
_p9k_prompt_segment $0 _OK_VIINS " $_p9k_color1 " 76 '' 0 '${${${${_p9k__keymap:#vicmd}:#vivis}:#vivli}}' '❯ '
2019-09-20 17:22:14 +08:00
fi
2019-10-25 19:22:50 +08:00
_p9k_prompt_segment $0 _OK_VICMD " $_p9k_color1 " 76 '' 0 '${(M)${:-$_p9k__keymap$_p9k__region_active}:#vicmd0}' '❮ '
_p9k_prompt_segment $0 _OK_VIVIS " $_p9k_color1 " 76 '' 0 '${$((! ${#${${${${:-$_p9k__keymap$_p9k__region_active}:#vicmd1}:#vivis?}:#vivli?}})):#0}' 'Ⅴ '
2019-09-18 19:38:31 +08:00
fi
2019-07-12 21:46:53 +08:00
else
2019-10-25 19:22:50 +08:00
if ( ( _p9k__status ) ) ; then
2019-09-20 17:22:14 +08:00
if ( ( _POWERLEVEL9K_PROMPT_CHAR_OVERWRITE_STATE ) ) ; then
2019-10-25 19:22:50 +08:00
_p9k_prompt_segment $0 _ERROR_VIINS " $_p9k_color1 " 196 '' 0 '${${:-$_p9k__keymap.$_p9k__zle_state}:#(vicmd.*|vivis.*|vivli.*|*.*overwrite*)}' '❯ '
_p9k_prompt_segment $0 _ERROR_VIOWR " $_p9k_color1 " 196 '' 0 '${${:-$_p9k__keymap.$_p9k__zle_state}:#(vicmd.*|vivis.*|vivli.*|*.*insert*)}' '▶'
2019-09-20 17:22:14 +08:00
else
2019-10-25 19:22:50 +08:00
_p9k_prompt_segment $0 _ERROR_VIINS " $_p9k_color1 " 196 '' 0 '${_p9k__keymap:#(vicmd|vivis|vivli)}' '❯ '
2019-09-20 17:22:14 +08:00
fi
2019-10-25 19:22:50 +08:00
_p9k_prompt_segment $0 _ERROR_VICMD " $_p9k_color1 " 196 '' 0 '${(M)${:-$_p9k__keymap$_p9k__region_active}:#vicmd0}' '❮ '
_p9k_prompt_segment $0 _ERROR_VIVIS " $_p9k_color1 " 196 '' 0 '${(M)${:-$_p9k__keymap$_p9k__region_active}:#(vicmd1|vivis?|vivli?)}' 'Ⅴ '
2019-09-18 19:38:31 +08:00
else
2019-09-20 17:22:14 +08:00
if ( ( _POWERLEVEL9K_PROMPT_CHAR_OVERWRITE_STATE ) ) ; then
2019-10-25 19:22:50 +08:00
_p9k_prompt_segment $0 _OK_VIINS " $_p9k_color1 " 76 '' 0 '${${:-$_p9k__keymap.$_p9k__zle_state}:#(vicmd.*|vivis.*|vivli.*|*.*overwrite*)}' '❯ '
_p9k_prompt_segment $0 _OK_VIOWR " $_p9k_color1 " 76 '' 0 '${${:-$_p9k__keymap.$_p9k__zle_state}:#(vicmd.*|vivis.*|vivli.*|*.*insert*)}' '▶'
2019-09-20 17:22:14 +08:00
else
2019-10-25 19:22:50 +08:00
_p9k_prompt_segment $0 _OK_VIINS " $_p9k_color1 " 76 '' 0 '${_p9k__keymap:#(vicmd|vivis|vivli)}' '❯ '
2019-09-20 17:22:14 +08:00
fi
2019-10-25 19:22:50 +08:00
_p9k_prompt_segment $0 _OK_VICMD " $_p9k_color1 " 76 '' 0 '${(M)${:-$_p9k__keymap$_p9k__region_active}:#vicmd0}' '❮ '
_p9k_prompt_segment $0 _OK_VIVIS " $_p9k_color1 " 76 '' 0 '${(M)${:-$_p9k__keymap$_p9k__region_active}:#(vicmd1|vivis?|vivli?)}' 'Ⅴ '
2019-09-18 19:38:31 +08:00
fi
2019-07-12 21:46:53 +08:00
fi
2020-02-17 05:23:57 +08:00
( ( _p9k__has_upglob ) ) || _p9k__prompt_char_saved[ $_p9k__prompt_side $_p9k__segment_index $(( !_p9k__status)) ] = $_p9k__prompt [ len+1,-1]
2019-07-12 21:46:53 +08:00
}
2019-10-16 23:36:54 +08:00
instant_prompt_prompt_char( ) {
2019-10-19 20:55:38 +08:00
_p9k_prompt_segment prompt_prompt_char_OK_VIINS " $_p9k_color1 " 76 '' 0 '' '❯ '
2019-10-16 23:36:54 +08:00
}
2019-06-01 23:54:53 +08:00
################################################################
# Segment to display Swap information
prompt_swap( ) {
2020-02-12 22:45:23 +08:00
local -i len = $# _p9k__prompt _p9k__has_upglob
2020-01-26 01:04:06 +08:00
_p9k_prompt_segment $0 yellow " $_p9k_color1 " SWAP_ICON 1 '$_p9k__swap_used' '$_p9k__swap_used'
2020-02-12 22:45:23 +08:00
( ( _p9k__has_upglob ) ) || typeset -g " _p9k__segment_val_ ${ _p9k__prompt_side } [_p9k__segment_index] " = $_p9k__prompt [ len+1,-1]
2020-01-26 01:04:06 +08:00
}
function _p9k_prompt_swap_init( ) {
if [ [ $_p9k_os = = OSX && $+commands[ sysctl] = = 0 || $_p9k_os != OSX && ! -r /proc/meminfo ] ] ; then
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '${:-}'
2020-01-26 01:04:06 +08:00
return
fi
typeset -g _p9k__swap_used =
_p9k__async_segments_compute += _p9k_prompt_swap_compute
}
_p9k_prompt_swap_compute( ) {
_p9k_worker_async _p9k_prompt_swap_async _p9k_prompt_swap_sync
}
_p9k_prompt_swap_async( ) {
2019-06-01 23:54:53 +08:00
local -F used_bytes
2019-07-24 20:34:26 +08:00
if [ [ " $_p9k_os " = = "OSX" ] ] ; then
2019-06-01 23:54:53 +08:00
( ( $+commands[ sysctl] ) ) || return
2019-07-24 21:52:54 +08:00
[ [ " $( sysctl vm.swapusage 2>/dev/null) " = ~ "used = ([0-9,.]+)([A-Z]+)" ] ] || return
2019-06-01 23:54:53 +08:00
used_bytes = ${ match [1]//,/. }
case ${ match [2] } in
'K' ) ( ( used_bytes *= 1024 ) ) ; ;
'M' ) ( ( used_bytes *= 1048576 ) ) ; ;
'G' ) ( ( used_bytes *= 1073741824 ) ) ; ;
'T' ) ( ( used_bytes *= 1099511627776 ) ) ; ;
2019-11-04 16:07:06 +08:00
*) return 0; ;
2019-06-01 23:54:53 +08:00
esac
else
2019-07-29 20:18:57 +08:00
local meminfo && meminfo = " $( grep -F 'Swap' /proc/meminfo 2>/dev/null) " || return
2019-06-01 23:54:53 +08:00
[ [ $meminfo = ~ 'SwapTotal:[[:space:]]+([0-9]+)' ] ] || return
( ( used_bytes += match[ 1] ) )
[ [ $meminfo = ~ 'SwapFree:[[:space:]]+([0-9]+)' ] ] || return
( ( used_bytes-= match[ 1] ) )
( ( used_bytes *= 1024 ) )
fi
_p9k_human_readable_bytes $used_bytes
2020-02-10 19:59:37 +08:00
[ [ $_p9k__ret != $_p9k__swap_used ] ] || return
_p9k__swap_used = $_p9k__ret
2020-01-26 21:46:50 +08:00
_p9k_print_params _p9k__swap_used
2020-01-26 01:04:06 +08:00
echo -E - 'reset=1'
}
_p9k_prompt_swap_sync( ) {
eval $REPLY
_p9k_worker_reply $REPLY
2019-06-01 23:54:53 +08:00
}
################################################################
# Symfony2-PHPUnit test ratio
prompt_symfony2_tests( ) {
if [ [ -d src && -d app && -f app/AppKernel.php ] ] ; then
local -a all = ( src/**/*.php( N) )
local -a code = ( ${ (@)all##*Tests* } )
( ( $# code ) ) || return
2019-07-25 03:07:28 +08:00
_p9k_build_test_stats " $0 " " $# code " " $(( $# all - $# code)) " "SF2" 'TEST_ICON'
2019-06-01 23:54:53 +08:00
fi
}
################################################################
# Segment to display Symfony2-Version
prompt_symfony2_version( ) {
if [ [ -r app/bootstrap.php.cache ] ] ; then
2019-07-24 21:52:54 +08:00
local v = " ${ $( grep -F " VERSION " app/bootstrap.php.cache 2>/dev/null) //[![ : digit : ].] } "
2019-07-25 03:07:28 +08:00
_p9k_prompt_segment " $0 " "grey35" " $_p9k_color1 " 'SYMFONY_ICON' 0 '' " ${ v // \% /%% } "
2019-06-01 23:54:53 +08:00
fi
}
################################################################
# Show a ratio of tests vs code
2019-07-25 03:07:28 +08:00
_p9k_build_test_stats( ) {
local code_amount = " $2 "
local tests_amount = " $3 "
local headline = " $4 "
2019-06-01 23:54:53 +08:00
( ( code_amount > 0 ) ) || return
local -F 2 ratio = $(( 100 . * tests_amount / code_amount ))
2019-07-25 03:07:28 +08:00
( ( ratio >= 75 ) ) && _p9k_prompt_segment " ${ 1 } _GOOD " "cyan" " $_p9k_color1 " " $5 " 0 '' " $headline : $ratio %% "
( ( ratio >= 50 && ratio < 75 ) ) && _p9k_prompt_segment " $1 _AVG " "yellow" " $_p9k_color1 " " $5 " 0 '' " $headline : $ratio %% "
( ( ratio < 50 ) ) && _p9k_prompt_segment " $1 _BAD " "red" " $_p9k_color1 " " $5 " 0 '' " $headline : $ratio %% "
2019-06-01 23:54:53 +08:00
}
################################################################
# System time
prompt_time( ) {
2019-07-23 21:47:25 +08:00
if ( ( _POWERLEVEL9K_EXPERIMENTAL_TIME_REALTIME ) ) ; then
2019-07-25 03:07:28 +08:00
_p9k_prompt_segment " $0 " " $_p9k_color2 " " $_p9k_color1 " "TIME_ICON" 0 '' " $_POWERLEVEL9K_TIME_FORMAT "
2019-07-18 05:24:53 +08:00
else
2020-02-10 19:59:37 +08:00
if [ [ $_p9k__refresh_reason = = precmd ] ] ; then
2019-10-19 18:33:39 +08:00
if [ [ $+__p9k_instant_prompt_active = = 1 && $__p9k_instant_prompt_time_format = = $_POWERLEVEL9K_TIME_FORMAT ] ] ; then
2020-02-10 19:59:37 +08:00
_p9k__time = ${ __p9k_instant_prompt_time // \% /%% }
2019-10-19 18:33:39 +08:00
else
2020-02-10 19:59:37 +08:00
_p9k__time = ${ ${ (%)_POWERLEVEL9K_TIME_FORMAT } // \% /%% }
2019-10-19 18:33:39 +08:00
fi
fi
2019-07-23 21:47:25 +08:00
if ( ( _POWERLEVEL9K_TIME_UPDATE_ON_COMMAND ) ) ; then
2020-02-10 19:59:37 +08:00
_p9k_escape $_p9k__time
local t = $_p9k__ret
2019-07-23 21:47:25 +08:00
_p9k_escape $_POWERLEVEL9K_TIME_FORMAT
2019-07-25 03:07:28 +08:00
_p9k_prompt_segment " $0 " " $_p9k_color2 " " $_p9k_color1 " "TIME_ICON" 1 '' \
2020-02-10 19:59:37 +08:00
" \${_p9k__line_finished- $t }\${_p9k__line_finished+ $_p9k__ret } "
2019-07-17 14:45:11 +08:00
else
2020-02-10 19:59:37 +08:00
_p9k_prompt_segment " $0 " " $_p9k_color2 " " $_p9k_color1 " "TIME_ICON" 0 '' $_p9k__time
2019-07-17 14:45:11 +08:00
fi
fi
2019-06-01 23:54:53 +08:00
}
2019-10-16 23:36:54 +08:00
instant_prompt_time( ) {
2019-10-19 18:33:39 +08:00
_p9k_escape $_POWERLEVEL9K_TIME_FORMAT
2020-02-10 19:59:37 +08:00
local stash = '${${__p9k_instant_prompt_time::=${(%)${__p9k_instant_prompt_time_format::=' $_p9k__ret '}}}+}'
2019-10-19 18:33:39 +08:00
_p9k_escape $_POWERLEVEL9K_TIME_FORMAT
2020-02-10 19:59:37 +08:00
_p9k_prompt_segment prompt_time " $_p9k_color2 " " $_p9k_color1 " "TIME_ICON" 1 '' $stash $_p9k__ret
2019-10-16 23:36:54 +08:00
}
2020-01-18 22:58:48 +08:00
_p9k_prompt_time_init( ) {
( ( _POWERLEVEL9K_EXPERIMENTAL_TIME_REALTIME ) ) || return
2020-01-21 03:12:05 +08:00
_p9k__async_segments_compute += _p9k_prompt_time_compute
2020-01-18 22:58:48 +08:00
}
2020-01-25 18:01:14 +08:00
_p9k_prompt_time_compute( ) {
_p9k_worker_async _p9k_prompt_time_async _p9k_prompt_time_sync
}
2020-01-21 06:37:03 +08:00
_p9k_prompt_time_async( ) {
sleep 1 || true
2020-01-21 03:12:05 +08:00
}
_p9k_prompt_time_sync( ) {
2020-01-25 18:01:14 +08:00
_p9k_worker_reply '_p9k_worker_invoke _p9k_prompt_time_compute _p9k_prompt_time_compute; reset=1'
2020-01-18 22:58:48 +08:00
}
2019-06-01 23:54:53 +08:00
################################################################
# System date
prompt_date( ) {
2020-02-10 19:59:37 +08:00
if [ [ $_p9k__refresh_reason = = precmd ] ] ; then
2019-10-19 18:33:39 +08:00
if [ [ $+__p9k_instant_prompt_active = = 1 && $__p9k_instant_prompt_date_format = = $_POWERLEVEL9K_DATE_FORMAT ] ] ; then
2020-02-10 19:59:37 +08:00
_p9k__date = ${ __p9k_instant_prompt_date // \% /%% }
2019-10-19 18:33:39 +08:00
else
2020-02-10 19:59:37 +08:00
_p9k__date = ${ ${ (%)_POWERLEVEL9K_DATE_FORMAT } // \% /%% }
2019-10-19 18:33:39 +08:00
fi
fi
2020-02-10 19:59:37 +08:00
_p9k_prompt_segment " $0 " " $_p9k_color2 " " $_p9k_color1 " "DATE_ICON" 0 '' " $_p9k__date "
2019-06-01 23:54:53 +08:00
}
2019-10-16 23:36:54 +08:00
instant_prompt_date( ) {
2019-10-19 18:33:39 +08:00
_p9k_escape $_POWERLEVEL9K_DATE_FORMAT
2020-02-10 19:59:37 +08:00
local stash = '${${__p9k_instant_prompt_date::=${(%)${__p9k_instant_prompt_date_format::=' $_p9k__ret '}}}+}'
2019-10-19 18:33:39 +08:00
_p9k_escape $_POWERLEVEL9K_DATE_FORMAT
2020-02-10 19:59:37 +08:00
_p9k_prompt_segment prompt_date " $_p9k_color2 " " $_p9k_color1 " "DATE_ICON" 1 '' $stash $_p9k__ret
2019-10-16 23:36:54 +08:00
}
2019-06-01 23:54:53 +08:00
################################################################
# todo.sh: shows the number of tasks in your todo.sh file
prompt_todo( ) {
2019-10-22 03:31:44 +08:00
unset P9K_TODO_TOTAL_TASK_COUNT P9K_TODO_FILTERED_TASK_COUNT
2020-02-10 19:59:37 +08:00
[ [ -r $_p9k__todo_file ] ] || return
2019-06-01 23:54:53 +08:00
local todo = $commands [ todo.sh]
2020-02-10 19:59:37 +08:00
if ! _p9k_cache_stat_get $0 $_p9k__todo_file ; then
2019-07-24 20:34:26 +08:00
local count = " $( $todo -p ls | tail -1) "
2019-10-22 03:31:44 +08:00
if [ [ $count = = ( #b)'TODO: '([[:digit:]]##)' of '([[:digit:]]##)' '* ]]; then
_p9k_cache_stat_set 1 $match [ 1] $match [ 2]
2019-06-01 23:54:53 +08:00
else
2019-10-22 03:31:44 +08:00
_p9k_cache_stat_set 0
2019-06-01 23:54:53 +08:00
fi
fi
2020-02-10 19:59:37 +08:00
( ( $_p9k__cache_val [ 1] ) ) || return
typeset -gi P9K_TODO_FILTERED_TASK_COUNT = $_p9k__cache_val [ 2]
typeset -gi P9K_TODO_TOTAL_TASK_COUNT = $_p9k__cache_val [ 3]
2020-01-03 16:56:33 +08:00
if ( ( ( P9K_TODO_TOTAL_TASK_COUNT || !_POWERLEVEL9K_TODO_HIDE_ZERO_TOTAL) &&
( P9K_TODO_FILTERED_TASK_COUNT || !_POWERLEVEL9K_TODO_HIDE_ZERO_FILTERED) ) ) ; then
if ( ( P9K_TODO_TOTAL_TASK_COUNT = = P9K_TODO_FILTERED_TASK_COUNT ) ) ; then
local text = $P9K_TODO_TOTAL_TASK_COUNT
else
local text = " $P9K_TODO_FILTERED_TASK_COUNT / $P9K_TODO_TOTAL_TASK_COUNT "
fi
_p9k_prompt_segment " $0 " "grey50" " $_p9k_color1 " 'TODO_ICON' 0 '' " $text "
fi
2019-06-01 23:54:53 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_todo_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$commands[todo.sh]'
2020-01-26 01:04:06 +08:00
}
2019-06-01 23:54:53 +08:00
################################################################
# VCS segment: shows the state of your repository, if you are in a folder under
# version control
2019-07-11 02:06:19 +08:00
# The vcs segment can have 4 different states - defaults to 'CLEAN'.
2019-07-24 20:34:26 +08:00
typeset -gA __p9k_vcs_states = (
2019-07-09 22:08:43 +08:00
'CLEAN' '2'
'MODIFIED' '3'
'UNTRACKED' '2'
'LOADING' '8'
2019-09-18 19:20:33 +08:00
'CONFLICTED' '3'
2019-06-01 23:54:53 +08:00
)
2019-07-24 21:01:26 +08:00
function +vi-git-untracked( ) {
[ [ -z " ${ vcs_comm [gitdir] } " || " ${ vcs_comm [gitdir] } " = = "." ] ] && return
# get the root for the current repo or submodule
2019-07-24 21:52:54 +08:00
local repoTopLevel = " $( git rev-parse --show-toplevel 2> /dev/null) "
2019-07-24 21:01:26 +08:00
# dump out if we're outside a git repository (which includes being in the .git folder)
[ [ $? != 0 || -z $repoTopLevel ] ] && return
2019-07-29 20:18:57 +08:00
local untrackedFiles = " $( git ls-files --others --exclude-standard " ${ repoTopLevel } " 2> /dev/null) "
2019-07-24 21:01:26 +08:00
if [ [ -z $untrackedFiles && $_POWERLEVEL9K_VCS_SHOW_SUBMODULE_DIRTY = = 1 ] ] ; then
2019-07-29 20:18:57 +08:00
untrackedFiles += " $( git submodule foreach --quiet --recursive 'git ls-files --others --exclude-standard' 2> /dev/null) "
2019-07-24 21:01:26 +08:00
fi
[ [ -z $untrackedFiles ] ] && return
hook_com[ unstaged] += " $( print_icon 'VCS_UNTRACKED_ICON' ) "
VCS_WORKDIR_HALF_DIRTY = true
}
function +vi-git-aheadbehind( ) {
2019-07-25 03:07:28 +08:00
local ahead behind
local -a gitstatus
2019-07-24 21:01:26 +08:00
2019-07-25 03:07:28 +08:00
# for git prior to 1.7
# ahead=$(git rev-list origin/${hook_com[branch]}..HEAD | wc -l)
2019-07-29 20:18:57 +08:00
ahead = " $( git rev-list --count " ${ hook_com [branch] } " @{ upstream} ..HEAD 2>/dev/null) "
2019-07-25 03:07:28 +08:00
( ( ahead ) ) && gitstatus += ( " $( print_icon 'VCS_OUTGOING_CHANGES_ICON' ) ${ ahead // / } " )
2019-07-24 21:01:26 +08:00
2019-07-25 03:07:28 +08:00
# for git prior to 1.7
# behind=$(git rev-list HEAD..origin/${hook_com[branch]} | wc -l)
2019-07-29 20:18:57 +08:00
behind = " $( git rev-list --count HEAD.." ${ hook_com [branch] } " @{ upstream} 2>/dev/null) "
2019-07-25 03:07:28 +08:00
( ( behind ) ) && gitstatus += ( " $( print_icon 'VCS_INCOMING_CHANGES_ICON' ) ${ behind // / } " )
2019-07-24 21:01:26 +08:00
2019-07-25 03:07:28 +08:00
hook_com[ misc] += ${ (j : : )gitstatus }
2019-07-24 21:01:26 +08:00
}
function +vi-git-remotebranch( ) {
2019-07-25 03:07:28 +08:00
local remote
local branch_name = " ${ hook_com [branch] } "
# Are we on a remote-tracking branch?
2019-07-29 20:18:57 +08:00
remote = " $( git rev-parse --verify HEAD@{ upstream} --symbolic-full-name 2>/dev/null) "
remote = ${ remote /refs \/ (remotes|heads) \/ }
2019-07-25 03:07:28 +08:00
if ( ( $+_POWERLEVEL9K_VCS_SHORTEN_LENGTH && $+_POWERLEVEL9K_VCS_SHORTEN_MIN_LENGTH ) ) ; then
if ( ( ${# hook_com [branch] } > _POWERLEVEL9K_VCS_SHORTEN_MIN_LENGTH && ${# hook_com [branch] } > _POWERLEVEL9K_VCS_SHORTEN_LENGTH ) ) ; then
case $_POWERLEVEL9K_VCS_SHORTEN_STRATEGY in
truncate_middle)
hook_com[ branch] = " ${ branch_name : 0 : $_POWERLEVEL9K_VCS_SHORTEN_LENGTH } ${ _POWERLEVEL9K_VCS_SHORTEN_DELIMITER } ${ branch_name : - $_POWERLEVEL9K_VCS_SHORTEN_LENGTH } "
; ;
truncate_from_right)
hook_com[ branch] = " ${ branch_name : 0 : $_POWERLEVEL9K_VCS_SHORTEN_LENGTH } ${ _POWERLEVEL9K_VCS_SHORTEN_DELIMITER } "
; ;
esac
2019-07-24 21:01:26 +08:00
fi
2019-07-25 03:07:28 +08:00
fi
if ( ( _POWERLEVEL9K_HIDE_BRANCH_ICON ) ) ; then
hook_com[ branch] = " ${ hook_com [branch] } "
else
hook_com[ branch] = " $( print_icon 'VCS_BRANCH_ICON' ) ${ hook_com [branch] } "
fi
# Always show the remote
#if [[ -n ${remote} ]] ; then
# Only show the remote if it differs from the local
if [ [ -n ${ remote } ] ] && [ [ " ${ remote #*/ } " != " ${ branch_name } " ] ] ; then
hook_com[ branch] += " $( print_icon 'VCS_REMOTE_BRANCH_ICON' ) ${ remote // / } "
fi
2019-07-24 21:01:26 +08:00
}
function +vi-git-tagname( ) {
if ( ( !_POWERLEVEL9K_VCS_HIDE_TAGS ) ) ; then
2019-07-25 03:07:28 +08:00
# If we are on a tag, append the tagname to the current branch string.
local tag
2019-07-29 20:18:57 +08:00
tag = " $( git describe --tags --exact-match HEAD 2>/dev/null) "
2019-07-25 03:07:28 +08:00
if [ [ -n " ${ tag } " ] ] ; then
# There is a tag that points to our current commit. Need to determine if we
# are also on a branch, or are in a DETACHED_HEAD state.
2019-07-29 20:18:57 +08:00
if [ [ -z " $( git symbolic-ref HEAD 2>/dev/null) " ] ] ; then
2019-07-25 03:07:28 +08:00
# DETACHED_HEAD state. We want to append the tag name to the commit hash
# and print it. Unfortunately, `vcs_info` blows away the hash when a tag
# exists, so we have to manually retrieve it and clobber the branch
# string.
local revision
2019-07-29 20:18:57 +08:00
revision = " $( git rev-list -n 1 --abbrev-commit --abbrev= ${ _POWERLEVEL9K_CHANGESET_HASH_LENGTH } HEAD) "
2019-07-25 03:07:28 +08:00
if ( ( _POWERLEVEL9K_HIDE_BRANCH_ICON ) ) ; then
hook_com[ branch] = " ${ revision } $( print_icon 'VCS_TAG_ICON' ) ${ tag } "
else
hook_com[ branch] = " $( print_icon 'VCS_BRANCH_ICON' ) ${ revision } $( print_icon 'VCS_TAG_ICON' ) ${ tag } "
fi
else
# We are on both a tag and a branch; print both by appending the tag name.
hook_com[ branch] += " $( print_icon 'VCS_TAG_ICON' ) ${ tag } "
2019-07-24 21:01:26 +08:00
fi
2019-07-25 03:07:28 +08:00
fi
2019-07-24 21:01:26 +08:00
fi
}
# Show count of stashed changes
# Port from https://github.com/whiteinge/dotfiles/blob/5dfd08d30f7f2749cfc60bc55564c6ea239624d9/.zsh_shouse_prompt#L268
function +vi-git-stash( ) {
if [ [ -s " ${ vcs_comm [gitdir] } /logs/refs/stash " ] ] ; then
local -a stashes = ( " ${ (@f) " $( <${ vcs_comm [gitdir] } /logs/refs/stash) " } " )
hook_com[ misc] += " $( print_icon 'VCS_STASH_ICON' ) ${# stashes } "
fi
}
function +vi-hg-bookmarks( ) {
if [ [ -n " ${ hgbmarks [@] } " ] ] ; then
hook_com[ hg-bookmark-string] = " $( print_icon 'VCS_BOOKMARK_ICON' ) ${ hgbmarks [@] } "
# To signal that we want to use the sting we just generated, set the special
# variable `ret' to something other than the default zero:
ret = 1
return 0
fi
}
function +vi-vcs-detect-changes( ) {
if [ [ " ${ hook_com [vcs] } " = = "git" ] ] ; then
2019-07-29 20:18:57 +08:00
local remote = " $( git ls-remote --get-url 2> /dev/null) "
2019-07-24 21:01:26 +08:00
if [ [ " $remote " = ~ "github" ] ] then
vcs_visual_identifier = 'VCS_GIT_GITHUB_ICON'
elif [ [ " $remote " = ~ "bitbucket" ] ] then
vcs_visual_identifier = 'VCS_GIT_BITBUCKET_ICON'
elif [ [ " $remote " = ~ "stash" ] ] then
vcs_visual_identifier = 'VCS_GIT_BITBUCKET_ICON'
elif [ [ " $remote " = ~ "gitlab" ] ] then
vcs_visual_identifier = 'VCS_GIT_GITLAB_ICON'
else
vcs_visual_identifier = 'VCS_GIT_ICON'
fi
elif [ [ " ${ hook_com [vcs] } " = = "hg" ] ] ; then
vcs_visual_identifier = 'VCS_HG_ICON'
elif [ [ " ${ hook_com [vcs] } " = = "svn" ] ] ; then
vcs_visual_identifier = 'VCS_SVN_ICON'
fi
if [ [ -n " ${ hook_com [staged] } " ] ] || [ [ -n " ${ hook_com [unstaged] } " ] ] ; then
VCS_WORKDIR_DIRTY = true
else
VCS_WORKDIR_DIRTY = false
fi
}
function +vi-svn-detect-changes( ) {
local svn_status = " $( svn status) "
if [ [ -n " $( echo " $svn_status " | \g rep \^ \? ) " ] ] ; then
hook_com[ unstaged] += " $( print_icon 'VCS_UNTRACKED_ICON' ) "
VCS_WORKDIR_HALF_DIRTY = true
fi
if [ [ -n " $( echo " $svn_status " | \g rep \^ \M ) " ] ] ; then
hook_com[ unstaged] += " $( print_icon 'VCS_UNSTAGED_ICON' ) "
VCS_WORKDIR_DIRTY = true
fi
if [ [ -n " $( echo " $svn_status " | \g rep \^ \A ) " ] ] ; then
hook_com[ staged] += " $( print_icon 'VCS_STAGED_ICON' ) "
VCS_WORKDIR_DIRTY = true
fi
}
2019-07-25 03:07:28 +08:00
_p9k_vcs_info_init( ) {
2019-06-01 23:54:53 +08:00
autoload -Uz vcs_info
2019-07-23 21:47:25 +08:00
local prefix = ''
if ( ( _POWERLEVEL9K_SHOW_CHANGESET ) ) ; then
_p9k_get_icon '' VCS_COMMIT_ICON
2020-02-10 19:59:37 +08:00
prefix = " $_p9k__ret %0. ${ _POWERLEVEL9K_CHANGESET_HASH_LENGTH } i "
2019-06-01 23:54:53 +08:00
fi
zstyle ':vcs_info:*' check-for-changes true
2019-07-23 21:47:25 +08:00
zstyle ':vcs_info:*' formats " $prefix %b%c%u%m "
zstyle ':vcs_info:*' actionformats " %b %F{ $_POWERLEVEL9K_VCS_ACTIONFORMAT_FOREGROUND }| %a%f "
_p9k_get_icon '' VCS_STAGED_ICON
2020-02-10 19:59:37 +08:00
zstyle ':vcs_info:*' stagedstr " $_p9k__ret "
2019-07-23 21:47:25 +08:00
_p9k_get_icon '' VCS_UNSTAGED_ICON
2020-02-10 19:59:37 +08:00
zstyle ':vcs_info:*' unstagedstr " $_p9k__ret "
2019-07-23 21:47:25 +08:00
zstyle ':vcs_info:git*+set-message:*' hooks $_POWERLEVEL9K_VCS_GIT_HOOKS
zstyle ':vcs_info:hg*+set-message:*' hooks $_POWERLEVEL9K_VCS_HG_HOOKS
zstyle ':vcs_info:svn*+set-message:*' hooks $_POWERLEVEL9K_VCS_SVN_HOOKS
2019-06-01 23:54:53 +08:00
# For Hg, only show the branch name
2019-07-23 21:47:25 +08:00
if ( ( _POWERLEVEL9K_HIDE_BRANCH_ICON ) ) ; then
zstyle ':vcs_info:hg*:*' branchformat "%b"
else
_p9k_get_icon '' VCS_BRANCH_ICON
2020-02-10 19:59:37 +08:00
zstyle ':vcs_info:hg*:*' branchformat " $_p9k__ret %b "
2019-07-23 21:47:25 +08:00
fi
2019-06-01 23:54:53 +08:00
# The `get-revision` function must be turned on for dirty-check to work for Hg
zstyle ':vcs_info:hg*:*' get-revision true
zstyle ':vcs_info:hg*:*' get-bookmarks true
zstyle ':vcs_info:hg*+gen-hg-bookmark-string:*' hooks hg-bookmarks
# TODO: fix the %b (branch) format for svn. Using %b breaks color-encoding of the foreground
# for the rest of the powerline.
2019-07-23 21:47:25 +08:00
zstyle ':vcs_info:svn*:*' formats " $prefix %c%u "
zstyle ':vcs_info:svn*:*' actionformats " $prefix %c%u %F{ $_POWERLEVEL9K_VCS_ACTIONFORMAT_FOREGROUND }| %a%f "
2019-06-01 23:54:53 +08:00
2019-07-23 21:47:25 +08:00
if ( ( _POWERLEVEL9K_SHOW_CHANGESET ) ) ; then
2019-06-01 23:54:53 +08:00
zstyle ':vcs_info:*' get-revision true
2019-07-25 03:07:28 +08:00
else
zstyle ':vcs_info:*' get-revision false
2019-06-01 23:54:53 +08:00
fi
}
2019-07-08 01:03:21 +08:00
function _p9k_vcs_status_save( ) {
local z = $'\0'
2019-11-11 18:51:15 +08:00
_p9k__gitstatus_last[ ${ ${ _p9k__git_dir : +GIT_DIR : $_p9k__git_dir } :- $VCS_STATUS_WORKDIR } ] = \
$VCS_STATUS_ACTION $z $VCS_STATUS_COMMIT \
2019-07-08 22:54:26 +08:00
$z $VCS_STATUS_COMMITS_AHEAD $z $VCS_STATUS_COMMITS_BEHIND $z $VCS_STATUS_HAS_CONFLICTED \
$z $VCS_STATUS_HAS_STAGED $z $VCS_STATUS_HAS_UNSTAGED $z $VCS_STATUS_HAS_UNTRACKED \
$z $VCS_STATUS_INDEX_SIZE $z $VCS_STATUS_LOCAL_BRANCH $z $VCS_STATUS_NUM_CONFLICTED \
$z $VCS_STATUS_NUM_STAGED $z $VCS_STATUS_NUM_UNSTAGED $z $VCS_STATUS_NUM_UNTRACKED \
$z $VCS_STATUS_REMOTE_BRANCH $z $VCS_STATUS_REMOTE_NAME $z $VCS_STATUS_REMOTE_URL \
2019-10-08 20:51:16 +08:00
$z $VCS_STATUS_RESULT $z $VCS_STATUS_STASHES $z $VCS_STATUS_TAG $z $VCS_STATUS_NUM_UNSTAGED_DELETED
2019-07-08 01:03:21 +08:00
}
function _p9k_vcs_status_restore( ) {
2019-07-08 22:54:26 +08:00
for VCS_STATUS_ACTION VCS_STATUS_COMMIT VCS_STATUS_COMMITS_AHEAD VCS_STATUS_COMMITS_BEHIND \
VCS_STATUS_HAS_CONFLICTED VCS_STATUS_HAS_STAGED VCS_STATUS_HAS_UNSTAGED \
VCS_STATUS_HAS_UNTRACKED VCS_STATUS_INDEX_SIZE VCS_STATUS_LOCAL_BRANCH \
VCS_STATUS_NUM_CONFLICTED VCS_STATUS_NUM_STAGED VCS_STATUS_NUM_UNSTAGED \
VCS_STATUS_NUM_UNTRACKED VCS_STATUS_REMOTE_BRANCH VCS_STATUS_REMOTE_NAME \
VCS_STATUS_REMOTE_URL VCS_STATUS_RESULT VCS_STATUS_STASHES VCS_STATUS_TAG \
2019-10-08 20:42:07 +08:00
VCS_STATUS_NUM_UNSTAGED_DELETED
2019-07-08 01:03:21 +08:00
in " ${ (@0)1 } " ; do done
}
function _p9k_vcs_status_for_dir( ) {
2019-11-11 18:51:15 +08:00
if [ [ -n $GIT_DIR ] ] ; then
2020-02-10 19:59:37 +08:00
_p9k__ret = $_p9k__gitstatus_last [ GIT_DIR:$GIT_DIR ]
[ [ -n $_p9k__ret ] ]
2019-11-11 18:51:15 +08:00
else
2020-01-27 22:04:34 +08:00
local dir = $_p9k__cwd_a
2019-11-11 18:51:15 +08:00
while true; do
2020-02-10 19:59:37 +08:00
_p9k__ret = $_p9k__gitstatus_last [ $dir ]
[ [ -n $_p9k__ret ] ] && return 0
2019-11-11 18:51:15 +08:00
[ [ $dir = = / ] ] && return 1
dir = ${ dir : h }
done
fi
2019-07-08 01:03:21 +08:00
}
function _p9k_vcs_status_purge( ) {
2019-11-11 18:51:15 +08:00
if [ [ -n $_p9k__git_dir ] ] ; then
_p9k__gitstatus_last[ GIT_DIR:$_p9k__git_dir ] = ""
else
local dir = $1
while true; do
# unset doesn't work if $dir contains weird shit
_p9k__gitstatus_last[ $dir ] = ""
_p9k_git_slow[ $dir ] = ""
[ [ $dir = = / ] ] && break
dir = ${ dir : h }
done
fi
2019-07-08 01:03:21 +08:00
}
2019-07-08 22:54:26 +08:00
function _p9k_vcs_icon( ) {
case " $VCS_STATUS_REMOTE_URL " in
2020-02-10 19:59:37 +08:00
*github*) _p9k__ret = VCS_GIT_GITHUB_ICON; ;
*bitbucket*) _p9k__ret = VCS_GIT_BITBUCKET_ICON; ;
*stash*) _p9k__ret = VCS_GIT_GITHUB_ICON; ;
*gitlab*) _p9k__ret = VCS_GIT_GITLAB_ICON; ;
*) _p9k__ret = VCS_GIT_ICON; ;
2019-07-08 22:54:26 +08:00
esac
}
2019-06-01 23:54:53 +08:00
function _p9k_vcs_render( ) {
2019-07-08 01:03:21 +08:00
local state
2019-10-25 19:22:50 +08:00
if ( ( $+_p9k__gitstatus_next_dir ) ) ; then
2019-11-11 18:51:15 +08:00
if _p9k_vcs_status_for_dir; then
2020-02-10 19:59:37 +08:00
_p9k_vcs_status_restore $_p9k__ret
2019-07-08 01:03:21 +08:00
state = LOADING
2019-06-01 23:54:53 +08:00
else
2019-07-25 03:07:28 +08:00
_p9k_prompt_segment prompt_vcs_LOADING " ${ __p9k_vcs_states [LOADING] } " " $_p9k_color1 " VCS_LOADING_ICON 0 '' " $_POWERLEVEL9K_VCS_LOADING_TEXT "
2019-07-08 01:03:21 +08:00
return 0
2019-06-01 23:54:53 +08:00
fi
2019-07-08 01:03:21 +08:00
elif [ [ $VCS_STATUS_RESULT != ok-* ] ] ; then
return 1
2019-06-01 23:54:53 +08:00
fi
2019-07-23 21:47:25 +08:00
if ( ( _POWERLEVEL9K_VCS_DISABLE_GITSTATUS_FORMATTING ) ) ; then
2019-07-08 22:54:26 +08:00
if [ [ -z $state ] ] ; then
2019-09-18 19:20:33 +08:00
if [ [ $VCS_STATUS_HAS_CONFLICTED = = 1 && $_POWERLEVEL9K_VCS_CONFLICTED_STATE = = 1 ] ] ; then
state = CONFLICTED
2019-09-18 16:45:30 +08:00
elif [ [ $VCS_STATUS_HAS_STAGED != 0 || $VCS_STATUS_HAS_UNSTAGED != 0 ] ] ; then
2019-07-08 22:54:26 +08:00
state = MODIFIED
elif [ [ $VCS_STATUS_HAS_UNTRACKED != 0 ] ] ; then
state = UNTRACKED
else
state = CLEAN
fi
fi
_p9k_vcs_icon
2020-02-10 19:59:37 +08:00
_p9k_prompt_segment prompt_vcs_$state " ${ __p9k_vcs_states [ $state ] } " " $_p9k_color1 " " $_p9k__ret " 0 '' ""
2019-07-08 22:54:26 +08:00
return 0
fi
2019-07-23 21:47:25 +08:00
( ( ${ _POWERLEVEL9K_VCS_GIT_HOOKS [(I)git-untracked] } ) ) || VCS_STATUS_HAS_UNTRACKED = 0
( ( ${ _POWERLEVEL9K_VCS_GIT_HOOKS [(I)git-aheadbehind] } ) ) || { VCS_STATUS_COMMITS_AHEAD = 0 && VCS_STATUS_COMMITS_BEHIND = 0 }
( ( ${ _POWERLEVEL9K_VCS_GIT_HOOKS [(I)git-stash] } ) ) || VCS_STATUS_STASHES = 0
( ( ${ _POWERLEVEL9K_VCS_GIT_HOOKS [(I)git-remotebranch] } ) ) || VCS_STATUS_REMOTE_BRANCH = ""
( ( ${ _POWERLEVEL9K_VCS_GIT_HOOKS [(I)git-tagname] } ) ) || VCS_STATUS_TAG = ""
2019-06-01 23:54:53 +08:00
2019-07-23 21:47:25 +08:00
( ( _POWERLEVEL9K_VCS_COMMITS_AHEAD_MAX_NUM >= 0 && VCS_STATUS_COMMITS_AHEAD > _POWERLEVEL9K_VCS_COMMITS_AHEAD_MAX_NUM ) ) &&
VCS_STATUS_COMMITS_AHEAD = $_POWERLEVEL9K_VCS_COMMITS_AHEAD_MAX_NUM
2019-06-04 16:39:21 +08:00
2019-07-23 21:47:25 +08:00
( ( _POWERLEVEL9K_VCS_COMMITS_BEHIND_MAX_NUM >= 0 && VCS_STATUS_COMMITS_BEHIND > _POWERLEVEL9K_VCS_COMMITS_BEHIND_MAX_NUM ) ) &&
VCS_STATUS_COMMITS_BEHIND = $_POWERLEVEL9K_VCS_COMMITS_BEHIND_MAX_NUM
2019-06-04 16:39:21 +08:00
2019-06-01 23:54:53 +08:00
local -a cache_key = (
" $VCS_STATUS_LOCAL_BRANCH "
" $VCS_STATUS_REMOTE_BRANCH "
" $VCS_STATUS_REMOTE_URL "
" $VCS_STATUS_ACTION "
" $VCS_STATUS_NUM_STAGED "
" $VCS_STATUS_NUM_UNSTAGED "
" $VCS_STATUS_NUM_UNTRACKED "
2019-09-18 16:45:30 +08:00
" $VCS_STATUS_HAS_CONFLICTED "
2019-06-01 23:54:53 +08:00
" $VCS_STATUS_HAS_STAGED "
" $VCS_STATUS_HAS_UNSTAGED "
" $VCS_STATUS_HAS_UNTRACKED "
" $VCS_STATUS_COMMITS_AHEAD "
" $VCS_STATUS_COMMITS_BEHIND "
" $VCS_STATUS_STASHES "
" $VCS_STATUS_TAG "
2019-10-08 20:42:07 +08:00
" $VCS_STATUS_NUM_UNSTAGED_DELETED "
2019-06-01 23:54:53 +08:00
)
2019-07-23 21:47:25 +08:00
if [ [ $_POWERLEVEL9K_SHOW_CHANGESET = = 1 || -z $VCS_STATUS_LOCAL_BRANCH ] ] ; then
2019-06-01 23:54:53 +08:00
cache_key += $VCS_STATUS_COMMIT
fi
2019-10-18 04:23:14 +08:00
if ! _p9k_cache_ephemeral_get " $state " " ${ (@)cache_key } " ; then
2019-07-08 01:03:21 +08:00
local icon
2019-07-08 18:32:46 +08:00
local content
2019-06-01 23:54:53 +08:00
2019-07-23 21:47:25 +08:00
if ( ( ${ _POWERLEVEL9K_VCS_GIT_HOOKS [(I)vcs-detect-changes] } ) ) ; then
2019-09-18 19:20:33 +08:00
if [ [ $VCS_STATUS_HAS_CONFLICTED = = 1 && $_POWERLEVEL9K_VCS_CONFLICTED_STATE = = 1 ] ] ; then
: ${ state : =CONFLICTED }
2019-09-18 16:45:30 +08:00
elif [ [ $VCS_STATUS_HAS_STAGED != 0 || $VCS_STATUS_HAS_UNSTAGED != 0 ] ] ; then
2019-07-08 01:03:21 +08:00
: ${ state : =MODIFIED }
2019-06-01 23:54:53 +08:00
elif [ [ $VCS_STATUS_HAS_UNTRACKED != 0 ] ] ; then
2019-07-08 01:03:21 +08:00
: ${ state : =UNTRACKED }
2019-06-01 23:54:53 +08:00
fi
# It's weird that removing vcs-detect-changes from POWERLEVEL9K_VCS_GIT_HOOKS gets rid
# of the GIT icon. That's what vcs_info does, so we do the same in the name of compatiblity.
2019-07-03 20:07:11 +08:00
case " $VCS_STATUS_REMOTE_URL " in
*github*) icon = VCS_GIT_GITHUB_ICON; ;
*bitbucket*) icon = VCS_GIT_BITBUCKET_ICON; ;
*stash*) icon = VCS_GIT_GITHUB_ICON; ;
*gitlab*) icon = VCS_GIT_GITLAB_ICON; ;
*) icon = VCS_GIT_ICON; ;
esac
2019-06-01 23:54:53 +08:00
fi
2019-07-08 01:03:21 +08:00
: ${ state : =CLEAN }
function _$0 _fmt( ) {
2019-07-09 19:32:45 +08:00
_p9k_vcs_style $state $1
2020-02-10 19:59:37 +08:00
content += " $_p9k__ret $2 "
2019-07-08 01:03:21 +08:00
}
2019-06-01 23:54:53 +08:00
local ws
2019-07-23 21:47:25 +08:00
if [ [ $_POWERLEVEL9K_SHOW_CHANGESET = = 1 || -z $VCS_STATUS_LOCAL_BRANCH ] ] ; then
2019-07-09 18:40:31 +08:00
_p9k_get_icon prompt_vcs_$state VCS_COMMIT_ICON
2020-02-10 19:59:37 +08:00
_$0 _fmt COMMIT " $_p9k__ret ${ ${ VCS_STATUS_COMMIT : 0 : $_POWERLEVEL9K_CHANGESET_HASH_LENGTH } :- HEAD } "
2019-06-01 23:54:53 +08:00
ws = ' '
fi
if [ [ -n $VCS_STATUS_LOCAL_BRANCH ] ] ; then
2019-08-14 13:24:09 +08:00
local branch = $ws
if ( ( !_POWERLEVEL9K_HIDE_BRANCH_ICON ) ) ; then
_p9k_get_icon prompt_vcs_$state VCS_BRANCH_ICON
2020-02-10 19:59:37 +08:00
branch += $_p9k__ret
2019-08-14 13:24:09 +08:00
fi
if ( ( $+_POWERLEVEL9K_VCS_SHORTEN_LENGTH && $+_POWERLEVEL9K_VCS_SHORTEN_MIN_LENGTH &&
$# VCS_STATUS_LOCAL_BRANCH > _POWERLEVEL9K_VCS_SHORTEN_MIN_LENGTH &&
$# VCS_STATUS_LOCAL_BRANCH > _POWERLEVEL9K_VCS_SHORTEN_LENGTH ) ) &&
[ [ $_POWERLEVEL9K_VCS_SHORTEN_STRATEGY = = ( truncate_middle| truncate_from_right) ] ] ; then
branch += ${ VCS_STATUS_LOCAL_BRANCH [1,_POWERLEVEL9K_VCS_SHORTEN_LENGTH]// \% /%% } ${ _POWERLEVEL9K_VCS_SHORTEN_DELIMITER }
if [ [ $_POWERLEVEL9K_VCS_SHORTEN_STRATEGY = = truncate_middle ] ] ; then
_p9k_vcs_style $state BRANCH
2020-02-10 19:59:37 +08:00
branch += ${ _p9k__ret } ${ VCS_STATUS_LOCAL_BRANCH [-_POWERLEVEL9K_VCS_SHORTEN_LENGTH,-1]// \% /%% }
2019-08-14 13:24:09 +08:00
fi
else
branch += ${ VCS_STATUS_LOCAL_BRANCH // \% /%% }
fi
_$0 _fmt BRANCH $branch
2019-06-01 23:54:53 +08:00
fi
2019-07-23 21:47:25 +08:00
if [ [ $_POWERLEVEL9K_VCS_HIDE_TAGS = = 0 && -n $VCS_STATUS_TAG ] ] ; then
2019-07-09 18:40:31 +08:00
_p9k_get_icon prompt_vcs_$state VCS_TAG_ICON
2020-02-10 19:59:37 +08:00
_$0 _fmt TAG " $_p9k__ret ${ VCS_STATUS_TAG // \% /%% } "
2019-06-01 23:54:53 +08:00
fi
if [ [ -n $VCS_STATUS_ACTION ] ] ; then
2019-06-20 19:34:20 +08:00
_$0 _fmt ACTION " | ${ VCS_STATUS_ACTION // \% /%% } "
2019-06-01 23:54:53 +08:00
else
if [ [ -n $VCS_STATUS_REMOTE_BRANCH &&
$VCS_STATUS_LOCAL_BRANCH != $VCS_STATUS_REMOTE_BRANCH ] ] ; then
2019-07-09 18:40:31 +08:00
_p9k_get_icon prompt_vcs_$state VCS_REMOTE_BRANCH_ICON
2020-02-10 19:59:37 +08:00
_$0 _fmt REMOTE_BRANCH " $_p9k__ret ${ VCS_STATUS_REMOTE_BRANCH // \% /%% } "
2019-06-01 23:54:53 +08:00
fi
2019-06-21 00:50:07 +08:00
if [ [ $VCS_STATUS_HAS_STAGED = = 1 || $VCS_STATUS_HAS_UNSTAGED = = 1 || $VCS_STATUS_HAS_UNTRACKED = = 1 ] ] ; then
2019-07-09 18:40:31 +08:00
_p9k_get_icon prompt_vcs_$state VCS_DIRTY_ICON
2020-02-10 19:59:37 +08:00
_$0 _fmt DIRTY " $_p9k__ret "
2019-06-21 00:50:07 +08:00
if [ [ $VCS_STATUS_HAS_STAGED = = 1 ] ] ; then
2019-07-09 18:40:31 +08:00
_p9k_get_icon prompt_vcs_$state VCS_STAGED_ICON
2020-02-10 19:59:37 +08:00
( ( _POWERLEVEL9K_VCS_STAGED_MAX_NUM != 1 ) ) && _p9k__ret += $VCS_STATUS_NUM_STAGED
_$0 _fmt STAGED " $_p9k__ret "
2019-06-21 00:50:07 +08:00
fi
if [ [ $VCS_STATUS_HAS_UNSTAGED = = 1 ] ] ; then
2019-07-09 18:40:31 +08:00
_p9k_get_icon prompt_vcs_$state VCS_UNSTAGED_ICON
2020-02-10 19:59:37 +08:00
( ( _POWERLEVEL9K_VCS_UNSTAGED_MAX_NUM != 1 ) ) && _p9k__ret += $VCS_STATUS_NUM_UNSTAGED
_$0 _fmt UNSTAGED " $_p9k__ret "
2019-06-21 00:50:07 +08:00
fi
if [ [ $VCS_STATUS_HAS_UNTRACKED = = 1 ] ] ; then
2019-07-09 18:40:31 +08:00
_p9k_get_icon prompt_vcs_$state VCS_UNTRACKED_ICON
2020-02-10 19:59:37 +08:00
( ( _POWERLEVEL9K_VCS_UNTRACKED_MAX_NUM != 1 ) ) && _p9k__ret += $VCS_STATUS_NUM_UNTRACKED
_$0 _fmt UNTRACKED " $_p9k__ret "
2019-06-21 00:50:07 +08:00
fi
2019-06-01 23:54:53 +08:00
fi
if [ [ $VCS_STATUS_COMMITS_BEHIND -gt 0 ] ] ; then
2019-07-09 18:40:31 +08:00
_p9k_get_icon prompt_vcs_$state VCS_INCOMING_CHANGES_ICON
2020-02-10 19:59:37 +08:00
( ( _POWERLEVEL9K_VCS_COMMITS_BEHIND_MAX_NUM != 1 ) ) && _p9k__ret += $VCS_STATUS_COMMITS_BEHIND
_$0 _fmt INCOMING_CHANGES " $_p9k__ret "
2019-06-01 23:54:53 +08:00
fi
2019-06-04 16:44:48 +08:00
if [ [ $VCS_STATUS_COMMITS_AHEAD -gt 0 ] ] ; then
2019-07-09 18:40:31 +08:00
_p9k_get_icon prompt_vcs_$state VCS_OUTGOING_CHANGES_ICON
2020-02-10 19:59:37 +08:00
( ( _POWERLEVEL9K_VCS_COMMITS_AHEAD_MAX_NUM != 1 ) ) && _p9k__ret += $VCS_STATUS_COMMITS_AHEAD
_$0 _fmt OUTGOING_CHANGES " $_p9k__ret "
2019-06-04 16:44:48 +08:00
fi
2019-06-01 23:54:53 +08:00
if [ [ $VCS_STATUS_STASHES -gt 0 ] ] ; then
2019-07-09 18:40:31 +08:00
_p9k_get_icon prompt_vcs_$state VCS_STASH_ICON
2020-02-10 19:59:37 +08:00
_$0 _fmt STASH " $_p9k__ret $VCS_STATUS_STASHES "
2019-06-01 23:54:53 +08:00
fi
fi
2019-10-18 04:23:14 +08:00
_p9k_cache_ephemeral_set " prompt_vcs_ $state " " ${ __p9k_vcs_states [ $state ] } " " $_p9k_color1 " " $icon " 0 '' " $content "
2019-06-01 23:54:53 +08:00
fi
2020-02-10 19:59:37 +08:00
_p9k_prompt_segment " $_p9k__cache_val [@] "
2019-06-01 23:54:53 +08:00
return 0
}
2019-11-07 15:39:01 +08:00
function _p9k_maybe_ignore_git_repo( ) {
if [ [ $VCS_STATUS_RESULT = = ok-* && $VCS_STATUS_WORKDIR = = $~_POWERLEVEL9K_VCS_DISABLED_WORKDIR_PATTERN ] ] ; then
VCS_STATUS_RESULT = norepo${ VCS_STATUS_RESULT #ok }
fi
}
2019-06-01 23:54:53 +08:00
function _p9k_vcs_resume( ) {
2020-02-02 05:03:42 +08:00
eval " $__p9k_intro "
2019-06-01 23:54:53 +08:00
2019-11-07 15:39:01 +08:00
_p9k_maybe_ignore_git_repo
2019-06-01 23:54:53 +08:00
if [ [ $VCS_STATUS_RESULT = = ok-async ] ] ; then
2019-10-25 19:22:50 +08:00
local latency = $(( EPOCHREALTIME - _p9k__gitstatus_start_time))
2019-07-23 21:47:25 +08:00
if ( ( latency > _POWERLEVEL9K_VCS_MAX_SYNC_LATENCY_SECONDS ) ) ; then
2019-11-11 18:51:15 +08:00
_p9k_git_slow[ ${ ${ _p9k__git_dir : +GIT_DIR : $_p9k__git_dir } :- $VCS_STATUS_WORKDIR } ] = 1
2019-07-23 21:47:25 +08:00
elif ( ( $1 && latency < 0.8 * _POWERLEVEL9K_VCS_MAX_SYNC_LATENCY_SECONDS ) ) ; then # 0.8 to avoid flip-flopping
2019-11-11 18:51:15 +08:00
_p9k_git_slow[ ${ ${ _p9k__git_dir : +GIT_DIR : $_p9k__git_dir } :- $VCS_STATUS_WORKDIR } ] = 0
2019-06-01 23:54:53 +08:00
fi
2019-07-08 01:03:21 +08:00
_p9k_vcs_status_save
2019-06-01 23:54:53 +08:00
fi
2019-10-25 19:22:50 +08:00
if [ [ -z $_p9k__gitstatus_next_dir ] ] ; then
unset _p9k__gitstatus_next_dir
2019-06-01 23:54:53 +08:00
case $VCS_STATUS_RESULT in
2020-01-27 22:04:34 +08:00
norepo-async) ( ( $1 ) ) && _p9k_vcs_status_purge $_p9k__cwd_a ; ;
ok-async) ( ( $1 ) ) || _p9k__gitstatus_next_dir = $_p9k__cwd_a ; ;
2019-06-01 23:54:53 +08:00
esac
fi
2019-07-08 01:03:21 +08:00
2019-10-25 19:22:50 +08:00
if [ [ -n $_p9k__gitstatus_next_dir ] ] ; then
2019-11-11 18:51:15 +08:00
_p9k__git_dir = $GIT_DIR
2019-10-25 19:22:50 +08:00
if ! gitstatus_query -d $_p9k__gitstatus_next_dir -t 0 -c '_p9k_vcs_resume 1' POWERLEVEL9K; then
unset _p9k__gitstatus_next_dir
2019-07-08 01:03:21 +08:00
unset VCS_STATUS_RESULT
else
2019-11-07 15:39:01 +08:00
_p9k_maybe_ignore_git_repo
2019-07-08 01:03:21 +08:00
case $VCS_STATUS_RESULT in
2019-10-25 19:22:50 +08:00
tout) _p9k__gitstatus_next_dir = '' ; _p9k__gitstatus_start_time = $EPOCHREALTIME ; ;
norepo-sync) _p9k_vcs_status_purge $_p9k__gitstatus_next_dir ; unset _p9k__gitstatus_next_dir; ;
ok-sync) _p9k_vcs_status_save; unset _p9k__gitstatus_next_dir; ;
2019-07-08 01:03:21 +08:00
esac
fi
fi
2020-02-10 19:59:37 +08:00
_p9k__refresh_reason = gitstatus
2019-12-14 21:57:30 +08:00
_p9k_set_prompt
2020-02-10 19:59:37 +08:00
_p9k__refresh_reason = ''
2019-12-14 21:57:30 +08:00
_p9k_reset_prompt
2019-06-01 23:54:53 +08:00
}
function _p9k_vcs_gitstatus( ) {
2020-02-10 19:59:37 +08:00
if [ [ $_p9k__refresh_reason = = precmd ] ] ; then
2019-10-25 19:22:50 +08:00
if ( ( $+_p9k__gitstatus_next_dir ) ) ; then
2020-01-27 22:04:34 +08:00
_p9k__gitstatus_next_dir = $_p9k__cwd_a
2019-06-01 23:54:53 +08:00
else
2019-07-23 21:47:25 +08:00
local -F timeout = _POWERLEVEL9K_VCS_MAX_SYNC_LATENCY_SECONDS
2019-11-11 18:51:15 +08:00
if ! _p9k_vcs_status_for_dir; then
_p9k__git_dir = $GIT_DIR
2020-01-27 22:04:34 +08:00
gitstatus_query -d $_p9k__cwd_a -t $timeout -p -c '_p9k_vcs_resume 0' POWERLEVEL9K || return 1
2019-11-07 15:39:01 +08:00
_p9k_maybe_ignore_git_repo
2019-07-08 01:03:21 +08:00
case $VCS_STATUS_RESULT in
2019-10-25 19:22:50 +08:00
tout) _p9k__gitstatus_next_dir = '' ; _p9k__gitstatus_start_time = $EPOCHREALTIME ; return 0; ;
2019-07-08 01:03:21 +08:00
norepo-sync) return 0; ;
ok-sync) _p9k_vcs_status_save; ;
2019-06-01 23:54:53 +08:00
esac
2019-07-08 01:03:21 +08:00
else
2019-11-11 18:51:15 +08:00
if [ [ -n $GIT_DIR ] ] ; then
[ [ $_p9k_git_slow [ GIT_DIR:$GIT_DIR ] = = 1 ] ] && timeout = 0
else
2020-01-27 22:04:34 +08:00
local dir = $_p9k__cwd_a
2019-11-11 18:51:15 +08:00
while true; do
case $_p9k_git_slow [ $dir ] in
"" ) [ [ $dir = = / ] ] && break; dir = ${ dir : h } ; ;
0) break; ;
1) timeout = 0; break; ;
esac
done
fi
2019-07-08 01:03:21 +08:00
fi
2019-10-25 19:22:50 +08:00
( ( _p9k__prompt_idx = = 1 ) ) && timeout = 0
2019-11-11 18:51:15 +08:00
_p9k__git_dir = $GIT_DIR
2020-01-27 22:04:34 +08:00
if ! gitstatus_query -d $_p9k__cwd_a -t $timeout -c '_p9k_vcs_resume 1' POWERLEVEL9K; then
2019-07-08 01:03:21 +08:00
unset VCS_STATUS_RESULT
return 1
fi
2019-11-07 15:39:01 +08:00
_p9k_maybe_ignore_git_repo
2019-07-08 01:03:21 +08:00
case $VCS_STATUS_RESULT in
2019-10-25 19:22:50 +08:00
tout) _p9k__gitstatus_next_dir = '' ; _p9k__gitstatus_start_time = $EPOCHREALTIME ; ;
2020-01-27 22:04:34 +08:00
norepo-sync) _p9k_vcs_status_purge $_p9k__cwd_a ; ;
2019-07-08 01:03:21 +08:00
ok-sync) _p9k_vcs_status_save; ;
esac
2019-06-01 23:54:53 +08:00
fi
fi
return 0
}
################################################################
# Segment to show VCS information
prompt_vcs( ) {
2019-07-23 21:47:25 +08:00
local -a backends = ( $_POWERLEVEL9K_VCS_BACKENDS )
2019-10-25 19:22:50 +08:00
if ( ( ${ backends [(I)git] } && !_p9k__gitstatus_disabled ) ) && _p9k_vcs_gitstatus; then
2019-07-25 03:07:28 +08:00
_p9k_vcs_render && return
2019-06-01 23:54:53 +08:00
backends = ( ${ backends : #git } )
fi
if ( ( $# backends ) ) ; then
VCS_WORKDIR_DIRTY = false
VCS_WORKDIR_HALF_DIRTY = false
local current_state = ""
# Actually invoke vcs_info manually to gather all information.
zstyle ':vcs_info:*' enable ${ backends }
vcs_info
local vcs_prompt = " ${ vcs_info_msg_0_ } "
if [ [ -n " $vcs_prompt " ] ] ; then
if [ [ " $VCS_WORKDIR_DIRTY " = = true ] ] ; then
# $vcs_visual_identifier gets set in +vi-vcs-detect-changes in functions/vcs.zsh,
# as we have there access to vcs_info internal hooks.
2019-07-09 22:08:43 +08:00
current_state = 'MODIFIED'
2019-06-01 23:54:53 +08:00
else
if [ [ " $VCS_WORKDIR_HALF_DIRTY " = = true ] ] ; then
2019-07-09 22:08:43 +08:00
current_state = 'UNTRACKED'
2019-06-01 23:54:53 +08:00
else
2019-07-09 22:08:43 +08:00
current_state = 'CLEAN'
2019-06-01 23:54:53 +08:00
fi
fi
2019-07-25 03:07:28 +08:00
_p9k_prompt_segment " ${ 0 } _ ${ (U)current_state } " " ${ __p9k_vcs_states [ $current_state ] } " " $_p9k_color1 " " $vcs_visual_identifier " 0 '' " $vcs_prompt "
2019-06-01 23:54:53 +08:00
fi
fi
}
################################################################
# Vi Mode: show editing mode (NORMAL|INSERT|VISUAL)
prompt_vi_mode( ) {
2020-02-12 22:45:23 +08:00
local -i len = $# _p9k__prompt _p9k__has_upglob
2019-09-20 17:22:14 +08:00
if ( ( __p9k_sh_glob ) ) ; then
if ( ( $+_POWERLEVEL9K_VI_OVERWRITE_MODE_STRING ) ) ; then
if [ [ -n $_POWERLEVEL9K_VI_INSERT_MODE_STRING ] ] ; then
2019-10-25 19:22:50 +08:00
_p9k_prompt_segment $0 _INSERT " $_p9k_color1 " blue '' 0 '${${${${${${:-$_p9k__keymap.$_p9k__zle_state}:#vicmd.*}:#vivis.*}:#vivli.*}:#*.*overwrite*}}' " $_POWERLEVEL9K_VI_INSERT_MODE_STRING "
2019-09-20 17:22:14 +08:00
fi
2019-10-25 19:22:50 +08:00
_p9k_prompt_segment $0 _OVERWRITE " $_p9k_color1 " blue '' 0 '${${${${${${:-$_p9k__keymap.$_p9k__zle_state}:#vicmd.*}:#vivis.*}:#vivli.*}:#*.*insert*}}' " $_POWERLEVEL9K_VI_OVERWRITE_MODE_STRING "
2019-09-20 17:22:14 +08:00
else
if [ [ -n $_POWERLEVEL9K_VI_INSERT_MODE_STRING ] ] ; then
2019-10-25 19:22:50 +08:00
_p9k_prompt_segment $0 _INSERT " $_p9k_color1 " blue '' 0 '${${${${_p9k__keymap:#vicmd}:#vivis}:#vivli}}' " $_POWERLEVEL9K_VI_INSERT_MODE_STRING "
2019-09-20 17:22:14 +08:00
fi
fi
if ( ( $+_POWERLEVEL9K_VI_VISUAL_MODE_STRING ) ) ; then
2019-10-25 19:22:50 +08:00
_p9k_prompt_segment $0 _NORMAL " $_p9k_color1 " white '' 0 '${(M)${:-$_p9k__keymap$_p9k__region_active}:#vicmd0}' " $_POWERLEVEL9K_VI_COMMAND_MODE_STRING "
_p9k_prompt_segment $0 _VISUAL " $_p9k_color1 " white '' 0 '${$((! ${#${${${${:-$_p9k__keymap$_p9k__region_active}:#vicmd1}:#vivis?}:#vivli?}})):#0}' " $_POWERLEVEL9K_VI_VISUAL_MODE_STRING "
2019-09-20 17:22:14 +08:00
else
2019-10-25 19:22:50 +08:00
_p9k_prompt_segment $0 _NORMAL " $_p9k_color1 " white '' 0 '${$((! ${#${${${_p9k__keymap:#vicmd}:#vivis}:#vivli}})):#0}' " $_POWERLEVEL9K_VI_COMMAND_MODE_STRING "
2019-09-18 19:38:31 +08:00
fi
else
2019-09-20 17:22:14 +08:00
if ( ( $+_POWERLEVEL9K_VI_OVERWRITE_MODE_STRING ) ) ; then
if [ [ -n $_POWERLEVEL9K_VI_INSERT_MODE_STRING ] ] ; then
2019-10-25 19:22:50 +08:00
_p9k_prompt_segment $0 _INSERT " $_p9k_color1 " blue '' 0 '${${:-$_p9k__keymap.$_p9k__zle_state}:#(vicmd.*|vivis.*|vivli.*|*.*overwrite*)}' " $_POWERLEVEL9K_VI_INSERT_MODE_STRING "
2019-09-20 17:22:14 +08:00
fi
2019-10-25 19:22:50 +08:00
_p9k_prompt_segment $0 _OVERWRITE " $_p9k_color1 " blue '' 0 '${${:-$_p9k__keymap.$_p9k__zle_state}:#(vicmd.*|vivis.*|vivli.*|*.*insert*)}' " $_POWERLEVEL9K_VI_OVERWRITE_MODE_STRING "
2019-09-20 17:22:14 +08:00
else
if [ [ -n $_POWERLEVEL9K_VI_INSERT_MODE_STRING ] ] ; then
2019-10-25 19:22:50 +08:00
_p9k_prompt_segment $0 _INSERT " $_p9k_color1 " blue '' 0 '${_p9k__keymap:#(vicmd|vivis|vivli)}' " $_POWERLEVEL9K_VI_INSERT_MODE_STRING "
2019-09-20 17:22:14 +08:00
fi
2019-09-18 19:38:31 +08:00
fi
2019-09-20 17:22:14 +08:00
if ( ( $+_POWERLEVEL9K_VI_VISUAL_MODE_STRING ) ) ; then
2019-10-25 19:22:50 +08:00
_p9k_prompt_segment $0 _NORMAL " $_p9k_color1 " white '' 0 '${(M)${:-$_p9k__keymap$_p9k__region_active}:#vicmd0}' " $_POWERLEVEL9K_VI_COMMAND_MODE_STRING "
_p9k_prompt_segment $0 _VISUAL " $_p9k_color1 " white '' 0 '${(M)${:-$_p9k__keymap$_p9k__region_active}:#(vicmd1|vivis?|vivli?)}' " $_POWERLEVEL9K_VI_VISUAL_MODE_STRING "
2019-09-20 17:22:14 +08:00
else
2019-10-25 19:22:50 +08:00
_p9k_prompt_segment $0 _NORMAL " $_p9k_color1 " white '' 0 '${(M)_p9k__keymap:#(vicmd|vivis|vivli)}' " $_POWERLEVEL9K_VI_COMMAND_MODE_STRING "
2019-09-20 17:22:14 +08:00
fi
2019-07-12 17:55:32 +08:00
fi
2020-02-12 22:45:23 +08:00
( ( _p9k__has_upglob ) ) || typeset -g " _p9k__segment_val_ ${ _p9k__prompt_side } [_p9k__segment_index] " = $_p9k__prompt [ len+1,-1]
2019-06-01 23:54:53 +08:00
}
2019-10-16 23:36:54 +08:00
instant_prompt_vi_mode( ) {
if [ [ -n $_POWERLEVEL9K_VI_INSERT_MODE_STRING ] ] ; then
_p9k_prompt_segment prompt_vi_mode_INSERT " $_p9k_color1 " blue '' 0 '' " $_POWERLEVEL9K_VI_INSERT_MODE_STRING "
fi
}
2019-06-01 23:54:53 +08:00
################################################################
# Virtualenv: current working virtualenv
# More information on virtualenv (Python):
# https://virtualenv.pypa.io/en/latest/
prompt_virtualenv( ) {
2019-06-20 15:37:40 +08:00
local msg = ''
2019-07-23 21:47:25 +08:00
if ( ( _POWERLEVEL9K_VIRTUALENV_SHOW_PYTHON_VERSION ) ) && _p9k_python_version; then
2020-02-10 19:59:37 +08:00
msg = " ${ _p9k__ret // \% /%% } "
2019-06-01 23:54:53 +08:00
fi
2019-11-27 18:01:57 +08:00
local v = ${ VIRTUAL_ENV : t }
( ( _POWERLEVEL9K_VIRTUALENV_GENERIC_NAMES[ ( I) $v ] ) ) && v = ${ VIRTUAL_ENV : h : t }
msg += " $_POWERLEVEL9K_VIRTUALENV_LEFT_DELIMITER ${ v // \% /%% } $_POWERLEVEL9K_VIRTUALENV_RIGHT_DELIMITER "
2019-07-25 03:07:28 +08:00
_p9k_prompt_segment " $0 " "blue" " $_p9k_color1 " 'PYTHON_ICON' 0 '' " $msg "
2019-06-01 23:54:53 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_virtualenv_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$VIRTUAL_ENV'
2020-01-26 01:04:06 +08:00
}
2020-01-28 16:59:54 +08:00
# _p9k_read_pyenv_like_version_file <filepath> [prefix]
function _p9k_read_pyenv_like_version_file( ) {
local -a stat
zstat -A stat +mtime -- $1 2>/dev/null || stat = ( -1)
local cached = $_p9k__read_pyenv_like_version_file_cache [ $1 :$2 ]
if [ [ $cached = = $stat [ 1] :* ] ] ; then
2020-02-10 19:59:37 +08:00
_p9k__ret = ${ cached #* : }
2020-01-28 16:59:54 +08:00
else
local fd content
{
2020-02-18 22:47:24 +08:00
{ sysopen -r -u fd -- $1 && sysread -i $fd -s 1024 content } 2>/dev/null
2020-01-28 16:59:54 +08:00
} always {
[ [ -n $fd ] ] && exec { fd} >& -
}
local MATCH
local versions = ( ${ (@) ${ (f)content } /(#m)*/ ${ MATCH [(w)1]# $2 } } )
2020-02-10 19:59:37 +08:00
_p9k__ret = ${ (j. : .)versions }
_p9k__read_pyenv_like_version_file_cache[ $1 :$2 ] = $stat [ 1] :$_p9k__ret
2020-01-28 16:59:54 +08:00
fi
2020-02-10 19:59:37 +08:00
[ [ -n $_p9k__ret ] ]
2019-06-01 23:54:53 +08:00
}
function _p9k_pyenv_global_version( ) {
2020-02-10 19:59:37 +08:00
_p9k_read_pyenv_like_version_file ${ PYENV_ROOT :- $HOME /.pyenv } /version python- || _p9k__ret = system
2019-06-01 23:54:53 +08:00
}
################################################################
# Segment to display pyenv information
# https://github.com/pyenv/pyenv#choosing-the-python-version
prompt_pyenv( ) {
local v = ${ (j. : .) ${ (@) ${ (s. : .)PYENV_VERSION } #python- } }
2019-12-12 22:38:56 +08:00
if [ [ -n $v ] ] ; then
( ( ${ _POWERLEVEL9K_PYENV_SOURCES [(I)shell] } ) ) || return
else
( ( ${ _POWERLEVEL9K_PYENV_SOURCES [(I)local|global] } ) ) || return
2020-01-28 16:59:54 +08:00
if [ [ $PYENV_DIR = = ( | .) ] ] ; then
_p9k_upglob .python-version
local -i idx = $?
if ( ( idx ) ) && _p9k_read_pyenv_like_version_file $_p9k__parent_dirs [ idx] /.python-version python-; then
2019-12-12 22:38:56 +08:00
( ( ${ _POWERLEVEL9K_PYENV_SOURCES [(I)local] } ) ) || return
2020-01-28 16:59:54 +08:00
else
2020-02-10 19:59:37 +08:00
_p9k__ret =
2019-06-01 23:54:53 +08:00
fi
2020-01-28 16:59:54 +08:00
else
2020-02-10 19:59:37 +08:00
_p9k__ret =
2020-01-28 16:59:54 +08:00
[ [ $PYENV_DIR = = /* ] ] && local dir = $PYENV_DIR || local dir = " $_p9k__cwd_a / $PYENV_DIR "
while true; do
if _p9k_read_pyenv_like_version_file $dir /.python-version python-; then
( ( ${ _POWERLEVEL9K_PYENV_SOURCES [(I)local] } ) ) || return
break
fi
[ [ $dir = = / ] ] && break
dir = ${ dir : h }
done
fi
2020-02-10 19:59:37 +08:00
if [ [ -z $_p9k__ret ] ] ; then
2020-01-28 16:59:54 +08:00
( ( _POWERLEVEL9K_PYENV_PROMPT_ALWAYS_SHOW ) ) || return
( ( ${ _POWERLEVEL9K_PYENV_SOURCES [(I)global] } ) ) || return
_p9k_pyenv_global_version
fi
2020-02-10 19:59:37 +08:00
v = $_p9k__ret
2019-06-01 23:54:53 +08:00
fi
2019-07-23 21:47:25 +08:00
if ( ( !_POWERLEVEL9K_PYENV_PROMPT_ALWAYS_SHOW ) ) ; then
2019-06-01 23:54:53 +08:00
_p9k_pyenv_global_version
2020-02-10 19:59:37 +08:00
[ [ $v = = $_p9k__ret ] ] && return
2019-06-01 23:54:53 +08:00
fi
2019-07-25 03:07:28 +08:00
_p9k_prompt_segment " $0 " "blue" " $_p9k_color1 " 'PYTHON_ICON' 0 '' " ${ v // \% /%% } "
2019-06-01 23:54:53 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_pyenv_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '${commands[pyenv]:-${${+functions[pyenv]}:#0}}'
2020-01-26 01:04:06 +08:00
}
2019-12-01 19:47:03 +08:00
function _p9k_goenv_global_version( ) {
2020-02-10 19:59:37 +08:00
_p9k_read_pyenv_like_version_file ${ GOENV_ROOT :- $HOME /.goenv } /version go- || _p9k__ret = system
2019-12-01 19:47:03 +08:00
}
################################################################
# Segment to display goenv information: https://github.com/syndbg/goenv
prompt_goenv( ) {
2020-01-28 18:41:49 +08:00
local v = ${ (j. : .) ${ (@) ${ (s. : .)GOENV_VERSION } #go- } }
2020-01-28 16:59:54 +08:00
if [ [ -n $v ] ] ; then
( ( ${ _POWERLEVEL9K_GOENV_SOURCES [(I)shell] } ) ) || return
else
( ( ${ _POWERLEVEL9K_GOENV_SOURCES [(I)local|global] } ) ) || return
if [ [ $GOENV_DIR = = ( | .) ] ] ; then
_p9k_upglob .go-version
local -i idx = $?
2020-02-10 19:59:37 +08:00
if ( ( idx ) ) && _p9k_read_pyenv_like_version_file $_p9k__parent_dirs [ idx] /.go-version go-; then
2020-01-28 16:59:54 +08:00
( ( ${ _POWERLEVEL9K_GOENV_SOURCES [(I)local] } ) ) || return
else
2020-02-10 19:59:37 +08:00
_p9k__ret =
2019-12-01 19:47:03 +08:00
fi
2020-01-28 16:59:54 +08:00
else
2020-02-10 19:59:37 +08:00
_p9k__ret =
2020-01-28 16:59:54 +08:00
[ [ $GOENV_DIR = = /* ] ] && local dir = $GOENV_DIR || local dir = " $_p9k__cwd_a / $GOENV_DIR "
while true; do
2020-02-10 19:59:37 +08:00
if _p9k_read_pyenv_like_version_file $dir /.go-version go-; then
2020-01-28 16:59:54 +08:00
( ( ${ _POWERLEVEL9K_GOENV_SOURCES [(I)local] } ) ) || return
break
fi
[ [ $dir = = / ] ] && break
dir = ${ dir : h }
done
fi
2020-02-10 19:59:37 +08:00
if [ [ -z $_p9k__ret ] ] ; then
2020-01-28 16:59:54 +08:00
( ( _POWERLEVEL9K_GOENV_PROMPT_ALWAYS_SHOW ) ) || return
( ( ${ _POWERLEVEL9K_GOENV_SOURCES [(I)global] } ) ) || return
_p9k_goenv_global_version
fi
2020-02-10 19:59:37 +08:00
v = $_p9k__ret
2019-12-01 19:47:03 +08:00
fi
if ( ( !_POWERLEVEL9K_GOENV_PROMPT_ALWAYS_SHOW ) ) ; then
_p9k_goenv_global_version
2020-02-10 19:59:37 +08:00
[ [ $v = = $_p9k__ret ] ] && return
2019-12-01 19:47:03 +08:00
fi
_p9k_prompt_segment " $0 " "blue" " $_p9k_color1 " 'GO_ICON' 0 '' " ${ v // \% /%% } "
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_goenv_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '${commands[goenv]:-${${+functions[goenv]}:#0}}'
2020-01-26 01:04:06 +08:00
}
2019-06-01 23:54:53 +08:00
################################################################
# Display openfoam information
prompt_openfoam( ) {
2020-01-28 02:23:56 +08:00
if [ [ -z " $WM_FORK " ] ] ; then
_p9k_prompt_segment " $0 " "yellow" " $_p9k_color1 " '' 0 '' " OF: ${ ${ WM_PROJECT_VERSION : t } // \% /%% } "
else
_p9k_prompt_segment " $0 " "yellow" " $_p9k_color1 " '' 0 '' " F-X: ${ ${ WM_PROJECT_VERSION : t } // \% /%% } "
2019-06-01 23:54:53 +08:00
fi
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_openfoam_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$WM_PROJECT_VERSION'
2020-01-26 01:04:06 +08:00
}
2019-06-01 23:54:53 +08:00
################################################################
# Segment to display Swift version
prompt_swift_version( ) {
_p9k_cached_cmd_stdout swift --version || return
2020-02-10 19:59:37 +08:00
[ [ $_p9k__ret = = ( #b)[^[:digit:]]#([[:digit:].]##)* ]] || return
2019-07-25 03:07:28 +08:00
_p9k_prompt_segment " $0 " "magenta" "white" 'SWIFT_ICON' 0 '' " ${ match [1]// \% /%% } "
2019-06-01 23:54:53 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_swift_version_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$commands[swift]'
2020-01-26 01:04:06 +08:00
}
2019-06-01 23:54:53 +08:00
################################################################
# dir_writable: Display information about the user's permission to write in the current directory
prompt_dir_writable( ) {
2020-01-28 02:23:56 +08:00
if [ [ ! -w " $_p9k__cwd_a " ] ] ; then
2019-07-25 03:07:28 +08:00
_p9k_prompt_segment " $0 _FORBIDDEN " "red" "yellow1" 'LOCK_ICON' 0 '' ''
2019-06-01 23:54:53 +08:00
fi
}
2019-10-19 18:33:39 +08:00
instant_prompt_dir_writable( ) { prompt_dir_writable; }
2019-06-01 23:54:53 +08:00
################################################################
# Kubernetes Current Context/Namespace
prompt_kubecontext( ) {
2019-10-10 01:57:18 +08:00
if ! _p9k_cache_stat_get $0 ${ (s. : .) ${ KUBECONFIG :- $HOME /.kube/config } } ; then
2020-01-26 18:45:56 +08:00
local name namespace cluster user cloud_name cloud_account cloud_zone cloud_cluster text state
2019-07-30 03:56:15 +08:00
( ) {
2019-07-30 13:52:26 +08:00
local cfg && cfg = ( ${ (f) " $( kubectl config view -o= yaml 2>/dev/null) " } ) || return
2019-07-30 13:55:18 +08:00
local ctx = ( ${ (@M)cfg : #current-context : [^ \" \' \| \> ]* } )
2019-07-30 03:56:15 +08:00
( ( $# ctx = = 1 ) ) || return
2019-07-30 15:02:46 +08:00
name = ${ ctx [1]#current-context : }
2019-07-30 03:56:15 +08:00
local -i pos = ${ cfg [(i)contexts : ] }
( ( pos <= $# cfg ) ) || return
shift $pos cfg
2019-07-30 15:02:46 +08:00
pos = ${ cfg [(i) name : $name ] }
2019-07-30 03:56:15 +08:00
( ( pos <= $# cfg ) ) || return
( ( --pos ) )
for ( ( ; pos > 0; --pos) ) ; do
local line = $cfg [ pos]
2019-07-30 13:52:26 +08:00
if [ [ $line = = '- context:' ] ] ; then
2019-11-04 16:07:06 +08:00
return 0
2019-07-30 13:52:26 +08:00
elif [ [ $line = = ( #b)' cluster: '([^\"\'\|\>]*) ]]; then
cluster = $match [ 1]
elif [ [ $line = = ( #b)' namespace: '([^\"\'\|\>]*) ]]; then
namespace = $match [ 1]
2020-01-26 18:45:56 +08:00
elif [ [ $line = = ( #b)' user: '([^\"\'\|\>]*) ]]; then
user = $match [ 1]
2019-07-30 13:52:26 +08:00
fi
2019-07-30 03:56:15 +08:00
done
}
2019-07-30 15:02:46 +08:00
if [ [ -n $name ] ] ; then
2019-07-30 15:38:27 +08:00
: ${ namespace : =default }
2019-07-30 15:02:46 +08:00
# gke_my-account_us-east1-a_cluster-01
2019-07-31 02:00:00 +08:00
# gke_my-account_us-east1_cluster-01
if [ [ $cluster = = ( #b)gke_(?*)_(asia|australia|europe|northamerica|southamerica|us)-([a-z]##<->)(-[a-z]|)_(?*) ]]; then
2019-07-30 15:02:46 +08:00
cloud_name = gke
cloud_account = $match [ 1]
2019-07-31 02:00:00 +08:00
cloud_zone = $match [ 2] -$match [ 3] -$match [ 4]
cloud_cluster = $match [ 5]
2019-07-30 23:24:46 +08:00
if ( ( ${ _POWERLEVEL9K_KUBECONTEXT_SHORTEN [(I)gke] } ) ) ; then
2019-07-30 15:02:46 +08:00
text = $cloud_cluster
fi
# arn:aws:eks:us-east-1:123456789012:cluster/cluster-01
elif [ [ $cluster = = ( #b)arn:aws:eks:([[:alnum:]-]##):([[:digit:]]##):cluster/(?*) ]]; then
cloud_name = eks
cloud_zone = $match [ 1]
cloud_account = $match [ 2]
cloud_cluster = $match [ 3]
2019-07-30 23:24:46 +08:00
if ( ( ${ _POWERLEVEL9K_KUBECONTEXT_SHORTEN [(I)eks] } ) ) ; then
2019-07-30 15:02:46 +08:00
text = $cloud_cluster
fi
fi
if [ [ -z $text ] ] ; then
text = $name
2019-07-30 15:38:27 +08:00
if [ [ $_POWERLEVEL9K_KUBECONTEXT_SHOW_DEFAULT_NAMESPACE = = 1 || $namespace != ( default| $name ) ] ] ; then
text += " / $namespace "
2019-07-30 15:02:46 +08:00
fi
fi
2019-06-01 23:54:53 +08:00
local pat class
2019-07-23 21:47:25 +08:00
for pat class in " ${ _POWERLEVEL9K_KUBECONTEXT_CLASSES [@] } " ; do
2019-07-30 03:56:15 +08:00
if [ [ $text = = ${ ~pat } ] ] ; then
2019-07-30 15:02:46 +08:00
[ [ -n $class ] ] && state = _${ (U)class }
2019-06-01 23:54:53 +08:00
break
fi
done
fi
2020-01-26 18:45:56 +08:00
_p9k_cache_stat_set " $name " " $namespace " " $cluster " " $user " " $cloud_name " " $cloud_account " " $cloud_zone " " $cloud_cluster " " $text " " $state "
2019-06-01 23:54:53 +08:00
fi
2019-07-30 15:02:46 +08:00
2020-02-10 19:59:37 +08:00
typeset -g P9K_KUBECONTEXT_NAME = $_p9k__cache_val [ 1]
typeset -g P9K_KUBECONTEXT_NAMESPACE = $_p9k__cache_val [ 2]
typeset -g P9K_KUBECONTEXT_CLUSTER = $_p9k__cache_val [ 3]
typeset -g P9K_KUBECONTEXT_USER = $_p9k__cache_val [ 4]
typeset -g P9K_KUBECONTEXT_CLOUD_NAME = $_p9k__cache_val [ 5]
typeset -g P9K_KUBECONTEXT_CLOUD_ACCOUNT = $_p9k__cache_val [ 6]
typeset -g P9K_KUBECONTEXT_CLOUD_ZONE = $_p9k__cache_val [ 7]
typeset -g P9K_KUBECONTEXT_CLOUD_CLUSTER = $_p9k__cache_val [ 8]
[ [ -n $_p9k__cache_val [ 9] ] ] || return
_p9k_prompt_segment $0 $_p9k__cache_val [ 10] magenta white KUBERNETES_ICON 0 '' " ${ _p9k__cache_val [9]// \% /%% } "
2019-06-01 23:54:53 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_kubecontext_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$commands[kubectl]'
2020-01-26 01:04:06 +08:00
}
2019-06-01 23:54:53 +08:00
################################################################
# Dropbox status
prompt_dropbox( ) {
# The first column is just the directory, so cut it
2019-07-24 21:52:54 +08:00
local dropbox_status = " $( dropbox-cli filestatus . | cut -d\ -f2-) "
2019-06-01 23:54:53 +08:00
# Only show if the folder is tracked and dropbox is running
if [ [ " $dropbox_status " != 'unwatched' && " $dropbox_status " != "isn't running!" ] ] ; then
# If "up to date", only show the icon
if [ [ " $dropbox_status " = ~ 'up to date' ] ] ; then
dropbox_status = ""
fi
2019-07-25 03:07:28 +08:00
_p9k_prompt_segment " $0 " "white" "blue" "DROPBOX_ICON" 0 '' " ${ dropbox_status // \% /%% } "
2019-06-01 23:54:53 +08:00
fi
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_dropbox_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$commands[dropbox-cli]'
2020-01-26 01:04:06 +08:00
}
2019-06-01 23:54:53 +08:00
# print Java version number
prompt_java_version( ) {
_p9k_cached_cmd_stdout_stderr java -fullversion || return
2020-02-10 19:59:37 +08:00
local v = $_p9k__ret
2019-06-01 23:54:53 +08:00
v = ${ ${ v #* \" } % \" * }
2019-07-23 21:47:25 +08:00
( ( _POWERLEVEL9K_JAVA_VERSION_FULL ) ) || v = ${ v %%-* }
2019-06-01 23:54:53 +08:00
[ [ -n $v ] ] || return
2019-07-25 03:07:28 +08:00
_p9k_prompt_segment " $0 " "red" "white" "JAVA_ICON" 0 '' " ${ v // \% /%% } "
2019-06-01 23:54:53 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_java_version_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$commands[java]'
2020-01-26 01:04:06 +08:00
}
2019-10-08 19:46:39 +08:00
prompt_azure( ) {
2019-10-10 05:31:33 +08:00
local cfg = ${ AZURE_CONFIG_DIR :- $HOME /.azure } /azureProfile.json
if ! _p9k_cache_stat_get $0 $cfg ; then
2019-10-08 19:46:39 +08:00
local name
2019-10-10 05:31:33 +08:00
if ( ( $+commands[ jq] ) ) && name = " $( jq -r '[.subscriptions[]|select(.isDefault==true)|.name][]|strings' $cfg 2>/dev/null) " ; then
name = ${ name %% $'\n' * }
elif ! name = " $( az account show --query name --output tsv 2>/dev/null) " ; then
name =
fi
2019-10-10 01:57:18 +08:00
_p9k_cache_stat_set " $name "
2019-10-08 19:46:39 +08:00
fi
2020-02-10 19:59:37 +08:00
[ [ -n $_p9k__cache_val [ 1] ] ] || return
_p9k_prompt_segment " $0 " "blue" "white" "AZURE_ICON" 0 '' " ${ _p9k__cache_val [1]// \% /%% } "
2019-10-08 19:46:39 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_azure_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$commands[az]'
2020-01-26 01:04:06 +08:00
}
2019-12-06 06:53:30 +08:00
prompt_gcloud( ) {
unset P9K_GCLOUD_PROJECT P9K_GCLOUD_ACCOUNT
2020-02-14 18:04:34 +08:00
_p9k_read_word ~/.config/gcloud/active_config || return
if ! _p9k_cache_stat_get $0 ~/.config/gcloud/configurations/config_$_p9k__ret ; then
# TODO: Use `gcloud config configurations list` instead.
2019-12-06 06:53:30 +08:00
_p9k_cache_stat_set " $( gcloud config get-value account 2>/dev/null) " " $( gcloud config get-value project 2>/dev/null) "
fi
2020-02-10 19:59:37 +08:00
[ [ -n $_p9k__cache_val [ 1] || -n $_p9k__cache_val [ 2] ] ] || return
P9K_GCLOUD_ACCOUNT = $_p9k__cache_val [ 1]
P9K_GCLOUD_PROJECT = $_p9k__cache_val [ 2]
2019-12-06 06:53:30 +08:00
_p9k_prompt_segment " $0 " "blue" "white" "GCLOUD_ICON" 0 '' " ${ P9K_GCLOUD_ACCOUNT // \% /%% } : ${ P9K_GCLOUD_PROJECT // \% /%% } "
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_gcloud_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$commands[gcloud]'
2020-01-26 01:04:06 +08:00
}
2019-12-20 01:46:31 +08:00
prompt_google_app_cred( ) {
unset P9K_GOOGLE_APP_CRED_{ TYPE,PROJECT_ID,CLIENT_EMAIL}
2019-12-17 01:21:23 +08:00
if ! _p9k_cache_stat_get $0 $GOOGLE_APPLICATION_CREDENTIALS ; then
2019-12-20 01:46:31 +08:00
local -a lines
local q = '[.type//"", .project_id//"", .client_email//"", 0][]'
if lines = ( " ${ (@f) $( jq -r $q <$GOOGLE_APPLICATION_CREDENTIALS 2>/dev/null) } " ) && ( ( $# lines = = 4 ) ) ; then
2020-01-03 00:18:31 +08:00
local text = " ${ (j. : .)lines[1,-2] } "
local pat class state
for pat class in " ${ _POWERLEVEL9K_GOOGLE_APP_CRED_CLASSES [@] } " ; do
if [ [ $text = = ${ ~pat } ] ] ; then
[ [ -n $class ] ] && state = _${ (U)class }
break
fi
done
_p9k_cache_stat_set 1 " ${ (@)lines[1,-2] } " " $text " " $state "
2019-12-20 01:46:31 +08:00
else
_p9k_cache_stat_set 0
2019-12-17 01:21:23 +08:00
fi
fi
2019-12-20 01:46:31 +08:00
2020-02-10 19:59:37 +08:00
( ( _p9k__cache_val[ 1] ) ) || return
P9K_GOOGLE_APP_CRED_TYPE = $_p9k__cache_val [ 2]
P9K_GOOGLE_APP_CRED_PROJECT_ID = $_p9k__cache_val [ 3]
P9K_GOOGLE_APP_CRED_CLIENT_EMAIL = $_p9k__cache_val [ 4]
_p9k_prompt_segment " $0 $_p9k__cache_val [6] " "blue" "white" "GCLOUD_ICON" 0 '' " $_p9k__cache_val [5] "
2019-12-17 01:21:23 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_google_app_cred_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '${GOOGLE_APPLICATION_CREDENTIALS:+$commands[jq]}'
2020-01-26 01:04:06 +08:00
}
2019-07-25 20:11:04 +08:00
typeset -gra __p9k_nordvpn_tag = (
P9K_NORDVPN_STATUS
2019-08-02 05:18:13 +08:00
P9K_NORDVPN_TECHNOLOGY
2019-07-25 20:11:04 +08:00
P9K_NORDVPN_PROTOCOL
P9K_NORDVPN_IP_ADDRESS
P9K_NORDVPN_SERVER
P9K_NORDVPN_COUNTRY
P9K_NORDVPN_CITY
)
function _p9k_fetch_nordvpn_status( ) {
setopt err_return
local REPLY
2019-07-25 23:54:12 +08:00
zsocket /run/nordvpnd.sock
2019-07-25 20:11:04 +08:00
local -i fd = $REPLY
{
>& $fd echo -nE - $'PRI * HTTP/2.0\r\n\r\nSM\r\n\r\n\0\0\0\4\1\0\0\0\0\0\0N\1\4\0\0\0\1\203\206E\221bA\226\223\325\\k\337\31i=LnH\323j?A\223\266\243y\270\303\fYmLT{$\357]R.\203\223\257_\213\35u\320b\r&=LMedz\212\232\312\310\264\307`+\210K\203@\2te\206M\2035\5\261\37\0\0\5\0\1\0\0\0\1\0\0\0\0\0'
local tag len val
local -i n
2020-02-05 21:37:43 +08:00
{
IFS = '' read -t 0.25 -r tag
2020-02-10 22:09:35 +08:00
tag = $'\n'
2020-02-05 21:37:43 +08:00
while true; do
tag = $(( #tag))
( ( ( tag >>= 3) && tag <= $# __p9k_nordvpn_tag ) ) || break
tag = $__p9k_nordvpn_tag [ tag]
2020-02-10 22:08:55 +08:00
[ [ -t $fd ] ] || true # https://www.zsh.org/mla/workers/2020/msg00207.html
2020-02-10 22:20:52 +08:00
sysread -s 1 -t 0.25 len
2020-02-05 21:37:43 +08:00
len = $(( #len))
val =
2020-02-10 22:20:52 +08:00
while true; do
( ( len ) ) || break
2020-02-10 22:08:55 +08:00
[ [ -t $fd ] ] || true # https://www.zsh.org/mla/workers/2020/msg00207.html
2020-02-10 22:20:52 +08:00
sysread -c n -s $len -t 0.25 'val[$#val+1]'
len += -n
done
2020-02-05 21:37:43 +08:00
typeset -g $tag = $val
2020-02-10 22:08:55 +08:00
[ [ -t $fd ] ] || true # https://www.zsh.org/mla/workers/2020/msg00207.html
2020-02-10 22:20:52 +08:00
sysread -s 1 -t 0.25 tag
2020-02-05 21:37:43 +08:00
done
} <& $fd
2019-07-25 20:11:04 +08:00
} always {
exec { fd} >& -
}
}
2019-07-26 16:20:40 +08:00
# Shows the state of NordVPN connection. Works only on Linux. Can be in the following 5 states.
#
# MISSING: NordVPN is not installed or nordvpnd is not running. By default the segment is not
# shown in this state. To make it visible, override POWERLEVEL9K_NORDVPN_MISSING_CONTENT_EXPANSION
# and/or POWERLEVEL9K_NORDVPN_MISSING_VISUAL_IDENTIFIER_EXPANSION.
#
# # Display this icon when NordVPN is not installed or nordvpnd is not running
# POWERLEVEL9K_NORDVPN_MISSING_VISUAL_IDENTIFIER_EXPANSION='⭐'
#
# CONNECTED: NordVPN is connected. By default shows LOCK_ICON as icon and country code as content.
# In addition, the following variables are set for the use by
# POWERLEVEL9K_NORDVPN_CONNECTED_VISUAL_IDENTIFIER_EXPANSION and
# POWERLEVEL9K_NORDVPN_CONNECTED_CONTENT_EXPANSION:
#
# - P9K_NORDVPN_STATUS
# - P9K_NORDVPN_PROTOCOL
2019-08-02 05:18:13 +08:00
# - P9K_NORDVPN_TECHNOLOGY
2019-07-26 16:20:40 +08:00
# - P9K_NORDVPN_IP_ADDRESS
# - P9K_NORDVPN_SERVER
# - P9K_NORDVPN_COUNTRY
# - P9K_NORDVPN_CITY
# - P9K_NORDVPN_COUNTRY_CODE
#
# The last variable is trivially derived from P9K_NORDVPN_SERVER. The rest correspond to the output
# lines of `nordvpn status` command. Example of using these variables:
#
# # Display the name of the city where VPN servers are located when connected to NordVPN.
# POWERLEVEL9K_NORDVPN_CONNECTED_CONTENT_EXPANSION='${P9K_NORDVPN_CITY}'
#
# DISCONNECTED, CONNECTING, DISCONNECTING: NordVPN is disconnected/connecting/disconnecting. By
# default shows LOCK_ICON as icon and FAIL_ICON as content. In state CONNECTING the same
# P9K_NORDVPN_* variables are set as in CONNECTED. In states DISCONNECTED and DISCONNECTING only
# P9K_NORDVPN_STATUS is set. Example customizations:
#
# # Hide NordVPN segment when disconnected (segments with no icon and no content are not shown).
# POWERLEVEL9K_NORDVPN_DISCONNECTED_CONTENT_EXPANSION=
# POWERLEVEL9K_NORDVPN_DISCONNECTED_VISUAL_IDENTIFIER_EXPANSION=
#
# # When NordVPN is connecting, show country code on cyan background.
# POWERLEVEL9K_NORDVPN_CONNECTING_CONTENT_EXPANSION='${P9K_NORDVPN_COUNTRY_CODE}'
# POWERLEVEL9K_NORDVPN_CONNECTING_BACKGROUND=cyan
2019-07-25 20:11:04 +08:00
function prompt_nordvpn( ) {
2019-07-25 23:54:12 +08:00
unset $__p9k_nordvpn_tag P9K_NORDVPN_COUNTRY_CODE
2020-01-28 02:23:56 +08:00
if [ [ -e /run/nordvpnd.sock ] ] ; then
2019-07-25 23:54:12 +08:00
_p9k_fetch_nordvpn_status 2>/dev/null
if [ [ $P9K_NORDVPN_SERVER = = ( #b)([[:alpha:]]##)[[:digit:]]##.nordvpn.com ]]; then
typeset -g P9K_NORDVPN_COUNTRY_CODE = ${ (U)match[1] }
fi
fi
2019-07-25 20:11:04 +08:00
case $P9K_NORDVPN_STATUS in
Connected)
2019-07-26 16:20:40 +08:00
_p9k_prompt_segment $0 _CONNECTED blue white LOCK_ICON 0 '' " $P9K_NORDVPN_COUNTRY_CODE " ; ;
Disconnected| Connecting| Disconnecting)
local state = ${ (U)P9K_NORDVPN_STATUS }
_p9k_get_icon $0 _$state FAIL_ICON
2020-02-10 19:59:37 +08:00
_p9k_prompt_segment $0 _$state yellow white LOCK_ICON 0 '' " $_p9k__ret " ; ;
2019-07-25 20:11:04 +08:00
*)
2019-07-26 16:20:40 +08:00
_p9k_prompt_segment $0 _MISSING blue white '' 0 '' '' ; ;
2019-07-25 20:11:04 +08:00
esac
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_nordvpn_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$commands[nordvpn]'
2020-01-26 01:04:06 +08:00
}
2019-08-17 16:01:06 +08:00
function prompt_ranger( ) {
_p9k_prompt_segment $0 $_p9k_color1 yellow RANGER_ICON 0 '' $RANGER_LEVEL
2020-01-26 01:04:06 +08:00
}
_p9k_prompt_ranger_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$RANGER_LEVEL'
2019-08-17 16:01:06 +08:00
}
2019-10-16 23:36:54 +08:00
function instant_prompt_ranger( ) {
_p9k_prompt_segment prompt_ranger $_p9k_color1 yellow RANGER_ICON 1 '$RANGER_LEVEL' '$RANGER_LEVEL'
}
2019-12-01 19:14:24 +08:00
function prompt_midnight_commander( ) {
2020-02-12 22:45:23 +08:00
local -i len = $# _p9k__prompt _p9k__has_upglob
2019-12-01 19:14:24 +08:00
_p9k_prompt_segment $0 $_p9k_color1 yellow MIDNIGHT_COMMANDER_ICON 0 '' ''
2020-02-12 22:45:23 +08:00
( ( _p9k__has_upglob ) ) || typeset -g " _p9k__segment_val_ ${ _p9k__prompt_side } [_p9k__segment_index] " = $_p9k__prompt [ len+1,-1]
2020-01-26 01:04:06 +08:00
}
_p9k_prompt_midnight_commander_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$MC_TMPDIR'
2019-12-01 19:14:24 +08:00
}
function instant_prompt_midnight_commander( ) {
_p9k_prompt_segment prompt_midnight_commander $_p9k_color1 yellow MIDNIGHT_COMMANDER_ICON 0 '$MC_TMPDIR' ''
}
2020-01-03 01:59:19 +08:00
function prompt_nnn( ) {
_p9k_prompt_segment $0 6 $_p9k_color1 NNN_ICON 0 '' $NNNLVL
2020-01-26 01:04:06 +08:00
}
_p9k_prompt_nnn_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '${NNNLVL:#0}'
2020-01-03 01:59:19 +08:00
}
function instant_prompt_nnn( ) {
_p9k_prompt_segment prompt_nnn 6 $_p9k_color1 NNN_ICON 1 '${NNNLVL:#0}' '$NNNLVL'
}
2019-12-02 20:29:58 +08:00
function prompt_vim_shell( ) {
2020-02-12 22:45:23 +08:00
local -i len = $# _p9k__prompt _p9k__has_upglob
2019-12-02 20:29:58 +08:00
_p9k_prompt_segment $0 green $_p9k_color1 VIM_ICON 0 '' ''
2020-02-12 22:45:23 +08:00
( ( _p9k__has_upglob ) ) || typeset -g " _p9k__segment_val_ ${ _p9k__prompt_side } [_p9k__segment_index] " = $_p9k__prompt [ len+1,-1]
2020-01-26 01:04:06 +08:00
}
_p9k_prompt_vim_shell_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$VIMRUNTIME'
2019-12-02 20:29:58 +08:00
}
function instant_prompt_vim_shell( ) {
_p9k_prompt_segment prompt_vim_shell green $_p9k_color1 VIM_ICON 0 '$VIMRUNTIME' ''
}
2020-01-30 15:25:24 +08:00
function prompt_nix_shell( ) {
_p9k_prompt_segment $0 4 $_p9k_color1 NIX_SHELL_ICON 0 '' " ${ (M)IN_NIX_SHELL : #(pure|impure) } "
}
_p9k_prompt_nix_shell_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '${IN_NIX_SHELL:#0}'
2020-01-30 15:25:24 +08:00
}
function instant_prompt_nix_shell( ) {
_p9k_prompt_segment prompt_nix_shell 4 $_p9k_color1 NIX_SHELL_ICON 1 '${IN_NIX_SHELL:#0}' '${(M)IN_NIX_SHELL:#(pure|impure)}'
}
2019-08-19 22:07:59 +08:00
function prompt_terraform( ) {
2020-01-31 17:52:34 +08:00
local ws = $TF_WORKSPACE
if [ [ -z $TF_WORKSPACE ] ] ; then
2020-02-10 19:59:37 +08:00
_p9k_read_word ${ ${ TF_DATA_DIR :- .terraform } : A } /environment && ws = $_p9k__ret
2019-08-19 22:07:59 +08:00
fi
2020-01-31 17:52:34 +08:00
[ [ $ws = = ( | default) ] ] && return
2019-12-16 04:15:48 +08:00
local pat class
for pat class in " ${ _POWERLEVEL9K_TERRAFORM_CLASSES [@] } " ; do
if [ [ $ws = = ${ ~pat } ] ] ; then
[ [ -n $class ] ] && state = _${ (U)class }
break
fi
done
2020-01-31 17:52:34 +08:00
_p9k_prompt_segment " $0 $state " $_p9k_color1 blue TERRAFORM_ICON 0 '' $ws
2019-08-19 22:07:59 +08:00
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_terraform_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$commands[terraform]'
2020-01-26 01:04:06 +08:00
}
2019-08-27 16:57:54 +08:00
function prompt_proxy( ) {
local -U p = (
$all_proxy $http_proxy $https_proxy $ftp_proxy
$ALL_PROXY $HTTP_PROXY $HTTPS_PROXY $FTP_PROXY )
p = ( ${ (@) ${ (@) ${ (@)p#* : // } ##*@ } %%/* } )
( ( $# p = = 1 ) ) || p = ( "" )
_p9k_prompt_segment $0 $_p9k_color1 blue PROXY_ICON 0 '' " $p [1] "
}
2020-01-26 01:04:06 +08:00
_p9k_prompt_proxy_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$all_proxy$http_proxy$https_proxy$ftp_proxy$ALL_PROXY$HTTP_PROXY$HTTPS_PROXY$FTP_PROXY'
2020-01-26 01:04:06 +08:00
}
2019-10-27 18:27:03 +08:00
function prompt_direnv( ) {
2020-02-12 22:45:23 +08:00
local -i len = $# _p9k__prompt _p9k__has_upglob
2020-01-26 01:04:06 +08:00
_p9k_prompt_segment $0 $_p9k_color1 yellow DIRENV_ICON 0 '$DIRENV_DIR' ''
2020-02-12 22:45:23 +08:00
( ( _p9k__has_upglob ) ) || typeset -g " _p9k__segment_val_ ${ _p9k__prompt_side } [_p9k__segment_index] " = $_p9k__prompt [ len+1,-1]
2020-01-26 01:04:06 +08:00
}
_p9k_prompt_direnv_init( ) {
# DIRENV_DIR is set in a precmd hook. If our hook isn't the last, DIRENV_DIR might
# still get set before prompt is expanded.
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '${DIRENV_DIR:-${precmd_functions[-1]:#_p9k_precmd}}'
2019-10-27 18:27:03 +08:00
}
2019-10-28 03:31:35 +08:00
function instant_prompt_direnv( ) {
if [ [ -n $DIRENV_DIR && $precmd_functions [ -1] = = _p9k_precmd ] ] ; then
_p9k_prompt_segment prompt_direnv $_p9k_color1 yellow DIRENV_ICON 0 '' ''
fi
}
2019-10-27 18:27:03 +08:00
2020-02-10 19:59:37 +08:00
function _p9k_timewarrior_clear( ) {
[ [ -z $_p9k_timewarrior_dir ] ] && return
_p9k_timewarrior_dir =
_p9k_timewarrior_dir_mtime = 0
_p9k_timewarrior_file_mtime = 0
_p9k_timewarrior_file_name =
unset _p9k_timewarrior_tags
_p9k__state_dump_scheduled = 1
}
2020-01-27 02:29:06 +08:00
function prompt_timewarrior( ) {
local -a stat
2020-02-10 19:59:37 +08:00
local dir = ${ TIMEWARRIORDB :- ~/.timewarrior } /data
[ [ $dir = = $_p9k_timewarrior_dir ] ] || _p9k_timewarrior_clear
2020-01-27 02:29:06 +08:00
if [ [ -n $_p9k_timewarrior_file_name ] ] ; then
2020-02-10 19:59:37 +08:00
zstat -A stat +mtime -- $dir $_p9k_timewarrior_file_name 2>/dev/null || stat = ( )
2020-01-27 02:29:06 +08:00
if [ [ $stat [ 1] = = $_p9k_timewarrior_dir_mtime && $stat [ 2] = = $_p9k_timewarrior_file_mtime ] ] ; then
if ( ( $+_p9k_timewarrior_tags ) ) ; then
_p9k_prompt_segment $0 grey 255 TIMEWARRIOR_ICON 0 '' " ${ _p9k_timewarrior_tags // \% /%% } "
fi
return
fi
fi
2020-02-10 19:59:37 +08:00
if [ [ ! -d $dir ] ] ; then
_p9k_timewarrior_clear
2020-01-27 02:29:06 +08:00
return
fi
2020-02-10 19:59:37 +08:00
_p9k_timewarrior_dir = $dir
2020-01-27 02:29:06 +08:00
if [ [ $stat [ 1] != $_p9k_timewarrior_dir_mtime ] ] ; then
2020-02-10 19:59:37 +08:00
local -a files = ( $dir /<->-<->.data( .N) )
2020-01-27 02:29:06 +08:00
if ( ( ! $# files ) ) ; then
2020-02-10 19:59:37 +08:00
if ( ( $# stat ) ) || zstat -A stat +mtime -- $dir 2>/dev/null; then
2020-01-27 02:29:06 +08:00
_p9k_timewarrior_dir_mtime = $stat [ 1]
_p9k_timewarrior_file_mtime = $stat [ 1]
2020-02-10 19:59:37 +08:00
_p9k_timewarrior_file_name = $dir # sic
unset _p9k_timewarrior_tags
_p9k__state_dump_scheduled = 1
2020-01-27 02:29:06 +08:00
else
2020-02-10 19:59:37 +08:00
_p9k_timewarrior_clear
2020-01-27 02:29:06 +08:00
fi
return
fi
_p9k_timewarrior_file_name = ${ ${ (AO)files } [1] }
fi
2020-02-10 19:59:37 +08:00
if ! zstat -A stat +mtime -- $dir $_p9k_timewarrior_file_name 2>/dev/null; then
_p9k_timewarrior_clear
2020-01-27 02:29:06 +08:00
return
fi
_p9k_timewarrior_dir_mtime = $stat [ 1]
_p9k_timewarrior_file_mtime = $stat [ 2]
{ local tail = ${ ${ (Af) " $( <$_p9k_timewarrior_file_name ) " } [-1] } } 2>/dev/null
if [ [ $tail = = ( #b)'inc '[^\ ]##(|\ #\#(*)) ]]; then
_p9k_timewarrior_tags = ${ ${ match [2]## # } %% # }
_p9k_prompt_segment $0 grey 255 TIMEWARRIOR_ICON 0 '' " ${ _p9k_timewarrior_tags // \% /%% } "
else
unset _p9k_timewarrior_tags
fi
2020-02-10 19:59:37 +08:00
_p9k__state_dump_scheduled = 1
2020-01-27 02:29:06 +08:00
}
function _p9k_prompt_timewarrior_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '$commands[timew]'
2020-01-27 02:29:06 +08:00
}
2020-02-03 18:47:55 +08:00
prompt_wifi( ) {
2020-02-12 22:45:23 +08:00
local -i len = $# _p9k__prompt _p9k__has_upglob
2020-02-03 18:47:55 +08:00
_p9k_prompt_segment $0 green $_p9k_color1 WIFI_ICON 1 '$_p9k__wifi_on' '$P9K_WIFI_LAST_TX_RATE Mbps'
2020-02-12 22:45:23 +08:00
( ( _p9k__has_upglob ) ) || typeset -g " _p9k__segment_val_ ${ _p9k__prompt_side } [_p9k__segment_index] " = $_p9k__prompt [ len+1,-1]
2020-02-03 18:47:55 +08:00
}
_p9k_prompt_wifi_init( ) {
if [ [ -x /System/Library/PrivateFrameworks/Apple80211.framework/Versions/Current/Resources/airport ] ] ; then
typeset -g _p9k__wifi_on =
typeset -g P9K_WIFI_LAST_TX_RATE =
typeset -g P9K_WIFI_SSID =
typeset -g P9K_WIFI_LINK_AUTH =
typeset -g P9K_WIFI_RSSI =
typeset -g P9K_WIFI_NOISE =
typeset -g P9K_WIFI_BARS =
_p9k__async_segments_compute += _p9k_prompt_wifi_compute
else
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '${:-}'
2020-02-03 18:47:55 +08:00
fi
}
_p9k_prompt_wifi_compute( ) {
_p9k_worker_async _p9k_prompt_wifi_async _p9k_prompt_wifi_sync
}
_p9k_prompt_wifi_async( ) {
local airport = /System/Library/PrivateFrameworks/Apple80211.framework/Versions/Current/Resources/airport
local last_tx_rate ssid link_auth rssi noise bars on out line v state
{
[ [ -x $airport ] ] || return 0
out = " $( $airport -I) " || return 0
for line in ${ ${ ${ (f)out } ##[[ : space : ]]# } %%[[ : space : ]]# } ; do
v = ${ line #* : }
case $line [ 1,-$# v-3] in
agrCtlRSSI) rssi = $v ; ;
agrCtlNoise) noise = $v ; ;
state) state = $v ; ;
lastTxRate) last_tx_rate = $v ; ;
link\ auth) link_auth = $v ; ;
SSID) ssid = $v ; ;
esac
done
if [ [ $state != running || $rssi != ( 0| -<->) || $noise != ( 0| -<->) ] ] ; then
rssi =
noise =
last_tx_rate =
link_auth =
ssid =
bars =
return 0
fi
# https://www.speedguide.net/faq/how-to-read-rssisignal-and-snrnoise-ratings-440
# http://www.wireless-nets.com/resources/tutorials/define_SNR_values.html
local -i snr_margin = 'rssi - noise'
if ( ( snr_margin >= 40 ) ) ; then
bars = 4
elif ( ( snr_margin >= 25 ) ) ; then
bars = 3
elif ( ( snr_margin >= 15 ) ) ; then
bars = 2
elif ( ( snr_margin >= 10 ) ) ; then
bars = 1
else
bars = 0
fi
on = 1
} always {
if [ [ $_p9k__wifi_on != $on ||
$P9K_WIFI_LAST_TX_RATE != $last_tx_rate ||
$P9K_WIFI_SSID != $ssid ||
$P9K_WIFI_LINK_AUTH != $link_auth ||
$P9K_WIFI_RSSI != $rssi ||
$P9K_WIFI_NOISE != $noise ||
$P9K_WIFI_BARS != $bars ] ] ; then
_p9k__wifi_on = $on
P9K_WIFI_LAST_TX_RATE = $last_tx_rate
P9K_WIFI_SSID = $ssid
P9K_WIFI_LINK_AUTH = $link_auth
P9K_WIFI_RSSI = $rssi
P9K_WIFI_NOISE = $noise
P9K_WIFI_BARS = $bars
_p9k_print_params \
_p9k__wifi_on \
P9K_WIFI_LAST_TX_RATE \
P9K_WIFI_SSID \
P9K_WIFI_LINK_AUTH \
P9K_WIFI_RSSI \
P9K_WIFI_NOISE \
P9K_WIFI_BARS
echo -E - 'reset=1'
fi
}
}
_p9k_prompt_wifi_sync( ) {
if [ [ -n $REPLY ] ] ; then
eval $REPLY
_p9k_worker_reply $REPLY
fi
}
2020-02-06 23:10:53 +08:00
function _p9k_asdf_check_meta( ) {
[ [ -n $_p9k_asdf_meta_sig ] ] || return
[ [ -z $^_p9k_asdf_meta_non_files( #qN) ]] || return
local -a stat
zstat -A stat +mtime -- $_p9k_asdf_meta_files 2>/dev/null || return
2020-02-08 23:47:58 +08:00
[ [ $_p9k_asdf_meta_sig = = $ASDF_CONFIG_FILE $'\0' $ASDF_DATA_DIR $'\0' ${ (pj : \0 : )stat } ] ] || return
2020-02-06 23:10:53 +08:00
}
function _p9k_asdf_init_meta( ) {
2020-02-10 19:59:37 +08:00
local last_sig = $_p9k_asdf_meta_sig
2020-02-06 23:10:53 +08:00
{
local -a files
local -i legacy_enabled
_p9k_asdf_plugins = ( )
_p9k_asdf_file_info = ( )
local cfg = ${ ASDF_CONFIG_FILE :- ~/.asdfrc }
files += $cfg
if [ [ -f $cfg && -r $cfg ] ] ; then
# Config parser in adsf is very strange.
#
# This gives "yes":
#
# legacy_version_file = yes = no
#
# This gives "no":
#
# legacy_version_file = yes
# legacy_version_file = yes
#
# We do the same.
local lines = ( ${ (@M) ${ (f) " $( <$cfg ) " } : #[[ : space : ]]#legacy_version_file[[ : space : ]]#=* } )
if [ [ $# lines = = 1 && ${ ${ (s : = : )lines[1] } [2] } = = [ [ :space:] ] #yes[[:space:]]# ]]; then
legacy_enabled = 1
fi
fi
local root = ${ ASDF_DATA_DIR :- ~/.asdf } /plugins
files += $root
if [ [ -d $root ] ] ; then
local plugin
for plugin in $root /[ ^[ :space:] ] ##(N); do
_p9k_asdf_plugins += ${ plugin : t }
2020-02-14 03:44:59 +08:00
( ( legacy_enabled ) ) || continue
2020-02-06 23:10:53 +08:00
if [ [ ! -e $plugin /bin ] ] ; then
files += $plugin /bin
else
local list_names = $plugin /bin/list-legacy-filenames
files += $list_names
if [ [ -x $list_names ] ] ; then
2020-02-14 03:44:59 +08:00
local parse = $plugin /bin/parse-legacy-file
2020-02-06 23:10:53 +08:00
local -i has_parse = 0
2020-02-14 03:44:59 +08:00
files += $parse
[ [ -x $parse ] ] && has_parse = 1
2020-02-06 23:10:53 +08:00
local name
for name in $( $list_names 2>/dev/null) ; do
2020-02-14 03:44:59 +08:00
[ [ $name = = ( */*| .tool-versions) ] ] && continue
2020-02-06 23:10:53 +08:00
_p9k_asdf_file_info[ $name ] += " ${ plugin : t } $has_parse "
done
fi
fi
done
fi
_p9k_asdf_meta_files = ( $^files( N) )
_p9k_asdf_meta_non_files = ( ${ files : |_p9k_asdf_meta_files } )
local -a stat
zstat -A stat +mtime -- $_p9k_asdf_meta_files 2>/dev/null || return
2020-02-08 23:47:58 +08:00
_p9k_asdf_meta_sig = $ASDF_CONFIG_FILE $'\0' $ASDF_DATA_DIR $'\0' ${ (pj : \0 : )stat }
2020-02-06 23:10:53 +08:00
} always {
2020-02-10 19:59:37 +08:00
if ( ( $? = = 0 ) ) ; then
_p9k__state_dump_scheduled = 1
return
fi
[ [ -n $last_sig ] ] && _p9k__state_dump_scheduled = 1
2020-02-06 23:10:53 +08:00
_p9k_asdf_meta_files = ( )
_p9k_asdf_meta_non_files = ( )
_p9k_asdf_meta_sig =
_p9k_asdf_plugins = ( )
_p9k_asdf_file_info = ( )
_p9k__asdf_dir2files = ( )
_p9k_asdf_file2versions = ( )
}
}
2020-02-07 18:38:18 +08:00
# Usage: _p9k_asdf_parse_version_file <file> <is_legacy>
#
# Mutates `versions` on success.
function _p9k_asdf_parse_version_file( ) {
local file = $1
local is_legacy = $2
local -a stat
zstat -A stat +mtime $file 2>/dev/null || return
if ( ( is_legacy ) ) ; then
local plugin has_parse
for plugin has_parse in $= _p9k_asdf_file_info[ $file :t] ; do
2020-02-08 23:47:58 +08:00
local cached = $_p9k_asdf_file2versions [ $plugin :$file ]
2020-02-07 18:38:18 +08:00
if [ [ $cached = = $stat [ 1] :* ] ] ; then
2020-02-09 00:00:31 +08:00
local v = ${ cached #* : }
2020-02-07 18:38:18 +08:00
else
if ( ( has_parse ) ) ; then
local v = ( $( ${ ASDF_DATA_DIR :- ~/.asdf } /plugins/$plugin /bin/parse-legacy-file $file 2>/dev/null) )
else
{ local v = ( $( <$file ) ) } 2>/dev/null
fi
2020-02-08 23:47:58 +08:00
_p9k_asdf_file2versions[ $plugin :$file ] = $stat [ 1] :" $v "
2020-02-10 19:59:37 +08:00
_p9k__state_dump_scheduled = 1
2020-02-07 18:38:18 +08:00
fi
2020-02-09 00:00:31 +08:00
( ( $# v ) ) && : ${ versions [ $plugin ]= " $v " }
2020-02-07 18:38:18 +08:00
done
else
2020-02-08 23:47:58 +08:00
local cached = $_p9k_asdf_file2versions [ :$file ]
2020-02-07 18:38:18 +08:00
if [ [ $cached = = $stat [ 1] :* ] ] ; then
local file_versions = ( ${ (0) ${ cached #* : } } )
else
local file_versions = ( )
{ local lines = ( ${ (@) ${ (f) " $( <$file ) " } / \# * } ) } 2>/dev/null
local line
for line in $lines ; do
local words = ( $= line)
( ( $# words > 1 && $_p9k_asdf_plugins [ ( Ie) $words [ 1] ] ) ) || continue
file_versions += ( $words [ 1] " ${ words [2,-1] } " )
done
2020-02-08 23:47:58 +08:00
_p9k_asdf_file2versions[ :$file ] = $stat [ 1] :${ (pj : \0 : )file_versions }
2020-02-10 19:59:37 +08:00
_p9k__state_dump_scheduled = 1
2020-02-07 18:38:18 +08:00
fi
local plugin version
for plugin version in $file_versions ; do
2020-02-09 00:00:31 +08:00
: ${ versions [ $plugin ]= $version }
2020-02-07 18:38:18 +08:00
done
fi
return 0
}
2020-02-06 23:10:53 +08:00
function prompt_asdf( ) {
_p9k_asdf_check_meta || _p9k_asdf_init_meta || return
local -A versions
local -a stat
zstat -A stat +mtime ~ 2>/dev/null || return
local dirs = ( $_p9k__parent_dirs ~)
local mtimes = ( $_p9k__parent_mtimes $stat [ 1] )
2020-02-07 18:38:18 +08:00
local -i has_global
2020-02-06 23:10:53 +08:00
local elem
for elem in ${ (@) ${ :- {1.. $# dirs } } /( #m)*/${${:-$MATCH:$_p9k__asdf_dir2files[$dirs[MATCH]]}#$MATCH:$mtimes[MATCH]:}}; do
if [ [ $elem = = *:* ] ] ; then
local dir = $dirs [ ${ elem %% : * } ]
zstat -A stat +mtime $dir 2>/dev/null || return
local files = ( $dir /.tool-versions( N) $dir /${ (k)^_p9k_asdf_file_info } ( N) )
_p9k__asdf_dir2files[ $dir ] = $stat [ 1] :${ (pj : \0 : )files }
else
local files = ( ${ (0)elem } )
fi
2020-02-07 18:38:18 +08:00
if [ [ ${ files [1] : h } = = ~ ] ] ; then
has_global = 1
local -A local_versions = ( ${ (kv)versions } )
versions = ( )
fi
2020-02-06 23:10:53 +08:00
local file
for file in $files ; do
2020-02-07 18:38:18 +08:00
[ [ $file = = */.tool-versions ] ]
_p9k_asdf_parse_version_file $file $? || return
2020-02-06 23:10:53 +08:00
done
done
2020-02-07 18:38:18 +08:00
if ( ( ! has_global ) ) ; then
has_global = 1
local -A local_versions = ( ${ (kv)versions } )
versions = ( )
fi
2020-02-06 23:10:53 +08:00
if [ [ -r $ASDF_DEFAULT_TOOL_VERSIONS_FILENAME ] ] ; then
2020-02-07 18:38:18 +08:00
_p9k_asdf_parse_version_file $ASDF_DEFAULT_TOOL_VERSIONS_FILENAME 0 || return
2020-02-06 23:10:53 +08:00
fi
2020-02-07 18:38:18 +08:00
local plugin
for plugin in $_p9k_asdf_plugins ; do
2020-02-06 23:31:30 +08:00
local upper = ${ (U)plugin//-/_ }
2020-02-11 18:22:53 +08:00
if ( ( $+parameters[ _POWERLEVEL9K_ASDF_${ upper } _SOURCES] ) ) ; then
local sources = ( ${ (P) ${ :- _POWERLEVEL9K_ASDF_ ${ upper } _SOURCES } } )
2020-02-07 18:38:18 +08:00
else
2020-02-11 18:22:53 +08:00
local sources = ( $_POWERLEVEL9K_ASDF_SOURCES )
2020-02-07 18:38:18 +08:00
fi
2020-02-11 18:22:53 +08:00
local version = " ${ (P) ${ :- ASDF_ ${ upper } _VERSION } } "
2020-02-07 18:38:18 +08:00
if [ [ -n $version ] ] ; then
( ( $sources [ ( I) shell] ) ) || continue
else
version = $local_versions [ $plugin ]
if [ [ -n $version ] ] ; then
( ( $sources [ ( I) local] ) ) || continue
else
version = $versions [ $plugin ]
[ [ -n $version ] ] || continue
( ( $sources [ ( I) global] ) ) || continue
fi
fi
if [ [ $version = = $versions [ $plugin ] ] ] ; then
2020-02-11 18:22:53 +08:00
if ( ( $+parameters[ _POWERLEVEL9K_ASDF_${ upper } _PROMPT_ALWAYS_SHOW] ) ) ; then
( ( _POWERLEVEL9K_ASDF_${ upper } _PROMPT_ALWAYS_SHOW ) ) || continue
2020-02-07 18:38:18 +08:00
else
2020-02-11 18:22:53 +08:00
( ( _POWERLEVEL9K_ASDF_PROMPT_ALWAYS_SHOW ) ) || continue
2020-02-07 18:38:18 +08:00
fi
fi
2020-02-07 18:46:08 +08:00
if [ [ $version = = system ] ] ; then
2020-02-11 18:22:53 +08:00
if ( ( $+parameters[ _POWERLEVEL9K_ASDF_${ upper } _SHOW_SYSTEM] ) ) ; then
( ( _POWERLEVEL9K_ASDF_${ upper } _SHOW_SYSTEM ) ) || continue
2020-02-07 18:46:08 +08:00
else
2020-02-11 18:22:53 +08:00
( ( _POWERLEVEL9K_ASDF_SHOW_SYSTEM ) ) || continue
2020-02-07 18:46:08 +08:00
fi
fi
2020-02-06 23:10:53 +08:00
_p9k_get_icon $0 _$upper ${ upper } _ICON $plugin
2020-02-10 19:59:37 +08:00
_p9k_prompt_segment $0 _$upper green $_p9k_color1 $'\1' $_p9k__ret 0 '' ${ version // \% /%% }
2020-02-06 23:10:53 +08:00
done
}
_p9k_prompt_asdf_init( ) {
2020-02-10 19:59:37 +08:00
typeset -g " _p9k__segment_cond_ ${ _p9k__prompt_side } [_p9k__segment_index] " = '${commands[asdf]:-${${+functions[asdf]}:#0}}'
2020-02-06 23:10:53 +08:00
}
2020-01-20 16:57:03 +08:00
# Use two preexec hooks to survive https://github.com/MichaelAquilina/zsh-you-should-use with
# YSU_HARDCORE=1. See https://github.com/romkatv/powerlevel10k/issues/427.
_p9k_preexec1( ) {
2020-02-10 19:59:37 +08:00
if ( ( $+_p9k__real_zle_rprompt_indent ) ) ; then
if [ [ -n $_p9k__real_zle_rprompt_indent ] ] ; then
ZLE_RPROMPT_INDENT = $_p9k__real_zle_rprompt_indent
2019-06-14 22:14:04 +08:00
else
unset ZLE_RPROMPT_INDENT
fi
2020-02-10 19:59:37 +08:00
unset _p9k__real_zle_rprompt_indent
2019-06-14 22:14:04 +08:00
fi
2020-01-20 16:57:03 +08:00
( ( $+functions[ TRAPINT] ) ) || trap - INT
}
_p9k_preexec2( ) {
2019-10-25 19:22:50 +08:00
_p9k__preexec_cmd = $2
_p9k__timer_start = EPOCHREALTIME
2019-06-14 22:14:04 +08:00
}
2019-06-01 23:54:53 +08:00
2020-01-18 22:41:43 +08:00
function _p9k_prompt_net_iface_init( ) {
typeset -g _p9k__public_ip_vpn =
typeset -g _p9k__public_ip_not_vpn =
2020-02-05 23:22:44 +08:00
typeset -g P9K_IP_IP =
typeset -g P9K_IP_INTERFACE =
typeset -g P9K_IP_TX_BYTES =
typeset -g P9K_IP_RX_BYTES =
typeset -g P9K_IP_TX_RATE =
typeset -g P9K_IP_RX_RATE =
typeset -g _p9__ip_timestamp =
2020-01-18 22:41:43 +08:00
typeset -g _p9k__vpn_ip_ip =
[ [ -z $_POWERLEVEL9K_PUBLIC_IP_VPN_INTERFACE ] ] && _p9k__public_ip_not_vpn = 1
2020-01-25 18:01:14 +08:00
_p9k__async_segments_compute += _p9k_prompt_net_iface_compute
2020-01-18 22:41:43 +08:00
}
2020-02-05 23:22:44 +08:00
# reads `iface2ip` and sets `iface` and `ip`
2020-01-18 22:41:43 +08:00
function _p9k_prompt_net_iface_match( ) {
2020-02-05 23:22:44 +08:00
local iface_regex = " ^( $1 )\$ "
2020-01-18 22:41:43 +08:00
for iface ip in " ${ (@kv)iface2ip } " ; do
[ [ $iface = ~ $iface_regex ] ] && return
done
return 1
}
2020-01-25 18:01:14 +08:00
function _p9k_prompt_net_iface_compute( ) {
_p9k_worker_async _p9k_prompt_net_iface_async _p9k_prompt_net_iface_sync
}
2020-01-18 22:41:43 +08:00
function _p9k_prompt_net_iface_async( ) {
2020-02-05 19:26:05 +08:00
# netstat -inbI en0
2020-01-18 22:41:43 +08:00
local iface ip line var
2020-02-05 23:22:44 +08:00
typeset -a iface2ip
2020-02-06 20:37:22 +08:00
if ( ( $+commands[ ifconfig] ) ) ; then
for line in ${ (f) " $( command ifconfig 2>/dev/null) " } ; do
2019-11-09 20:49:08 +08:00
if [ [ $line = = ( #b)([^[:space:]]##):[[:space:]]##flags=(<->)'<'* ]]; then
[ [ $match [ 2] = = *[ 13579] ] ] && iface = $match [ 1] || iface =
elif [ [ -n $iface && $line = = ( #b)[[:space:]]##inet[[:space:]]##([0-9.]##)* ]]; then
2020-02-05 23:22:44 +08:00
iface2ip += ( $iface $match [ 1] )
2019-11-09 20:49:08 +08:00
iface =
fi
done
2020-02-06 20:37:22 +08:00
elif ( ( $+commands[ ip] ) ) ; then
for line in ${ (f) " $( command ip -4 a show 2>/dev/null) " } ; do
2019-11-09 20:49:08 +08:00
if [ [ $line = = ( #b)<->:[[:space:]]##([^:]##):[[:space:]]##\<([^\>]#)\>* ]]; then
[ [ ,$match [ 2] , = = *,UP,* ] ] && iface = $match [ 1] || iface =
elif [ [ -n $iface && $line = = ( #b)[[:space:]]##inet[[:space:]]##([0-9.]##)* ]]; then
2020-02-05 23:22:44 +08:00
iface2ip += ( $iface $match [ 1] )
2019-11-09 20:49:08 +08:00
iface =
fi
done
fi
2020-01-18 22:41:43 +08:00
if _p9k_prompt_net_iface_match $_POWERLEVEL9K_PUBLIC_IP_VPN_INTERFACE ; then
2020-01-25 18:01:14 +08:00
local public_ip_vpn = 1
local public_ip_not_vpn =
2020-01-18 22:41:43 +08:00
else
2020-01-25 18:01:14 +08:00
local public_ip_vpn =
local public_ip_not_vpn = 1
2020-01-18 22:41:43 +08:00
fi
if _p9k_prompt_net_iface_match $_POWERLEVEL9K_IP_INTERFACE ; then
2020-02-05 23:22:44 +08:00
local ip_ip = $ip ip_interface = $iface ip_timestamp = $EPOCHREALTIME
2020-02-06 00:26:16 +08:00
local ip_tx_bytes = 0 ip_rx_bytes = 0 ip_tx_rate = '0 B/s' ip_rx_rate = '0 B/s'
2020-02-05 23:22:44 +08:00
if [ [ $_p9k_os = = ( Linux| Android) ] ] ; then
if [ [ -r /sys/class/net/$iface /statistics/rx_bytes ] ] &&
_p9k_read_file /sys/class/net/$iface /statistics/rx_bytes; then
2020-02-10 19:59:37 +08:00
ip_rx_bytes = $_p9k__ret
2020-02-05 23:22:44 +08:00
fi
if [ [ -r /sys/class/net/$iface /statistics/tx_bytes ] ] &&
_p9k_read_file /sys/class/net/$iface /statistics/tx_bytes; then
2020-02-10 19:59:37 +08:00
ip_tx_bytes = $_p9k__ret
2020-02-05 23:22:44 +08:00
fi
2020-02-05 23:38:09 +08:00
elif [ [ $_p9k_os = = ( BSD| OSX) && $+commands[ netstat] = = 1 ] ] ; then
2020-02-05 23:33:46 +08:00
local -a lines
if lines = ( ${ (f) " $( netstat -inbI $iface ) " } ) ; then
local header = ( $= lines[ 1] )
local -i rx_idx = $header [ ( Ie) Ibytes]
local -i tx_idx = $header [ ( Ie) Obytes]
for line in ${ lines : 1 } ; do
( ( ip_rx_bytes += ${ line [(w)rx_idx] } ) )
( ( ip_tx_bytes += ${ line [(w)tx_idx] } ) )
2020-02-05 23:22:44 +08:00
done
fi
fi
if [ [ $ip_ip = = $P9K_IP_IP && $iface = = $P9K_IP_INTERFACE ] ] ; then
local -F t = 'ip_timestamp - _p9__ip_timestamp'
if ( ( t <= 0 ) ) ; then
ip_tx_rate = $P9K_IP_TX_RATE
ip_rx_rate = $P9K_IP_RX_RATE
else
2020-02-06 00:26:16 +08:00
_p9k_human_readable_bytes $(( ( ip_tx_bytes - P9K_IP_TX_BYTES) / t))
2020-02-10 19:59:37 +08:00
[ [ $_p9k__ret = = *B ] ] && ip_tx_rate = " $_p9k__ret [1,-2] B/s " || ip_tx_rate = " $_p9k__ret [1,-2] $_p9k__ret [-1]iB/s "
2020-02-06 00:26:16 +08:00
_p9k_human_readable_bytes $(( ( ip_rx_bytes - P9K_IP_RX_BYTES) / t))
2020-02-10 19:59:37 +08:00
[ [ $_p9k__ret = = *B ] ] && ip_rx_rate = " $_p9k__ret [1,-2] B/s " || ip_rx_rate = " $_p9k__ret [1,-2] $_p9k__ret [-1]iB/s "
2020-02-05 23:22:44 +08:00
fi
fi
2020-01-18 22:41:43 +08:00
else
2020-02-05 23:22:44 +08:00
local ip_ip = ip_interface = ip_tx_bytes = ip_rx_bytes = ip_tx_rate = ip_rx_rate = ip_timestamp =
2020-01-18 22:41:43 +08:00
fi
if _p9k_prompt_net_iface_match $_POWERLEVEL9K_VPN_IP_INTERFACE ; then
2020-01-25 18:01:14 +08:00
local vpn_ip_ip = $ip
2020-01-18 22:41:43 +08:00
else
2020-01-25 18:01:14 +08:00
local vpn_ip_ip =
fi
[ [ $_p9k__public_ip_vpn = = $public_ip_vpn &&
$_p9k__public_ip_not_vpn = = $public_ip_not_vpn &&
2020-02-05 23:22:44 +08:00
$P9K_IP_IP = = $ip_ip &&
$P9K_IP_INTERFACE = = $ip_interface &&
$P9K_IP_TX_BYTES = = $ip_tx_bytes &&
$P9K_IP_RX_BYTES = = $ip_rx_bytes &&
$P9K_IP_TX_RATE = = $ip_tx_rate &&
$P9K_IP_RX_RATE = = $ip_rx_rate &&
2020-01-25 18:01:14 +08:00
$_p9k__vpn_ip_ip = = $vpn_ip_ip ] ] && return 1
_p9k__public_ip_vpn = $public_ip_vpn
_p9k__public_ip_not_vpn = $public_ip_not_vpn
2020-02-05 23:22:44 +08:00
P9K_IP_IP = $ip_ip
P9K_IP_INTERFACE = $ip_interface
P9K_IP_TX_BYTES = $ip_tx_bytes
P9K_IP_RX_BYTES = $ip_rx_bytes
P9K_IP_TX_RATE = $ip_tx_rate
P9K_IP_RX_RATE = $ip_rx_rate
_p9__ip_timestamp = $ip_timestamp
2020-01-25 18:01:14 +08:00
_p9k__vpn_ip_ip = $vpn_ip_ip
2020-02-05 23:22:44 +08:00
_p9k_print_params \
_p9k__public_ip_vpn \
_p9k__public_ip_not_vpn \
P9K_IP_IP \
P9K_IP_INTERFACE \
P9K_IP_TX_BYTES \
P9K_IP_RX_BYTES \
P9K_IP_TX_RATE \
P9K_IP_RX_RATE \
_p9__ip_timestamp \
_p9k__vpn_ip_ip
2020-01-25 18:01:14 +08:00
echo -E - 'reset=1'
}
_p9k_prompt_net_iface_sync( ) {
eval $REPLY
_p9k_worker_reply $REPLY
2019-08-29 00:55:33 +08:00
}
2019-06-01 23:54:53 +08:00
function _p9k_set_prompt( ) {
2019-10-29 22:54:30 +08:00
PROMPT =
2019-06-01 23:54:53 +08:00
RPROMPT =
2019-10-29 22:54:30 +08:00
[ [ $1 = = instant_ ] ] || PROMPT += '${$((_p9k_on_expand()))+}'
PROMPT += $_p9k_prompt_prefix_left
2019-06-01 23:54:53 +08:00
2019-11-03 02:03:45 +08:00
local -i left_idx = 1 right_idx = 1 num_lines = $# _p9k_line_segments_left
2020-02-10 19:59:37 +08:00
for _p9k__line_index in { 1..$num_lines } ; do
2019-07-18 18:21:54 +08:00
local right =
2019-07-23 21:47:25 +08:00
if ( ( !_POWERLEVEL9K_DISABLE_RPROMPT ) ) ; then
2020-02-10 19:59:37 +08:00
_p9k__dir =
2019-10-25 19:22:50 +08:00
_p9k__prompt =
2020-02-10 19:59:37 +08:00
_p9k__segment_index = right_idx
_p9k__prompt_side = right
2020-01-26 01:04:06 +08:00
if [ [ $1 = = instant_ ] ] ; then
2020-02-10 19:59:37 +08:00
for _p9k__segment_name in ${ ${ (0)_p9k_line_segments_right[_p9k__line_index] } %_joined } ; do
if ( ( $+functions[ instant_prompt_$_p9k__segment_name ] ) ) ; then
local disabled = _POWERLEVEL9K_${ (U)_p9k__segment_name } _DISABLED_DIR_PATTERN
2020-01-27 22:04:34 +08:00
if [ [ $_p9k__cwd != ${ (P)~disabled } ] ] ; then
2020-01-26 01:04:06 +08:00
local -i len = $# _p9k__prompt
2020-02-10 19:59:37 +08:00
_p9k__non_hermetic_expansion = 0
instant_prompt_$_p9k__segment_name
if ( ( _p9k__non_hermetic_expansion ) ) ; then
2020-01-26 01:04:06 +08:00
_p9k__prompt[ len+1,-1] =
fi
fi
fi
2020-02-10 19:59:37 +08:00
( ( ++_p9k__segment_index) )
2020-01-26 01:04:06 +08:00
done
else
2020-02-10 19:59:37 +08:00
for _p9k__segment_name in ${ ${ (0)_p9k_line_segments_right[_p9k__line_index] } %_joined } ; do
local cond = $_p9k__segment_cond_right [ _p9k__segment_index]
2020-01-26 01:04:06 +08:00
if [ [ -z $cond || -n ${ (e)cond } ] ] ; then
2020-02-10 19:59:37 +08:00
local disabled = _POWERLEVEL9K_${ (U)_p9k__segment_name } _DISABLED_DIR_PATTERN
2020-01-27 22:04:34 +08:00
if [ [ $_p9k__cwd != ${ (P)~disabled } ] ] ; then
2020-02-10 19:59:37 +08:00
local val = $_p9k__segment_val_right [ _p9k__segment_index]
2020-01-26 01:04:06 +08:00
if [ [ -n $val ] ] ; then
_p9k__prompt += $val
else
2020-02-10 19:59:37 +08:00
if [ [ $_p9k__segment_name = = custom_* ] ] ; then
_p9k_custom_prompt $_p9k__segment_name [ 8,-1]
elif ( ( $+functions[ prompt_$_p9k__segment_name ] ) ) ; then
prompt_$_p9k__segment_name
2020-01-26 01:04:06 +08:00
fi
fi
fi
fi
2020-02-10 19:59:37 +08:00
( ( ++_p9k__segment_index) )
2020-01-26 01:04:06 +08:00
done
fi
2019-10-25 19:22:50 +08:00
_p9k__prompt = ${ ${ _p9k__prompt // $' %{\b' / '%{%G' } // $' \b' }
2020-02-10 19:59:37 +08:00
right_idx = _p9k__segment_index
if [ [ -n $_p9k__prompt || $_p9k_line_never_empty_right [ _p9k__line_index] = = 1 ] ] ; then
right = $_p9k_line_prefix_right [ _p9k__line_index] $_p9k__prompt $_p9k_line_suffix_right [ _p9k__line_index]
2019-07-16 22:19:16 +08:00
fi
fi
2020-02-10 19:59:37 +08:00
unset _p9k__dir
_p9k__prompt = $_p9k_line_prefix_left [ _p9k__line_index]
_p9k__segment_index = left_idx
_p9k__prompt_side = left
2020-01-26 01:04:06 +08:00
if [ [ $1 = = instant_ ] ] ; then
2020-02-10 19:59:37 +08:00
for _p9k__segment_name in ${ ${ (0)_p9k_line_segments_left[_p9k__line_index] } %_joined } ; do
if ( ( $+functions[ instant_prompt_$_p9k__segment_name ] ) ) ; then
local disabled = _POWERLEVEL9K_${ (U)_p9k__segment_name } _DISABLED_DIR_PATTERN
2020-01-27 22:04:34 +08:00
if [ [ $_p9k__cwd != ${ (P)~disabled } ] ] ; then
2020-01-26 01:04:06 +08:00
local -i len = $# _p9k__prompt
2020-02-10 19:59:37 +08:00
_p9k__non_hermetic_expansion = 0
instant_prompt_$_p9k__segment_name
if ( ( _p9k__non_hermetic_expansion ) ) ; then
2020-01-26 01:04:06 +08:00
_p9k__prompt[ len+1,-1] =
fi
fi
fi
2020-02-10 19:59:37 +08:00
( ( ++_p9k__segment_index) )
2020-01-26 01:04:06 +08:00
done
else
2020-02-10 19:59:37 +08:00
for _p9k__segment_name in ${ ${ (0)_p9k_line_segments_left[_p9k__line_index] } %_joined } ; do
local cond = $_p9k__segment_cond_left [ _p9k__segment_index]
2020-01-26 01:04:06 +08:00
if [ [ -z $cond || -n ${ (e)cond } ] ] ; then
2020-02-10 19:59:37 +08:00
local disabled = _POWERLEVEL9K_${ (U)_p9k__segment_name } _DISABLED_DIR_PATTERN
2020-01-27 22:04:34 +08:00
if [ [ $_p9k__cwd != ${ (P)~disabled } ] ] ; then
2020-02-10 19:59:37 +08:00
local val = $_p9k__segment_val_left [ _p9k__segment_index]
2020-01-26 01:04:06 +08:00
if [ [ -n $val ] ] ; then
_p9k__prompt += $val
else
2020-02-10 19:59:37 +08:00
if [ [ $_p9k__segment_name = = custom_* ] ] ; then
_p9k_custom_prompt $_p9k__segment_name [ 8,-1]
elif ( ( $+functions[ prompt_$_p9k__segment_name ] ) ) ; then
prompt_$_p9k__segment_name
2020-01-26 01:04:06 +08:00
fi
fi
fi
fi
2020-02-10 19:59:37 +08:00
( ( ++_p9k__segment_index) )
2020-01-26 01:04:06 +08:00
done
fi
2019-10-25 19:22:50 +08:00
_p9k__prompt = ${ ${ _p9k__prompt // $' %{\b' / '%{%G' } // $' \b' }
2020-02-10 19:59:37 +08:00
left_idx = _p9k__segment_index
_p9k__prompt += $_p9k_line_suffix_left [ _p9k__line_index]
if ( ( $+_p9k__dir || ( _p9k__line_index != num_lines && $# right) ) ) ; then
_p9k__prompt = '${${:-${_p9k__d::=0}${_p9k__rprompt::=' $right '}${_p9k__lprompt::=' $_p9k__prompt '}}+}'
2019-10-25 19:22:50 +08:00
_p9k__prompt += $_p9k_gap_pre
2020-02-10 19:59:37 +08:00
if ( ( $+_p9k__dir ) ) ; then
if ( ( _p9k__line_index = = num_lines && ( _POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS > 0 || _POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS_PCT > 0) ) ) ; then
2019-07-23 21:47:25 +08:00
local a = $_POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS
2020-02-10 19:59:37 +08:00
local f = $(( 0 .01*_POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS_PCT)) '*_p9k__clm'
_p9k__prompt += " \${\${_p9k__h::= $(( ( $a <$f ) * $f + ( $a >= $f ) * $a )) }+} "
2019-07-19 19:29:54 +08:00
else
2020-02-10 19:59:37 +08:00
_p9k__prompt += '${${_p9k__h::=0}+}'
2019-07-19 19:29:54 +08:00
fi
2019-07-23 21:47:25 +08:00
if [ [ $_POWERLEVEL9K_DIR_MAX_LENGTH = = <->( '%' | ) ] ] ; then
2019-10-08 15:46:24 +08:00
local lim =
2019-07-23 21:47:25 +08:00
if [ [ $_POWERLEVEL9K_DIR_MAX_LENGTH [ -1] = = '%' ] ] ; then
2020-02-10 19:59:37 +08:00
lim = " $_p9k__dir_len - $(( 0 .01*$_POWERLEVEL9K_DIR_MAX_LENGTH [ 1 ,-2] )) *_p9k__clm "
2019-07-19 19:29:54 +08:00
else
2020-02-10 19:59:37 +08:00
lim = $(( _p9k__dir_len-_POWERLEVEL9K_DIR_MAX_LENGTH))
2019-07-19 19:29:54 +08:00
( ( lim <= 0) ) && lim =
fi
if [ [ -n $lim ] ] ; then
2020-02-10 19:59:37 +08:00
_p9k__prompt += '${${${$((_p9k__h<_p9k__m+' $lim ')):#1}:-${_p9k__h::=$((_p9k__m+' $lim '))}}+}'
2019-07-19 19:29:54 +08:00
fi
2019-07-18 18:49:32 +08:00
fi
2020-02-10 19:59:37 +08:00
_p9k__prompt += '${${_p9k__d::=$((_p9k__m-_p9k__h))}+}'
_p9k__prompt += '${_p9k__lprompt/\%\{d\%\}*\%\{d\%\}/' $_p9k__dir '}'
_p9k__prompt += '${${_p9k__m::=$((_p9k__d+_p9k__h))}+}'
2019-07-18 18:49:32 +08:00
else
2020-02-10 19:59:37 +08:00
_p9k__prompt += '${_p9k__lprompt}'
2019-07-18 18:49:32 +08:00
fi
2020-02-10 19:59:37 +08:00
( ( _p9k__line_index != num_lines && $# right) ) && _p9k__prompt += $_p9k_line_gap_post [ _p9k__line_index]
2019-07-16 22:19:16 +08:00
fi
2020-02-10 19:59:37 +08:00
if ( ( _p9k__line_index = = num_lines ) ) ; then
2019-11-03 02:03:45 +08:00
[ [ -n $right ] ] && RPROMPT = $_p9k_prompt_prefix_right $right $_p9k_prompt_suffix_right
2020-02-10 19:59:37 +08:00
_p9k__prompt = '${_p9k__' $_p9k__line_index '-' $_p9k__prompt '}' $_p9k_prompt_suffix_left
2019-10-25 19:22:50 +08:00
[ [ $1 = = instant_ ] ] || PROMPT += $_p9k__prompt
2019-10-16 23:36:54 +08:00
else
2019-11-03 02:03:45 +08:00
[ [ -n $right ] ] || _p9k__prompt += $'\n'
2020-02-10 19:59:37 +08:00
PROMPT += '${_p9k__' $_p9k__line_index '-' $_p9k__prompt '}'
2019-07-18 18:21:54 +08:00
fi
2019-07-16 22:19:16 +08:00
done
2019-06-09 15:18:16 +08:00
2020-02-10 19:59:37 +08:00
_p9k__prompt_side =
2019-07-25 00:34:29 +08:00
( ( $# _p9k_cache < _POWERLEVEL9K_MAX_CACHE_SIZE ) ) || _p9k_cache = ( )
2019-10-25 19:22:50 +08:00
( ( $# _p9k__cache_ephemeral < _POWERLEVEL9K_MAX_CACHE_SIZE ) ) || _p9k__cache_ephemeral = ( )
2020-02-04 20:07:05 +08:00
[ [ -n $RPROMPT ] ] || unset RPROMPT
2019-06-01 23:54:53 +08:00
}
2019-10-16 23:36:54 +08:00
_p9k_set_instant_prompt( ) {
local saved_prompt = $PROMPT
local saved_rprompt = $RPROMPT
_p9k_set_prompt instant_
2020-02-10 19:59:37 +08:00
typeset -g _p9k__instant_prompt = $PROMPT $'\x1f' $_p9k__prompt $'\x1f' $RPROMPT
2019-10-16 23:36:54 +08:00
PROMPT = $saved_prompt
RPROMPT = $saved_rprompt
2020-02-04 20:07:05 +08:00
[ [ -n $RPROMPT ] ] || unset RPROMPT
2019-10-16 23:36:54 +08:00
}
2020-01-26 23:54:52 +08:00
typeset -gri __p9k_instant_prompt_version = 18
2019-10-19 20:55:38 +08:00
2019-10-18 22:22:11 +08:00
_p9k_dump_instant_prompt( ) {
local user = ${ (%) :- %n }
local root_dir = ${ __p9k_dump_file : h }
2019-10-19 18:33:39 +08:00
local prompt_dir = ${ root_dir } /p10k-$user
2019-10-18 22:22:11 +08:00
local root_file = $root_dir /p10k-instant-prompt-$user .zsh
2020-01-27 22:04:34 +08:00
local prompt_file = $prompt_dir /prompt-${# _p9k__cwd }
2019-10-18 22:22:11 +08:00
[ [ -d $prompt_dir ] ] || mkdir -p $prompt_dir || return
[ [ -w $root_dir && -w $prompt_dir ] ] || return
2019-10-27 02:43:38 +08:00
if [ [ ! -e $root_file ] ] ; then
2019-10-18 22:22:11 +08:00
local tmp = $root_file .tmp.$$
local -i fd
2020-02-18 22:47:24 +08:00
sysopen -a -m 600 -o creat,trunc -u fd -- $tmp || return
2019-10-18 22:22:11 +08:00
{
2019-10-28 22:19:51 +08:00
[ [ $TERM_PROGRAM = = Hyper ] ] && local hyper = '==' || local hyper = '!='
2019-11-03 23:58:01 +08:00
local -a display_v = ( " ${ _p9k__display_v [@] } " )
local -i i
for ( ( i = 6; i <= $# display_v; i += 2) ) ; do display_v[ i] = show; done
2019-11-04 17:40:03 +08:00
display_v[ 2] = hide
display_v[ 4] = hide
2019-10-18 22:22:11 +08:00
>& $fd print -r -- " () {
2020-01-26 23:54:52 +08:00
$__p9k_intro
2019-10-19 20:55:38 +08:00
( ( ! \$ +__p9k_instant_prompt_disabled ) ) || return
typeset -gi __p9k_instant_prompt_disabled = 1 __p9k_instant_prompt_sourced = $__p9k_instant_prompt_version
2019-10-25 15:19:40 +08:00
[ [ -t 0 && -t 1 && -t 2 && \$ ZSH_VERSION = = ${ (q)ZSH_VERSION } && \$ ZSH_PATCHLEVEL = = ${ (q)ZSH_PATCHLEVEL } &&
2019-10-28 22:19:51 +08:00
\$ TERM_PROGRAM $hyper 'Hyper' && \$ +VTE_VERSION = = $+VTE_VERSION &&
\$ POWERLEVEL9K_DISABLE_INSTANT_PROMPT != 'true' &&
2019-11-29 18:18:30 +08:00
\$ POWERLEVEL9K_INSTANT_PROMPT != 'off' ] ] || { __p9k_instant_prompt_sourced = 0; return 1; }
2019-10-19 20:55:38 +08:00
local -i ZLE_RPROMPT_INDENT = ${ ZLE_RPROMPT_INDENT :- 1 }
local PROMPT_EOL_MARK = ${ (q)PROMPT_EOL_MARK-%B%S%#%s%b }
[ [ -n \$ SSH_CLIENT || -n \$ SSH_TTY || -n \$ SSH_CONNECTION ] ] && local ssh = 1 || local ssh = 0
local cr = \$ '\r' lf = \$ '\n' esc = \$ '\e[' rs = $'\x1e' us = $'\x1f'
local -i height = $_POWERLEVEL9K_INSTANT_PROMPT_COMMAND_LINES
local prompt_dir = ${ (q)prompt_dir }
zmodload zsh/langinfo
if [ [ \$ { langinfo[ CODESET] :-} != ( utf| UTF) ( -| ) 8 ] ] ; then
2020-02-20 15:31:53 +08:00
local lc = ${ (q) ${ ${ ${ __p9k_locale :- ${ (M)LC_CTYPE : #*.(utf|UTF)(-|)8 } } :- ${ (M)LC_ALL : #*.(utf|UTF)(-|)8 } } } :- ${ (M)LANG : #*.(utf|UTF)(-|)8 } }
2019-10-19 20:55:38 +08:00
local LC_ALL = \$ { lc:-\$ { \$ { ( @M) \$ ( locale -a 2>/dev/null) :#*.( utf| UTF) ( -| ) 8} [ 1] :-en_US.UTF-8} }
fi "
2019-10-18 22:22:11 +08:00
>& $fd print -r -- '
2019-10-19 20:55:38 +08:00
zmodload zsh/terminfo
2019-10-27 02:43:38 +08:00
( ( $+terminfo[ cuu] && $+terminfo[ cuf] && $+terminfo[ ed] && $+terminfo[ sc] && $+terminfo[ rc] ) ) || return
2019-10-19 20:55:38 +08:00
local pwd = ${ (%) :- %/ }
local prompt_file = $prompt_dir /prompt-${# pwd }
local key = $pwd :$ssh :${ (%) :- %# }
local content
{ content = " $( <$prompt_file ) " } 2>/dev/null || return
local tail = ${ content ##* $rs $key $us }
[ [ ${# tail } != ${# content } ] ] || return
2019-11-03 23:58:01 +08:00
local P9K_PROMPT = instant
if ( ( ! $+P9K_TTY ) ) ; then '
if ( ( _POWERLEVEL9K_NEW_TTY_MAX_AGE_SECONDS < 0 ) ) ; then
>& $fd print -r -- ' typeset -gx P9K_TTY=new'
else
>& $fd print -r -- '
typeset -gx P9K_TTY = old
zmodload -F zsh/stat b:zstat
zmodload zsh/datetime
local -a stat
if zstat -A stat +ctime -- $TTY 2>/dev/null &&
( ( EPOCHREALTIME - stat[ 1] < '$_POWERLEVEL9K_NEW_TTY_MAX_AGE_SECONDS' ) ) ; then
P9K_TTY = new
fi '
fi
>& $fd print -r -- ' fi
local -i _p9k__empty_line_i = 3 _p9k__ruler_i = 3
2020-01-13 17:21:22 +08:00
local -A _p9k_display_k = ( '${(j: :)${(@q)${(kv)_p9k_display_k}}}' )
2019-11-03 23:58:01 +08:00
local -a _p9k__display_v = ( '${(j: :)${(@q)display_v}}' )
function p10k( ) {
2020-01-26 23:54:52 +08:00
'$__p9k_intro'
2019-11-03 23:58:01 +08:00
[ [ $1 = = display ] ] || return
shift
2020-01-26 23:54:52 +08:00
local -i k dump
local opt prev new pair list name var
2020-01-13 17:21:22 +08:00
while getopts ":ha" opt; do
case $opt in
a) dump = 1; ;
h) return 0; ;
?) return 1; ;
esac
done
if ( ( dump ) ) ; then
reply = ( )
shift $(( OPTIND-1))
( ( ARGC ) ) || set -- "*"
for opt; do
for k in ${ (u@)_p9k_display_k[(I) $opt ] : /(#m)*/ $_p9k_display_k [ $MATCH ] } ; do
reply += ( $_p9k__display_v [ k,k+1] )
done
done
return 0
fi
for opt in " ${ @ : $OPTIND } " ; do
2019-11-04 17:40:03 +08:00
pair = ( ${ (s : = : )opt } )
list = ( ${ (s : , : ) ${ pair [2] } } )
2020-01-13 17:21:22 +08:00
if [ [ ${ (b)pair[1] } = = $pair [ 1] ] ] ; then
local ks = ( $_p9k_display_k [ $pair [ 1] ] )
else
local ks = ( ${ (u@)_p9k_display_k[(I) $pair [1]] : /(#m)*/ $_p9k_display_k [ $MATCH ] } )
fi
for k in $ks ; do
2019-11-04 17:40:03 +08:00
if ( ( $# list = = 1 ) ) ; then
[ [ $_p9k__display_v [ k+1] = = $list [ 1] ] ] && continue
new = $list [ 1]
else
new = ${ list [list[(I) $_p9k__display_v [k+1]]+1] :- $list [1] }
[ [ $_p9k__display_v [ k+1] = = $new ] ] && continue
fi
2019-11-03 23:58:01 +08:00
_p9k__display_v[ k+1] = $new
2019-11-04 17:40:03 +08:00
name = $_p9k__display_v [ k]
2019-11-03 23:58:01 +08:00
if [ [ $name = = ( empty_line| ruler) ] ] ; then
2019-11-04 17:40:03 +08:00
var = _p9k__${ name } _i
2019-11-03 23:58:01 +08:00
[ [ $new = = hide ] ] && typeset -gi $var = 3 || unset $var
2019-11-04 17:40:03 +08:00
elif [ [ $name = = ( #b)(<->)(*) ]]; then
var = _p9k__${ match [1] } ${ ${ ${ ${ match [2]// \/ } /#left/l } /#right/r } /#gap/g }
2019-11-03 23:58:01 +08:00
[ [ $new = = hide ] ] && typeset -g $var = || unset $var
fi
done
done
} '
if ( ( _POWERLEVEL9K_PROMPT_ADD_NEWLINE ) ) ; then
2019-11-04 17:40:03 +08:00
>& $fd print -r -- ' [[ $P9K_TTY == old ]] && { unset _p9k__empty_line_i; _p9k__display_v[2]=print }'
2019-11-03 23:58:01 +08:00
fi
if ( ( _POWERLEVEL9K_SHOW_RULER ) ) ; then
2019-11-04 17:40:03 +08:00
>& $fd print -r -- '[[ $P9K_TTY == old ]] && { unset _p9k__ruler_i; _p9k__display_v[4]=print }'
2019-11-03 23:58:01 +08:00
fi
2020-01-08 23:23:32 +08:00
if ( ( $+functions[ p10k-on-init] ) ) ; then
>& $fd print -r -- '
2020-01-12 02:36:11 +08:00
p10k-on-init( ) { '$functions[p10k-on-init]' } '
fi
if ( ( $+functions[ p10k-on-pre-prompt] ) ) ; then
>& $fd print -r -- '
p10k-on-pre-prompt( ) { '$functions[p10k-on-pre-prompt]' } '
fi
if ( ( $+functions[ p10k-on-post-prompt] ) ) ; then
>& $fd print -r -- '
p10k-on-post-prompt( ) { '$functions[p10k-on-post-prompt]' } '
fi
if ( ( $+functions[ p10k-on-post-widget] ) ) ; then
>& $fd print -r -- '
p10k-on-post-widget( ) { '$functions[p10k-on-post-widget]' } '
fi
if ( ( $+functions[ p10k-on-init] ) ) ; then
>& $fd print -r -- '
p10k-on-init'
fi
2020-01-13 17:21:22 +08:00
local pat idx var
for pat idx var in $_p9k_show_on_command ; do
2020-01-13 00:33:33 +08:00
>& $fd print -r -- "
2020-01-13 17:21:22 +08:00
local $var =
_p9k__display_v[ $idx ] = hide"
2020-01-13 00:33:33 +08:00
done
2020-01-12 02:36:11 +08:00
if ( ( $+functions[ p10k-on-pre-prompt] ) ) ; then
>& $fd print -r -- '
p10k-on-pre-prompt'
fi
if ( ( $+functions[ p10k-on-init] ) ) ; then
>& $fd print -r -- '
2020-01-08 23:23:32 +08:00
unfunction p10k-on-init'
fi
2019-11-03 23:58:01 +08:00
if ( ( $+functions[ p10k-on-pre-prompt] ) ) ; then
>& $fd print -r -- '
unfunction p10k-on-pre-prompt'
2020-01-12 02:36:11 +08:00
fi
if ( ( $+functions[ p10k-on-post-prompt] ) ) ; then
>& $fd print -r -- '
unfunction p10k-on-post-prompt'
fi
if ( ( $+functions[ p10k-on-post-widget] ) ) ; then
>& $fd print -r -- '
unfunction p10k-on-post-widget'
2019-11-03 23:58:01 +08:00
fi
>& $fd print -r -- '
trap "unset -m _p9k__\*; unfunction p10k" EXIT
2019-10-19 20:55:38 +08:00
local -a _p9k_t = ( " ${ (@ps : $us : ) ${ tail %% $rs * } } " ) '
2019-10-28 22:19:51 +08:00
if [ [ $+VTE_VERSION = = 1 || $TERM_PROGRAM = = Hyper ] ] ; then
if [ [ $TERM_PROGRAM = = Hyper ] ] ; then
local bad_lines = 40 bad_columns = 100
else
local bad_lines = 24 bad_columns = 80
fi
2019-10-25 20:43:36 +08:00
>& $fd print -r -- '
2019-10-28 22:19:51 +08:00
if ( ( LINES = = '$bad_lines' && COLUMNS = = '$bad_columns' ) ) ; then
2019-10-27 02:43:38 +08:00
zmodload -F zsh/stat b:zstat
2019-10-21 17:14:33 +08:00
zmodload zsh/datetime
2019-10-27 02:43:38 +08:00
local -a tty_ctime
2019-11-03 23:58:01 +08:00
if ! zstat -A tty_ctime +ctime -- $TTY 2>/dev/null || ( ( tty_ctime[ 1] + 2 > EPOCHREALTIME ) ) ; then
2019-10-27 02:43:38 +08:00
zmodload zsh/datetime
local -F deadline = $(( EPOCHREALTIME+0.025))
local tty_size
while true; do
if ( ( EPOCHREALTIME > deadline ) ) || ! tty_size = " $( /bin/stty size 2>/dev/null) " || [ [ $tty_size != <->" " <-> ] ] ; then
2019-11-03 23:58:01 +08:00
( ( $+_p9k__ruler_i ) ) || local -i _p9k__ruler_i = 1
local _p9k__g = _p9k__'$#_p9k_line_segments_right' r = _p9k__'$#_p9k_line_segments_right' r_frame =
2019-10-27 02:43:38 +08:00
break
fi
2019-10-28 22:19:51 +08:00
if [ [ $tty_size != " ' $bad_lines ' ' $bad_columns ' " ] ] ; then
2019-10-27 02:43:38 +08:00
local lines_columns = ( ${ =tty_size } )
local LINES = $lines_columns [ 1]
local COLUMNS = $lines_columns [ 2]
break
fi
done
fi
2019-10-21 21:07:54 +08:00
fi '
fi
2019-11-03 02:03:45 +08:00
( ( __p9k_ksh_arrays ) ) && >& $fd print -r -- ' setopt ksh_arrays'
( ( __p9k_sh_glob ) ) && >& $fd print -r -- ' setopt sh_glob'
2019-10-21 21:07:54 +08:00
>& $fd print -r -- ' typeset -ga __p9k_used_instant_prompt=("${(@e)_p9k_t[-3,-1]}")'
2019-10-19 20:55:38 +08:00
( ( __p9k_ksh_arrays ) ) && >& $fd print -r -- ' unsetopt ksh_arrays'
( ( __p9k_sh_glob ) ) && >& $fd print -r -- ' unsetopt sh_glob'
>& $fd print -r -- '
2019-11-05 21:08:46 +08:00
( ( height += ${# ${ __p9k_used_instant_prompt [1]//[^ $lf ] } } ) )
2020-02-10 19:59:37 +08:00
local _p9k__ret
2019-10-19 20:55:38 +08:00
function _p9k_prompt_length( ) {
local COLUMNS = 1024
local -i x y = $# 1 m
if ( ( y ) ) ; then
while ( ( ${ ${ (%) :- $1 % $y (l.1.0) } [-1] } ) ) ; do
x = y
( ( y *= 2 ) ) ;
done
local xy
while ( ( y > x + 1 ) ) ; do
m = $(( x + ( y - x) / 2 ))
typeset ${ ${ (%) :- $1 % $m (l.x.y) } [-1] } = $m
done
fi
2020-02-10 19:59:37 +08:00
_p9k__ret = $x
2019-10-19 20:55:38 +08:00
}
2019-10-25 20:43:36 +08:00
local out'
2019-11-03 23:58:01 +08:00
[ [ $+VTE_VERSION = = 1 || $TERM_PROGRAM = = Hyper ] ] && >& $fd print -r -- ' if (( ! $+_p9k__g )); then'
2019-10-25 20:43:36 +08:00
>& $fd print -r -- '
2020-02-10 19:59:37 +08:00
[ [ $PROMPT_EOL_MARK = = "%B%S%#%s%b" ] ] && _p9k__ret = 1 || _p9k_prompt_length $PROMPT_EOL_MARK
local -i fill = $(( COLUMNS > _p9k__ret ? COLUMNS - _p9k__ret : 0 ))
2019-10-27 03:11:39 +08:00
out += " ${ (%) :- %b%k%f%s%u $PROMPT_EOL_MARK ${ (pl. $fill .. .) } $cr %b%k%f%s%u%E } " '
2019-10-28 22:19:51 +08:00
[ [ $+VTE_VERSION = = 1 || $TERM_PROGRAM = = Hyper ] ] && >& $fd print -r -- ' fi'
2019-10-25 20:43:36 +08:00
>& $fd print -r -- '
out += " ${ (pl. $height .. $lf .) } $esc ${ height } A $terminfo [sc] "
2019-10-19 20:55:38 +08:00
out += ${ (%) :- " $__p9k_used_instant_prompt [1] $__p9k_used_instant_prompt [2] " }
if [ [ -n $__p9k_used_instant_prompt [ 3] ] ] ; then
_p9k_prompt_length " $__p9k_used_instant_prompt [2] "
2020-02-10 19:59:37 +08:00
local -i left_len = _p9k__ret
2019-10-19 20:55:38 +08:00
_p9k_prompt_length " $__p9k_used_instant_prompt [3] "
2020-02-10 19:59:37 +08:00
local -i gap = $(( COLUMNS - left_len - _p9k__ret - ZLE_RPROMPT_INDENT))
2019-10-19 20:55:38 +08:00
if ( ( gap >= 40 ) ) ; then
2019-10-27 02:43:38 +08:00
out += " ${ (pl. $gap .. .) } ${ (%) :- ${ __p9k_used_instant_prompt [3] } %b%k%f%s%u } $cr $esc ${ left_len } C "
2019-10-18 22:22:11 +08:00
fi
2019-10-19 20:55:38 +08:00
fi
2019-10-19 21:34:37 +08:00
typeset -g __p9k_instant_prompt_output = ${ TMPDIR :- /tmp } /p10k-instant-prompt-output-${ (%) :- %n } -$$
{ echo -n > $__p9k_instant_prompt_output } || return
2019-10-19 20:55:38 +08:00
print -rn -- " $out " || return
2019-10-22 04:04:37 +08:00
exec { __p9k_fd_0} <& 0 { __p9k_fd_1} >& 1 { __p9k_fd_2} >& 2 0</dev/null 1>$__p9k_instant_prompt_output
2019-10-19 20:55:38 +08:00
exec 2>& 1
typeset -gi __p9k_instant_prompt_active = 1
2019-10-20 16:36:41 +08:00
typeset -g __p9k_instant_prompt_dump_file = ${ XDG_CACHE_HOME :- ~/.cache } /p10k-dump-${ (%) :- %n } .zsh
if source $__p9k_instant_prompt_dump_file 2>/dev/null && ( ( $+functions[ _p9k_preinit] ) ) ; then
_p9k_preinit
fi
2019-10-19 20:55:38 +08:00
function _p9k_instant_prompt_precmd_first( ) {
2020-01-26 23:54:52 +08:00
'$__p9k_intro'
2019-10-19 20:55:38 +08:00
function _p9k_instant_prompt_sched_last( ) {
2019-10-20 15:34:42 +08:00
( ( $+__p9k_instant_prompt_active ) ) || return 0
( ) {
2020-01-26 23:54:52 +08:00
'$__p9k_intro'
2019-10-22 04:04:37 +08:00
exec 0<& $__p9k_fd_0 1>& $__p9k_fd_1 2>& $__p9k_fd_2 { __p9k_fd_0} >& - { __p9k_fd_1} >& - { __p9k_fd_2} >& -
unset __p9k_fd_0 __p9k_fd_1 __p9k_fd_2 __p9k_instant_prompt_active
2019-10-19 20:55:38 +08:00
typeset -gi __p9k_instant_prompt_erased = 1
2019-10-27 02:43:38 +08:00
print -rn -- $terminfo [ rc] ${ (%) :- %b%k%f%s%u } $terminfo [ ed]
2019-10-19 21:34:37 +08:00
if [ [ -s $__p9k_instant_prompt_output ] ] ; then
cat $__p9k_instant_prompt_output 2>/dev/null
2020-02-10 19:59:37 +08:00
local _p9k__ret mark = " ${ PROMPT_EOL_MARK -%B%S%#%s%b } "
2019-10-27 03:06:07 +08:00
_p9k_prompt_length $mark
2020-02-10 19:59:37 +08:00
local -i fill = $(( COLUMNS > _p9k__ret ? COLUMNS - _p9k__ret : 0 ))
2019-10-27 03:11:39 +08:00
echo -nE - " ${ (%) :- %b%k%f%s%u $mark ${ (pl. $fill .. .) } $cr %b%k%f%s%u%E } "
2019-10-19 18:33:39 +08:00
fi
2019-10-19 20:55:38 +08:00
zmodload -F zsh/files b:zf_rm
2019-10-19 21:34:37 +08:00
zf_rm -f -- $__p9k_instant_prompt_output ${ XDG_CACHE_HOME :- $HOME /.cache } /p10k-instant-prompt-${ (%) :- %n } .zsh{ ,.zwc} 2>/dev/null
2019-10-20 15:34:42 +08:00
}
2019-10-27 02:43:38 +08:00
setopt no_local_options prompt_cr prompt_sp
2019-10-18 22:22:11 +08:00
}
2019-10-19 20:55:38 +08:00
zmodload zsh/sched
sched +0 _p9k_instant_prompt_sched_last
precmd_functions = ( ${ (@)precmd_functions : #_p9k_instant_prompt_precmd_first } )
}
precmd_functions = ( _p9k_instant_prompt_precmd_first $precmd_functions )
2020-01-07 17:55:43 +08:00
DISABLE_UPDATE_PROMPT = true
2019-10-20 02:11:47 +08:00
} && unsetopt prompt_cr prompt_sp || true'
2019-10-18 22:22:11 +08:00
} always {
exec { fd} >& -
}
2020-02-18 22:47:24 +08:00
{
( ( ! $? ) ) || return
zf_mv -f $tmp $root_file || return
zcompile -R -- $tmp .zwc $root_file || return
zf_mv -f -- $tmp .zwc $root_file .zwc || return
} always {
( ( $? ) ) && zf_rm -f -- $tmp $tmp .zwc 2>/dev/null
}
2019-10-18 22:22:11 +08:00
fi
local tmp = $prompt_file .tmp.$$
2020-02-18 22:47:24 +08:00
zf_mv -f -- $prompt_file $tmp 2>/dev/null
2019-10-25 19:22:50 +08:00
if [ [ " $( <$prompt_file ) " = = *$'\x1e' $_p9k__instant_prompt_sig $'\x1f' * ] ] 2>/dev/null; then
2019-10-18 22:22:11 +08:00
echo -n >$tmp || return
fi
2020-02-18 22:47:24 +08:00
local -i fd
sysopen -a -m 600 -o creat -u fd -- $tmp || return
{
{
print -rnu $fd -- $'\x1e' $_p9k__instant_prompt_sig $'\x1f' ${ (pj : \x 1f : )_p9k_t } $'\x1f' $_p9k__instant_prompt || return
} always {
exec { fd} >& -
}
zf_mv -f -- $tmp $prompt_file || return
} always {
( ( $? ) ) && zf_rm -f -- $tmp 2>/dev/null
}
2019-10-18 22:22:11 +08:00
}
2019-09-20 17:22:14 +08:00
typeset -gi __p9k_sh_glob
typeset -gi __p9k_ksh_arrays
2019-07-27 18:27:56 +08:00
typeset -gi __p9k_new_status
typeset -ga __p9k_new_pipestatus
2019-07-27 18:09:09 +08:00
_p9k_save_status( ) {
local -i pipe
2019-10-25 19:22:50 +08:00
if ( ( !$+_p9k__line_finished ) ) ; then
2019-07-27 18:09:09 +08:00
: # SIGINT
2019-10-25 19:22:50 +08:00
elif ( ( !$+_p9k__preexec_cmd ) ) ; then
2019-07-27 18:09:09 +08:00
# Empty line, comment or parse error.
#
# This case is handled incorrectly:
#
# true | false
# |
#
# Here status=1 and pipestatus=(0 1). Ideally we should ignore pipestatus but we won't.
#
# This works though (unless pipefail is set):
#
# false | true
# |
#
# We get status=1 and pipestatus=(1 0) and correctly ignore pipestatus.
2019-10-25 19:22:50 +08:00
( ( _p9k__status = = __p9k_new_status ) ) && return
2019-07-27 18:27:56 +08:00
elif ( ( $__p9k_new_pipestatus [ ( I) $__p9k_new_status ] ) ) ; then # just in case
2019-10-25 19:22:50 +08:00
local cmd = ( ${ (z)_p9k__preexec_cmd } )
2019-07-27 18:09:09 +08:00
if [ [ $# cmd != 0 && $cmd [ 1] != '!' && ${ (Q)cmd[1] } != coproc ] ] ; then
local arg
2019-10-25 19:22:50 +08:00
for arg in ${ (z)_p9k__preexec_cmd } ; do
2019-07-27 18:09:09 +08:00
# '()' is for functions, *';' is for complex commands.
if [ [ $arg = = ( '()' | '&&' | '||' | '&' | '&|' | '&!' | *';' ) ] ] ; then
pipe = 0
break
elif [ [ $arg = = *( '|' | '|&' ) * ] ] ; then
pipe = 1
fi
done
fi
fi
2019-10-25 19:22:50 +08:00
_p9k__status = $__p9k_new_status
2019-07-27 18:09:09 +08:00
if ( ( pipe ) ) ; then
2019-10-25 19:22:50 +08:00
_p9k__pipestatus = ( $__p9k_new_pipestatus )
2019-07-27 18:09:09 +08:00
else
2019-10-25 19:22:50 +08:00
_p9k__pipestatus = ( $_p9k__status )
2019-07-27 18:09:09 +08:00
fi
}
2019-10-03 15:42:02 +08:00
function _p9k_dump_state( ) {
2019-10-04 02:14:16 +08:00
local dir = ${ __p9k_dump_file : h }
2020-02-18 22:47:24 +08:00
[ [ -d $dir ] ] || mkdir -p -- $dir || return
2019-10-04 14:55:15 +08:00
[ [ -w $dir ] ] || return
2020-02-18 22:47:24 +08:00
local tmp = $__p9k_dump_file .tmp.$$
2019-10-03 15:42:02 +08:00
local -i fd
2020-02-18 22:47:24 +08:00
sysopen -a -m 600 -o creat,trunc -u fd -- $tmp || return
2019-10-03 15:42:02 +08:00
{
2020-02-18 22:47:24 +08:00
{
typeset -g __p9k_cached_param_pat = $_p9k__param_pat
typeset -g __p9k_cached_param_sig = $_p9k__param_sig
typeset -pm __p9k_cached_param_pat __p9k_cached_param_sig >& $fd || return
unset __p9k_cached_param_pat __p9k_cached_param_sig
( ( $+_p9k_preinit ) ) && { print -r -- $_p9k_preinit >& $fd || return }
print -r -- '_p9k_restore_state_impl() {' >& $fd || return
typeset -pm '_POWERLEVEL9K_*|_p9k_[^_]*|icons|OS|DEFAULT_COLOR|DEFAULT_COLOR_INVERTED' >& $fd || return
print -r -- '}' >& $fd || return
} always {
exec { fd} >& -
}
zf_mv -f -- $tmp $__p9k_dump_file || return
zcompile -R -- $tmp .zwc $__p9k_dump_file || return
zf_mv -f -- $tmp .zwc $__p9k_dump_file .zwc || return
2019-10-03 15:42:02 +08:00
} always {
2020-02-18 22:47:24 +08:00
( ( $? ) ) && zf_rm -f -- $tmp $tmp .zwc 2>/dev/null
2019-10-03 15:42:02 +08:00
}
}
function _p9k_restore_state( ) {
2019-10-04 02:14:16 +08:00
{
2019-10-28 00:16:44 +08:00
[ [ $__p9k_cached_param_pat = = $_p9k__param_pat && $__p9k_cached_param_sig = = $_p9k__param_sig ] ] || return
2019-10-04 02:14:16 +08:00
( ( $+functions[ _p9k_restore_state_impl] ) ) || return
_p9k_restore_state_impl
2020-02-10 19:59:37 +08:00
_p9k__state_restored = 1
2019-10-04 02:14:16 +08:00
} always {
unset __p9k_cached_param_sig
2020-02-10 19:59:37 +08:00
if ( ( !_p9k__state_restored ) ) ; then
2019-10-18 22:22:11 +08:00
if ( ( $+functions[ _p9k_preinit] ) ) ; then
unfunction _p9k_preinit
( ( $+functions[ gitstatus_stop] ) ) && gitstatus_stop POWERLEVEL9K
fi
local user = ${ (%) :- %n }
local root_dir = ${ __p9k_dump_file : h }
2019-10-19 18:33:39 +08:00
zf_rm -f -- $root_dir /p10k-instant-prompt-$user .zsh{ ,.zwc} ${ root_dir } /p10k-$user /prompt-*( N) 2>/dev/null
2019-10-04 02:14:16 +08:00
fi
}
2019-10-03 15:42:02 +08:00
}
2019-10-18 22:22:11 +08:00
function _p9k_clear_instant_prompt( ) {
2019-10-29 22:54:30 +08:00
if ( ( $+__p9k_fd_0 ) ) ; then
exec 0<& $__p9k_fd_0 { __p9k_fd_0} >& -
unset __p9k_fd_0
fi
exec 1>& $__p9k_fd_1 2>& $__p9k_fd_2 { __p9k_fd_1} >& - { __p9k_fd_2} >& -
unset __p9k_fd_1 __p9k_fd_2
2019-12-14 21:57:30 +08:00
if ( ( _p9k__can_hide_cursor ) ) ; then
echoti civis
_p9k__cursor_hidden = 1
fi
2019-10-29 22:54:30 +08:00
if [ [ -s $__p9k_instant_prompt_output ] ] ; then
{
local content
[ [ $_POWERLEVEL9K_INSTANT_PROMPT = = verbose ] ] && content = " $( <$__p9k_instant_prompt_output ) "
local mark = " ${ PROMPT_EOL_MARK -%B%S%#%s%b } "
_p9k_prompt_length $mark
2020-02-10 19:59:37 +08:00
local -i fill = $(( COLUMNS > _p9k__ret ? COLUMNS - _p9k__ret : 0 ))
2019-11-08 21:55:13 +08:00
local cr = $'\r'
2019-10-29 22:54:30 +08:00
local sp = " ${ (%) :- %b%k%f%s%u $mark ${ (pl. $fill .. .) } $cr %b%k%f%s%u%E } "
2019-10-27 02:43:38 +08:00
print -rn -- $terminfo [ rc] ${ (%) :- %b%k%f%s%u } $terminfo [ ed]
2020-01-07 17:52:06 +08:00
local unexpected = ${ (S)content// $'\e' *( $'\a' | $'\e\\' ) }
if [ [ -n $unexpected ] ] ; then
2020-01-07 17:34:56 +08:00
local omz1 = '[Oh My Zsh] Would you like to update? [Y/n]: '
local omz2 = 'Updating Oh My Zsh'
2020-01-07 17:52:06 +08:00
local omz3 = 'https://shop.planetargon.com/collections/oh-my-zsh'
if [ [ -n ${ ${ unexpected / $omz1 } / $omz2 * $omz3 ( $'\n' |) } ] ] ; then
2020-01-07 17:34:56 +08:00
echo -E - ""
echo -E - " ${ (%) :- [%3FWARNING%f] : Console output during zsh initialization detected. } "
echo -E - ""
echo -E - " ${ (%) :- When using Powerlevel10k with instant prompt, console output during zsh } "
echo -E - " ${ (%) :- initialization may indicate issues. } "
echo -E - ""
echo -E - " ${ (%) :- You can : } "
echo -E - ""
echo -E - " ${ (%) :- - %BRecommended%b : Change %B $__p9k_zshrc_u %b so that it does not perform console I/O } "
echo -E - " ${ (%) :- after the instant prompt preamble. See the link below for details. } "
echo -E - ""
echo -E - " ${ (%) :- * You %Bwill not%b see this error message again. } "
echo -E - " ${ (%) :- * Zsh will start %Bquickly%b and prompt will update %Bsmoothly%b. } "
echo -E - ""
echo -E - " ${ (%) :- - Suppress this warning either by running %Bp10k configure%b or by manually } "
echo -E - " ${ (%) :- defining the following parameter : } "
echo -E - ""
echo -E - " ${ (%) :- %3Ftypeset%f -g POWERLEVEL9K_INSTANT_PROMPT=quiet } "
echo -E - ""
echo -E - " ${ (%) :- * You %Bwill not%b see this error message again. } "
echo -E - " ${ (%) :- * Zsh will start %Bquickly%b but prompt will %Bjump down%b after initialization. } "
echo -E - ""
echo -E - " ${ (%) :- - Disable instant prompt either by running %Bp10k configure%b or by manually } "
echo -E - " ${ (%) :- defining the following parameter : } "
echo -E - ""
echo -E - " ${ (%) :- %3Ftypeset%f -g POWERLEVEL9K_INSTANT_PROMPT=off } "
echo -E - ""
echo -E - " ${ (%) :- * You %Bwill not%b see this error message again. } "
echo -E - " ${ (%) :- * Zsh will start %Bslowly%b. } "
echo -E - ""
echo -E - " ${ (%) :- - Do nothing. } "
echo -E - ""
echo -E - " ${ (%) :- * You %Bwill%b see this error message every time you start zsh. } "
echo -E - " ${ (%) :- * Zsh will start %Bquickly%b but prompt will %Bjump down%b after initialization. } "
echo -E - ""
echo -E - " ${ (%) :- For details, see : } "
echo - " ${ (%) :- \e ]8;;https : //github.com/romkatv/powerlevel10k/blob/master/README.md#instant-prompt \a https : //github.com/romkatv/powerlevel10k/blob/master/README.md#instant-prompt \e ]8;; \a } "
echo -E - ""
echo - " ${ (%) :- %3F-- console output produced during zsh initialization follows --%f } "
echo -E - ""
fi
2019-10-29 22:54:30 +08:00
fi
cat $__p9k_instant_prompt_output
echo -nE - $sp
zf_rm -f -- $__p9k_instant_prompt_output
} 2>/dev/null
else
zf_rm -f -- $__p9k_instant_prompt_output 2>/dev/null
print -rn -- $terminfo [ rc] ${ (%) :- %b%k%f%s%u } $terminfo [ ed]
fi
prompt_opts = ( percent subst sp cr)
2020-02-15 16:25:44 +08:00
if [ [ $_POWERLEVEL9K_DISABLE_INSTANT_PROMPT = = 0 && $__p9k_instant_prompt_active = = 2 ] ] ; then
2019-10-29 22:54:30 +08:00
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- [%1FERROR%f] : When using Powerlevel10k with instant prompt, %Bprompt_cr%b must be unset. } "
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- You can : } "
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- - %BRecommended%b : call %Bp10k finalize%b at the end of %B $__p9k_zshrc_u %b. } "
>& 2 echo -E - " ${ (%) :- You can do this by running the following command : } "
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- %2Fecho%f %3F '(( ! \${+functions[p10k]\} )) || p10k finalize' %f >>! $__p9k_zshrc_u } "
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- * You %Bwill not%b see this error message again. } "
>& 2 echo -E - " ${ (%) :- * Zsh will start %Bquickly%b and %Bwithout%b prompt flickering. } "
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- - Find where %Bprompt_cr%b option gets sets in your zsh configs and stop setting it. } "
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- * You %Bwill not%b see this error message again. } "
>& 2 echo -E - " ${ (%) :- * Zsh will start %Bquickly%b and %Bwithout%b prompt flickering. } "
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- - Disable instant prompt either by running %Bp10k configure%b or by manually } "
>& 2 echo -E - " ${ (%) :- defining the following parameter : } "
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- %3Ftypeset%f -g POWERLEVEL9K_INSTANT_PROMPT=off } "
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- * You %Bwill not%b see this error message again. } "
>& 2 echo -E - " ${ (%) :- * Zsh will start %Bslowly%b. } "
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- - Do nothing. } "
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- * You %Bwill%b see this error message every time you start zsh. } "
>& 2 echo -E - " ${ (%) :- * Zsh will start %Bquckly%b but %Bwith%b prompt flickering. } "
>& 2 echo -E - ""
fi
}
2020-02-10 21:10:18 +08:00
function _p9k_do_dump( ) {
eval " $__p9k_intro "
zle -F $1
exec { 1} >& -
if ! ( ( _p9k__instant_prompt_disabled || $+_p9k_dumped_instant_prompt_sigs[ $_p9k__instant_prompt_sig ] ) ) ; then
_p9k_set_instant_prompt
_p9k_dump_instant_prompt
_p9k_dumped_instant_prompt_sigs[ $_p9k__instant_prompt_sig ] = 1
fi
_p9k_dump_state
_p9k__state_dump_scheduled = 0
_p9k__state_dump_fd = 0
}
2019-10-29 22:54:30 +08:00
function _p9k_maybe_dump( ) {
( ( __p9k_dumps_enabled ) ) || return 0
2020-01-27 22:04:34 +08:00
_p9k__instant_prompt_sig = $_p9k__cwd :$P9K_SSH :${ (%) :- %# }
2019-10-29 22:54:30 +08:00
2020-02-10 21:10:18 +08:00
if ( ( ! _p9k__state_dump_fd ) ) ; then
2019-10-29 22:54:30 +08:00
if ( ( _p9k__prompt_idx = = 1 ) ) then
( ( _p9k__instant_prompt_disabled ) ) || _p9k_set_instant_prompt
2020-02-10 19:59:37 +08:00
if ( ( !_p9k__state_restored ) ) ; then
2019-10-29 22:54:30 +08:00
if ( ( !_p9k__instant_prompt_disabled ) ) ; then
_p9k_dump_instant_prompt
_p9k_dumped_instant_prompt_sigs[ $_p9k__instant_prompt_sig ] = 1
fi
_p9k_dump_state
_p9k__state_dump_scheduled = 0
2020-02-10 21:10:18 +08:00
elif ( ( ! _p9k__instant_prompt_disabled ) ) ; then
2019-10-29 22:54:30 +08:00
_p9k_dump_instant_prompt
if ( ( ! $+_p9k_dumped_instant_prompt_sigs[ $_p9k__instant_prompt_sig ] ) ) ; then
2020-02-10 17:28:59 +08:00
_p9k_dumped_instant_prompt_sigs[ $_p9k__instant_prompt_sig ] = 1
2019-10-29 22:54:30 +08:00
_p9k_dump_state
_p9k__state_dump_scheduled = 0
fi
fi
2020-02-10 21:10:18 +08:00
elif ( ( _p9k__state_dump_scheduled ||
! ( _p9k__instant_prompt_disabled || $+_p9k_dumped_instant_prompt_sigs[ $_p9k__instant_prompt_sig ] ) ) ) ; then
exec { _p9k__state_dump_fd} </dev/null
zle -F $_p9k__state_dump_fd _p9k_do_dump
2019-10-20 16:15:35 +08:00
fi
2019-10-29 22:54:30 +08:00
fi
}
function _p9k_on_expand( ) {
2020-02-15 16:25:44 +08:00
( ( _p9k__expanded && ! ${ +__p9k_instant_prompt_active } ) ) && return
2019-10-29 22:54:30 +08:00
2020-02-15 16:25:44 +08:00
eval " $__p9k_intro "
2019-10-29 22:54:30 +08:00
2020-02-15 16:25:44 +08:00
if ( ( ! _p9k__expanded ) ) ; then
2019-10-29 22:54:30 +08:00
_p9k_maybe_dump
2019-11-03 20:36:49 +08:00
if ( ( ! $+P9K_TTY ) ) ; then
2019-11-03 23:58:01 +08:00
typeset -gx P9K_TTY = old
2019-11-03 20:36:49 +08:00
if ( ( _POWERLEVEL9K_NEW_TTY_MAX_AGE_SECONDS < 0 ) ) ; then
P9K_TTY = new
else
local -a stat
if zstat -A stat +ctime -- $TTY 2>/dev/null &&
( ( EPOCHREALTIME - stat[ 1] < _POWERLEVEL9K_NEW_TTY_MAX_AGE_SECONDS ) ) ; then
P9K_TTY = new
fi
fi
fi
__p9k_reset_state = 1
if ( ( _POWERLEVEL9K_PROMPT_ADD_NEWLINE ) ) ; then
if [ [ $P9K_TTY = = new ] ] ; then
2019-11-06 16:21:12 +08:00
_p9k__empty_line_i = 3
2019-11-04 17:40:03 +08:00
_p9k__display_v[ 2] = hide
2020-01-13 15:54:29 +08:00
elif [ [ -z $_p9k_transient_prompt && $+functions[ p10k-on-post-prompt] = = 0 ] ] ; then
2019-11-06 16:21:12 +08:00
_p9k__empty_line_i = 3
2019-11-04 17:40:03 +08:00
_p9k__display_v[ 2] = print
2019-11-06 16:21:12 +08:00
else
unset _p9k__empty_line_i
_p9k__display_v[ 2] = show
2019-11-03 20:36:49 +08:00
fi
fi
if ( ( _POWERLEVEL9K_SHOW_RULER ) ) ; then
if [ [ $P9K_TTY = = new ] ] ; then
2019-11-06 16:21:12 +08:00
_p9k__ruler_i = 3
2019-11-04 17:40:03 +08:00
_p9k__display_v[ 4] = hide
2020-01-13 15:54:29 +08:00
elif [ [ -z $_p9k_transient_prompt && $+functions[ p10k-on-post-prompt] = = 0 ] ] ; then
2019-11-06 16:21:12 +08:00
_p9k__ruler_i = 3
2019-11-04 17:40:03 +08:00
_p9k__display_v[ 4] = print
2019-11-06 16:21:12 +08:00
else
unset _p9k__ruler_i
_p9k__display_v[ 4] = show
2019-11-03 20:36:49 +08:00
fi
fi
2020-02-15 16:25:44 +08:00
[ [ -z $_p9k__last_tty ] ] && _p9k_wrap_widgets
fi
if ( ( $+__p9k_instant_prompt_active ) ) ; then
_p9k_clear_instant_prompt
unset __p9k_instant_prompt_active
fi
if ( ( ! _p9k__expanded ) ) ; then
_p9k__expanded = 1
[ [ -z $_p9k__last_tty && $+functions[ p10k-on-init] = = 1 ] ] && p10k-on-init
2019-11-03 23:58:01 +08:00
2020-01-13 17:21:22 +08:00
local pat idx var
for pat idx var in $_p9k_show_on_command ; do
_p9k_display_segment $idx $var hide
2020-01-13 00:33:33 +08:00
done
2020-02-15 16:25:44 +08:00
2020-01-09 03:16:52 +08:00
( ( $+functions[ p10k-on-pre-prompt] ) ) && p10k-on-pre-prompt
2019-11-03 20:36:49 +08:00
2020-02-17 00:16:12 +08:00
if zle; then
local -a P9K_COMMANDS = ( $_p9k__last_commands )
local pat idx var
for pat idx var in $_p9k_show_on_command ; do
if ( ( $P9K_COMMANDS [ ( I) $pat ] ) ) ; then
_p9k_display_segment $idx $var show
else
_p9k_display_segment $idx $var hide
fi
done
2020-02-17 00:23:17 +08:00
if ( ( $+functions[ p10k-on-post-widget] ) ) ; then
local -h WIDGET
unset WIDGET
p10k-on-post-widget
fi
2020-02-17 00:16:12 +08:00
else
2020-01-13 15:50:50 +08:00
if [ [ $_p9k__display_v [ 2] = = print && -n $_p9k_t [ _p9k_empty_line_idx] ] ] ; then
print -rnP -- '%b%k%f%E' $_p9k_t [ _p9k_empty_line_idx]
fi
2020-01-02 23:17:56 +08:00
if [ [ $_p9k__display_v [ 4] = = print ] ] ; then
( ) {
2020-01-13 15:50:50 +08:00
local ruler = $_p9k_t [ _p9k_ruler_idx]
2020-02-10 19:59:37 +08:00
local -i _p9k__clm = COLUMNS _p9k__ind = ${ ZLE_RPROMPT_INDENT :- 1 }
2020-01-02 23:17:56 +08:00
( ( __p9k_ksh_arrays ) ) && setopt ksh_arrays
( ( __p9k_sh_glob ) ) && setopt sh_glob
2020-01-27 23:06:41 +08:00
setopt prompt_subst
2020-01-13 15:50:50 +08:00
print -rnP -- '%b%k%f%E' $ruler
2020-01-02 23:17:56 +08:00
}
fi
2019-10-20 16:15:35 +08:00
fi
2020-02-17 00:16:12 +08:00
__p9k_reset_state = 0
_p9k__last_tty = $P9K_TTY
P9K_TTY = old
2019-10-29 22:54:30 +08:00
fi
2019-10-18 22:22:11 +08:00
}
2019-10-29 22:54:30 +08:00
functions -M _p9k_on_expand
2019-10-18 22:22:11 +08:00
2019-09-20 17:22:14 +08:00
_p9k_precmd_impl( ) {
2020-02-02 05:03:42 +08:00
eval " $__p9k_intro "
2019-09-20 17:22:14 +08:00
( ( __p9k_enabled ) ) || return
2019-07-25 00:34:29 +08:00
2020-02-20 15:31:53 +08:00
if ( ( ! $+__p9k_locale ) ) ; then
2020-02-05 19:50:51 +08:00
_p9k_init_locale
2020-02-20 15:31:53 +08:00
[ [ -z $__p9k_locale ] ] || local LC_ALL = $__p9k_locale
2020-02-05 19:50:51 +08:00
fi
2019-10-25 19:22:50 +08:00
if ! zle || [ [ -z $_p9k__param_sig ] ] ; then
2019-09-20 18:09:47 +08:00
if zle; then
__p9k_new_status = 0
__p9k_new_pipestatus = ( 0)
2020-02-16 23:38:19 +08:00
else
2020-01-02 23:17:56 +08:00
_p9k__must_restore_prompt = 0
2019-09-20 18:09:47 +08:00
fi
2020-02-10 19:59:37 +08:00
if ( ( $+_p9k__real_zle_rprompt_indent ) ) ; then
if [ [ -n $_p9k__real_zle_rprompt_indent ] ] ; then
ZLE_RPROMPT_INDENT = $_p9k__real_zle_rprompt_indent
2019-09-12 17:35:24 +08:00
else
unset ZLE_RPROMPT_INDENT
fi
2020-02-10 19:59:37 +08:00
unset _p9k__real_zle_rprompt_indent
2019-07-25 01:11:43 +08:00
fi
2019-09-12 17:35:24 +08:00
if _p9k_must_init; then
2019-10-27 02:43:38 +08:00
local -i instant_prompt_disabled
2019-09-12 17:35:24 +08:00
if ( ( !__p9k_configured ) ) ; then
__p9k_configured = 1
2019-10-27 02:43:38 +08:00
if [ [ " ${ parameters [(I)POWERLEVEL9K_*] } " = = ( POWERLEVEL9K_MODE| ) ] ] ; then
_p9k_can_configure -q
case $? in
0)
(
2019-11-29 17:55:30 +08:00
source " $__p9k_root_dir " /internal/wizard.zsh
2019-10-27 02:43:38 +08:00
)
if ( ( $? ) ) ; then
instant_prompt_disabled = 1
else
source " $__p9k_cfg_path "
2019-11-21 16:24:29 +08:00
_p9k__force_must_init = 1
_p9k_must_init
2019-10-27 02:43:38 +08:00
fi
; ;
2)
zf_rm -f -- ${ __p9k_dump_file : h } /p10k-instant-prompt-${ (%) :- %n } .zsh{ ,.zwc} 2>/dev/null
instant_prompt_disabled = 1
; ;
esac
2019-07-30 21:11:58 +08:00
fi
fi
2019-09-12 17:35:24 +08:00
_p9k_init
2019-10-27 02:43:38 +08:00
_p9k__instant_prompt_disabled = $(( _POWERLEVEL9K_DISABLE_INSTANT_PROMPT | | instant_prompt_disabled))
2019-07-30 21:11:58 +08:00
fi
2019-09-12 17:35:24 +08:00
2019-10-25 19:22:50 +08:00
if ( ( _p9k__timer_start ) ) ; then
typeset -gF P9K_COMMAND_DURATION_SECONDS = $(( EPOCHREALTIME - _p9k__timer_start))
2019-09-12 17:35:24 +08:00
else
unset P9K_COMMAND_DURATION_SECONDS
fi
_p9k_save_status
2019-10-25 19:22:50 +08:00
_p9k__timer_start = 0
_p9k__region_active = 0
2019-09-12 17:35:24 +08:00
2020-01-20 16:57:03 +08:00
unset _p9k__line_finished _p9k__preexec_cmd
2019-10-25 19:22:50 +08:00
_p9k__keymap = main
_p9k__zle_state = insert
2019-10-03 20:21:58 +08:00
2019-10-25 19:22:50 +08:00
( ( ++_p9k__prompt_idx ) )
2019-07-30 21:11:58 +08:00
fi
2019-06-01 23:54:53 +08:00
2020-01-27 22:04:34 +08:00
_p9k_fetch_cwd
2020-01-18 22:41:43 +08:00
2020-01-26 23:54:52 +08:00
local f_compute
for f_compute in " ${ _p9k__async_segments_compute [@] } " ; do
_p9k_worker_invoke ${ f_compute %% * } ${ (e)f_compute }
done
2020-02-17 00:16:12 +08:00
_p9k__expanded = 0
2020-02-10 19:59:37 +08:00
_p9k__refresh_reason = precmd
2019-09-20 17:22:14 +08:00
_p9k_set_prompt
2020-02-10 19:59:37 +08:00
_p9k__refresh_reason = ''
2019-10-03 15:42:02 +08:00
2020-01-20 16:57:03 +08:00
if [ [ $precmd_functions [ 1] != _p9k_do_nothing && $precmd_functions [ ( I) _p9k_do_nothing] != 0 ] ] ; then
precmd_functions = ( _p9k_do_nothing ${ (@)precmd_functions : #_p9k_do_nothing } )
fi
2019-10-28 03:31:35 +08:00
if [ [ $precmd_functions [ -1] != _p9k_precmd && $precmd_functions [ ( I) _p9k_precmd] != 0 ] ] ; then
precmd_functions = ( ${ (@)precmd_functions : #_p9k_precmd } _p9k_precmd)
fi
2020-01-20 16:57:03 +08:00
if [ [ $preexec_functions [ 1] != _p9k_preexec1 && $preexec_functions [ ( I) _p9k_preexec1] != 0 ] ] ; then
preexec_functions = ( _p9k_preexec1 ${ (@)preexec_functions : #_p9k_preexec1 } )
fi
if [ [ $preexec_functions [ -1] != _p9k_preexec2 && $preexec_functions [ ( I) _p9k_preexec2] != 0 ] ] ; then
preexec_functions = ( ${ (@)preexec_functions : #_p9k_preexec2 } _p9k_preexec2)
2019-11-12 18:03:49 +08:00
fi
2020-01-25 19:51:46 +08:00
_p9k_worker_receive
2019-09-20 17:22:14 +08:00
}
2019-11-05 00:06:42 +08:00
_p9k_trapint( ) {
if ( ( __p9k_enabled ) ) ; then
2020-02-02 05:03:42 +08:00
eval " $__p9k_intro "
2020-01-09 03:16:52 +08:00
zle && _p9k_on_widget_zle-line-finish int
2019-11-05 00:06:42 +08:00
fi
2020-01-02 23:17:56 +08:00
return 0
2019-11-05 00:06:42 +08:00
}
2019-09-20 17:22:14 +08:00
_p9k_precmd( ) {
__p9k_new_status = $?
__p9k_new_pipestatus = ( $pipestatus )
[ [ -o ksh_arrays ] ] && __p9k_ksh_arrays = 1 || __p9k_ksh_arrays = 0
[ [ -o sh_glob ] ] && __p9k_sh_glob = 1 || __p9k_sh_glob = 0
2019-11-03 21:29:11 +08:00
_p9k_precmd_impl
2020-02-15 16:25:44 +08:00
( ( ${ +functions[TRAPINT] } ) ) || trap '_p9k_trapint; return 130' INT
[ [ ${ +__p9k_instant_prompt_active } = = 0 || -o no_prompt_cr ] ] || __p9k_instant_prompt_active = 2
setopt no_local_options no_prompt_bang prompt_percent prompt_subst prompt_cr prompt_sp
2019-06-01 23:54:53 +08:00
}
2019-09-20 17:22:14 +08:00
function _p9k_reset_prompt( ) {
2019-11-06 16:32:54 +08:00
if zle && [ [ -z $_p9k__line_finished ] ] ; then
2020-01-26 23:54:52 +08:00
setopt prompt_subst
2019-11-04 16:07:06 +08:00
( ( __p9k_ksh_arrays ) ) && setopt ksh_arrays
( ( __p9k_sh_glob ) ) && setopt sh_glob
2019-12-14 21:57:30 +08:00
( ( _p9k__can_hide_cursor ) ) && echoti civis
2019-11-04 16:07:06 +08:00
zle .reset-prompt
zle -R
2019-12-14 21:57:30 +08:00
( ( _p9k__can_hide_cursor ) ) && echoti cnorm
2019-11-04 16:07:06 +08:00
fi
2019-09-18 19:38:31 +08:00
}
2019-06-01 23:54:53 +08:00
# Does ZSH have a certain off-by-one bug that triggers when PROMPT overflows to a new line?
#
# Bug: https://github.com/zsh-users/zsh/commit/d8d9fee137a5aa2cf9bf8314b06895bfc2a05518.
# ZSH_PATCHLEVEL=zsh-5.4.2-159-gd8d9fee13. Released in 5.5.
#
# Fix: https://github.com/zsh-users/zsh/commit/64d13738357c9b9c212adbe17f271716abbcf6ea.
# ZSH_PATCHLEVEL=zsh-5.7.1-50-g64d137383.
#
# Test: PROMPT="${(pl:$((COLUMNS))::-:)}<%1(l.%2(l.FAIL.PASS).FAIL)> " zsh -dfis <<<exit
# Workaround: PROMPT="${(pl:$((COLUMNS))::-:)}%{%G%}<%1(l.%2(l.FAIL.PASS).FAIL)> " zsh -dfis <<<exit
function _p9k_prompt_overflow_bug( ) {
[ [ $ZSH_PATCHLEVEL = ~ '^zsh-5\.4\.2-([0-9]+)-' ] ] && return $(( match[ 1 ] < 159 ))
[ [ $ZSH_PATCHLEVEL = ~ '^zsh-5\.7\.1-([0-9]+)-' ] ] && return $(( match[ 1 ] >= 50 ))
is-at-least 5.5 && ! is-at-least 5.7.2
}
2020-02-05 19:50:51 +08:00
function _p9k_init_locale( ) {
zmodload zsh/langinfo
if [ [ ${ langinfo [CODESET] :- } != ( utf| UTF) ( -| ) 8 ] ] ; then
2020-02-20 15:31:53 +08:00
typeset -g __p9k_locale = ${ ${ (@M) $( locale -a) : #*.(utf|UTF)(-|)8 } [1] :- en_US .UTF-8 }
2020-02-05 19:50:51 +08:00
else
2020-02-20 15:31:53 +08:00
typeset -g __p9k_locale =
2020-02-05 19:50:51 +08:00
fi
}
2019-10-28 00:16:44 +08:00
typeset -g _p9k__param_pat
typeset -g _p9k__param_sig
2019-07-24 20:34:26 +08:00
_p9k_init_vars( ) {
2020-02-06 23:10:53 +08:00
typeset -ga _p9k_asdf_meta_files
typeset -ga _p9k_asdf_meta_non_files
typeset -g _p9k_asdf_meta_sig
# example: (ruby lua chubaka)
typeset -ga _p9k_asdf_plugins
# example: (.ruby-version "ruby 1 chubaka 0")
#
# - "1" means parse-legacy-file is present
# - "chubaka" is another plugin that claims to be able to parse .ruby-version
typeset -gA _p9k_asdf_file_info
# dir => mtime ':' ${(pj:\0:)files}
typeset -gA _p9k__asdf_dir2files
2020-02-08 23:47:58 +08:00
# :file => mtime ':' ${(pj:\0:)tool_versions}
# plugin:file => mtime ':' version
2020-02-06 23:10:53 +08:00
typeset -gA _p9k_asdf_file2versions
2020-01-28 02:23:56 +08:00
# filepath => mtime ':' word
typeset -gA _p9k__read_word_cache
2020-01-28 16:59:54 +08:00
# filepath:prefix => mtime ':' versions
typeset -gA _p9k__read_pyenv_like_version_file_cache
2020-01-28 02:23:56 +08:00
# _p9k__parent_dirs and _p9k__parent_mtimes are parallel arrays. They are updated
# together with _p9k__cwd. _p9k__parent_mtimes[i] is mtime for _p9k__parent_dirs[i].
#
# When _p9k__cwd is / or ~, both arrays are empty. When _p9k__cwd is ~/foo/bar,
# _p9k__parent_dirs is (/home/user/foo/bar /home/user/foo). When _p9k__cwd is
# /foo/bar, it's (/foo/bar /foo).
#
# $_p9k__parent_mtimes_i[i] == "$i:$_p9k__parent_mtimes[i]"
# $_p9k__parent_mtimes_s == "$_p9k__parent_mtimes_i".
typeset -ga _p9k__parent_dirs
typeset -ga _p9k__parent_mtimes
typeset -ga _p9k__parent_mtimes_i
typeset -g _p9k__parent_mtimes_s
2020-01-28 17:10:42 +08:00
typeset -g _p9k__cwd
typeset -g _p9k__cwd_a
2020-01-28 02:23:56 +08:00
# dir/pattern => dir mtime ':' num_matches
typeset -gA _p9k__glob_cache
# dir/pattern => space-separated parent dir mtimes ' :' the first matching parent dir
# Note: ' :' is indeed the delimiter.
typeset -gA _p9k__upsearch_cache
2020-02-10 19:59:37 +08:00
typeset -g _p9k_timewarrior_dir
2020-01-28 02:23:56 +08:00
typeset -gi _p9k_timewarrior_dir_mtime
typeset -gi _p9k_timewarrior_file_mtime
typeset -g _p9k_timewarrior_file_name
2020-02-17 05:23:57 +08:00
typeset -gA _p9k__prompt_char_saved
2020-01-28 02:23:56 +08:00
typeset -g _p9k__worker_pid
typeset -g _p9k__worker_req_fd
typeset -g _p9k__worker_resp_fd
typeset -g _p9k__worker_shell_pid
typeset -g _p9k__worker_file_prefix
typeset -gA _p9k__worker_request_map
2020-01-26 01:04:06 +08:00
typeset -ga _p9k__segment_cond_left
typeset -ga _p9k__segment_cond_right
typeset -ga _p9k__segment_val_left
typeset -ga _p9k__segment_val_right
2020-01-13 00:33:33 +08:00
typeset -ga _p9k_show_on_command
2020-01-12 02:02:54 +08:00
typeset -g _p9k__last_buffer
typeset -ga _p9k__last_commands
2020-01-02 23:17:56 +08:00
typeset -g _p9k__last_tty
typeset -gi _p9k__must_restore_prompt
typeset -gi _p9k__restore_prompt_fd
2019-12-14 21:57:30 +08:00
typeset -gi _p9k__can_hide_cursor = $(( $+ terminfo[ civis] & & $+ terminfo[ cnorm] ))
typeset -gi _p9k__cursor_hidden
2019-10-27 02:43:38 +08:00
typeset -gi _p9k__instant_prompt_disabled
2020-02-10 19:59:37 +08:00
typeset -gi _p9k__non_hermetic_expansion
typeset -g _p9k__time
typeset -g _p9k__date
2019-10-18 22:22:11 +08:00
typeset -gA _p9k_dumped_instant_prompt_sigs
2019-10-25 19:22:50 +08:00
typeset -g _p9k__instant_prompt_sig
2020-02-10 19:59:37 +08:00
typeset -g _p9k__instant_prompt
2019-10-25 19:22:50 +08:00
typeset -gi _p9k__state_dump_scheduled
2020-02-10 21:10:18 +08:00
typeset -gi _p9k__state_dump_fd
2019-10-25 19:22:50 +08:00
typeset -gi _p9k__prompt_idx
2020-02-10 19:59:37 +08:00
typeset -gi _p9k__state_restored
2019-07-27 18:09:09 +08:00
typeset -gi _p9k_reset_on_line_finish
2019-10-25 19:22:50 +08:00
typeset -gF _p9k__timer_start
typeset -gi _p9k__status
typeset -ga _p9k__pipestatus
2020-02-10 19:59:37 +08:00
typeset -g _p9k__ret
typeset -g _p9k__cache_key
typeset -ga _p9k__cache_val
2019-10-25 19:22:50 +08:00
typeset -g _p9k__cache_stat_meta
typeset -g _p9k__cache_stat_fprint
typeset -g _p9k__cache_fprint_key
2019-07-24 20:34:26 +08:00
typeset -gA _p9k_cache
2019-10-25 19:22:50 +08:00
typeset -gA _p9k__cache_ephemeral
2019-07-24 20:34:26 +08:00
typeset -ga _p9k_t
2020-02-10 19:59:37 +08:00
typeset -g _p9k__n
typeset -gi _p9k__i
typeset -g _p9k__bg
2019-07-25 00:34:29 +08:00
typeset -ga _p9k_left_join
typeset -ga _p9k_right_join
2019-10-25 19:22:50 +08:00
typeset -g _p9k__public_ip
2020-02-10 19:59:37 +08:00
typeset -g _p9k__todo_file
2019-11-11 18:51:15 +08:00
typeset -g _p9k__git_dir
2019-07-24 20:34:26 +08:00
# git workdir => 1 if gitstatus is slow on it, 0 if it's fast.
typeset -gA _p9k_git_slow
2019-10-09 22:24:23 +08:00
# git workdir => the last state we've seen for it
2019-10-25 19:22:50 +08:00
typeset -gA _p9k__gitstatus_last
typeset -gi _p9k__gitstatus_disabled
typeset -gF _p9k__gitstatus_start_time
typeset -g _p9k__prompt
2020-02-10 19:59:37 +08:00
typeset -g _p9k__rprompt
typeset -g _p9k__lprompt
typeset -g _p9k__prompt_side
typeset -g _p9k__segment_name
typeset -gi _p9k__segment_index
typeset -gi _p9k__line_index
typeset -g _p9k__refresh_reason
2019-10-25 19:22:50 +08:00
typeset -gi _p9k__region_active
2019-07-24 20:34:26 +08:00
typeset -ga _p9k_line_segments_left
typeset -ga _p9k_line_segments_right
typeset -ga _p9k_line_prefix_left
typeset -ga _p9k_line_prefix_right
typeset -ga _p9k_line_suffix_left
typeset -ga _p9k_line_suffix_right
typeset -ga _p9k_line_never_empty_right
typeset -ga _p9k_line_gap_post
2020-02-10 19:59:37 +08:00
typeset -g _p9k__xy
typeset -g _p9k__clm
typeset -g _p9k__p
typeset -gi _p9k__x
typeset -gi _p9k__y
typeset -gi _p9k__m
typeset -gi _p9k__d
typeset -gi _p9k__h
typeset -gi _p9k__ind
2019-07-24 20:34:26 +08:00
typeset -g _p9k_gap_pre
2019-11-03 02:03:45 +08:00
typeset -gi _p9k__ruler_i = 3
2019-10-29 22:54:30 +08:00
typeset -gi _p9k_ruler_idx
2019-11-03 02:03:45 +08:00
typeset -gi _p9k__empty_line_i = 3
2019-10-29 22:54:30 +08:00
typeset -gi _p9k_empty_line_idx
2019-07-24 20:34:26 +08:00
typeset -g _p9k_prompt_prefix_left
typeset -g _p9k_prompt_prefix_right
typeset -g _p9k_prompt_suffix_left
typeset -g _p9k_prompt_suffix_right
typeset -gi _p9k_emulate_zero_rprompt_indent
typeset -gA _p9k_battery_states
typeset -g _p9k_os
typeset -g _p9k_os_icon
typeset -g _p9k_color1
typeset -g _p9k_color2
2020-02-10 19:59:37 +08:00
typeset -g _p9k__s
typeset -g _p9k__ss
typeset -g _p9k__sss
typeset -g _p9k__v
typeset -g _p9k__c
typeset -g _p9k__e
typeset -g _p9k__w
typeset -gi _p9k__dir_len
2019-07-24 20:34:26 +08:00
typeset -gi _p9k_num_cpus
2019-10-25 19:22:50 +08:00
typeset -g _p9k__keymap
typeset -g _p9k__zle_state
2019-10-03 15:42:02 +08:00
typeset -g _p9k_uname
typeset -g _p9k_uname_o
typeset -g _p9k_uname_m
2019-11-06 16:21:12 +08:00
typeset -g _p9k_transient_prompt
2019-11-06 20:29:20 +08:00
typeset -g _p9k__last_prompt_pwd
2020-01-13 17:21:22 +08:00
typeset -gA _p9k_display_k
2019-11-03 18:20:52 +08:00
typeset -ga _p9k__display_v
2020-02-03 18:47:55 +08:00
typeset -gaU _p9k__async_segments_compute
2019-07-24 20:34:26 +08:00
2019-10-29 00:54:50 +08:00
typeset -gA _p9k__dotnet_stat_cache
typeset -gA _p9k__dir_stat_cache
2019-10-29 22:54:30 +08:00
typeset -gi _p9k__expanded
2019-11-21 16:24:29 +08:00
typeset -gi _p9k__force_must_init
2019-10-25 19:03:58 +08:00
2019-07-25 00:34:29 +08:00
typeset -g P9K_VISUAL_IDENTIFIER
typeset -g P9K_CONTENT
typeset -g P9K_GAP
2020-01-08 23:23:32 +08:00
typeset -g P9K_PROMPT = regular
2019-07-24 20:34:26 +08:00
}
2019-07-23 21:47:25 +08:00
_p9k_init_params( ) {
2019-10-27 02:43:38 +08:00
# invarint: _POWERLEVEL9K_INSTANT_PROMPT == (verbose|quiet|off)
2019-11-14 19:40:28 +08:00
# invariant: [[ ($_POWERLEVEL9K_INSTANT_PROMPT == off) == $_POWERLEVEL9K_DISABLE_INSTANT_PROMPT ]]
2019-10-27 02:43:38 +08:00
_p9k_declare -s POWERLEVEL9K_INSTANT_PROMPT # verbose, quiet, off
if [ [ $_POWERLEVEL9K_INSTANT_PROMPT = = off ] ] ; then
typeset -gi _POWERLEVEL9K_DISABLE_INSTANT_PROMPT = 1
else
_p9k_declare -b POWERLEVEL9K_DISABLE_INSTANT_PROMPT 0
if ( ( _POWERLEVEL9K_DISABLE_INSTANT_PROMPT ) ) ; then
_POWERLEVEL9K_INSTANT_PROMPT = off
elif [ [ $_POWERLEVEL9K_INSTANT_PROMPT != quiet ] ] ; then
_POWERLEVEL9K_INSTANT_PROMPT = verbose
fi
fi
2019-11-06 16:21:12 +08:00
_p9k_declare -s POWERLEVEL9K_TRANSIENT_PROMPT off
[ [ $_POWERLEVEL9K_TRANSIENT_PROMPT = = ( off| always| same-dir) ] ] || _POWERLEVEL9K_TRANSIENT_PROMPT = off
2020-01-18 22:41:43 +08:00
_p9k_declare -s POWERLEVEL9K_WORKER_LOG_LEVEL
2020-01-13 00:48:04 +08:00
_p9k_declare -i POWERLEVEL9K_COMMANDS_MAX_TOKEN_COUNT 64
2020-01-09 20:01:41 +08:00
_p9k_declare -a POWERLEVEL9K_HOOK_WIDGETS --
2020-01-03 16:56:33 +08:00
_p9k_declare -b POWERLEVEL9K_TODO_HIDE_ZERO_TOTAL 0
_p9k_declare -b POWERLEVEL9K_TODO_HIDE_ZERO_FILTERED 0
2019-11-06 17:32:10 +08:00
_p9k_declare -b POWERLEVEL9K_DISABLE_HOT_RELOAD 0
2019-11-04 16:48:35 +08:00
_p9k_declare -F POWERLEVEL9K_NEW_TTY_MAX_AGE_SECONDS 5
2019-11-05 21:10:20 +08:00
_p9k_declare -i POWERLEVEL9K_INSTANT_PROMPT_COMMAND_LINES 1
2019-07-23 21:47:25 +08:00
_p9k_declare -a POWERLEVEL9K_LEFT_PROMPT_ELEMENTS -- context dir vcs
_p9k_declare -a POWERLEVEL9K_RIGHT_PROMPT_ELEMENTS -- status root_indicator background_jobs history time
_p9k_declare -b POWERLEVEL9K_DISABLE_RPROMPT 0
_p9k_declare -b POWERLEVEL9K_PROMPT_ADD_NEWLINE 0
2019-07-24 18:47:56 +08:00
_p9k_declare -b POWERLEVEL9K_PROMPT_ON_NEWLINE 0
_p9k_declare -b POWERLEVEL9K_RPROMPT_ON_NEWLINE 0
2019-07-23 21:47:25 +08:00
_p9k_declare -b POWERLEVEL9K_SHOW_RULER 0
_p9k_declare -i POWERLEVEL9K_PROMPT_ADD_NEWLINE_COUNT 1
_p9k_declare -s POWERLEVEL9K_COLOR_SCHEME dark
_p9k_declare -s POWERLEVEL9K_GITSTATUS_DIR ""
2019-11-07 15:39:01 +08:00
_p9k_declare -s POWERLEVEL9K_VCS_DISABLED_WORKDIR_PATTERN
2019-07-23 21:47:25 +08:00
_p9k_declare -b POWERLEVEL9K_VCS_SHOW_SUBMODULE_DIRTY 0
_p9k_declare -i POWERLEVEL9K_VCS_SHORTEN_LENGTH
_p9k_declare -i POWERLEVEL9K_VCS_SHORTEN_MIN_LENGTH
_p9k_declare -s POWERLEVEL9K_VCS_SHORTEN_STRATEGY
2019-08-14 13:24:09 +08:00
_p9k_declare -e POWERLEVEL9K_VCS_SHORTEN_DELIMITER '\u2026'
2019-09-18 19:20:33 +08:00
_p9k_declare -b POWERLEVEL9K_VCS_CONFLICTED_STATE 0
2019-07-23 21:47:25 +08:00
_p9k_declare -b POWERLEVEL9K_HIDE_BRANCH_ICON 0
_p9k_declare -b POWERLEVEL9K_VCS_HIDE_TAGS 0
_p9k_declare -i POWERLEVEL9K_CHANGESET_HASH_LENGTH 8
# Specifies the maximum number of elements in the cache. When the cache grows over this limit,
# it gets cleared. This is meant to avoid memory leaks when a rogue prompt is filling the cache
# with data.
_p9k_declare -i POWERLEVEL9K_MAX_CACHE_SIZE 10000
_p9k_declare -e POWERLEVEL9K_ANACONDA_LEFT_DELIMITER "("
_p9k_declare -e POWERLEVEL9K_ANACONDA_RIGHT_DELIMITER ")"
_p9k_declare -b POWERLEVEL9K_ANACONDA_SHOW_PYTHON_VERSION 1
_p9k_declare -b POWERLEVEL9K_BACKGROUND_JOBS_VERBOSE 1
_p9k_declare -b POWERLEVEL9K_BACKGROUND_JOBS_VERBOSE_ALWAYS 0
_p9k_declare -b POWERLEVEL9K_DISK_USAGE_ONLY_WARNING 0
_p9k_declare -i POWERLEVEL9K_DISK_USAGE_WARNING_LEVEL 90
_p9k_declare -i POWERLEVEL9K_DISK_USAGE_CRITICAL_LEVEL 95
_p9k_declare -i POWERLEVEL9K_BATTERY_LOW_THRESHOLD 10
_p9k_declare -i POWERLEVEL9K_BATTERY_HIDE_ABOVE_THRESHOLD 999
2020-02-03 14:30:45 +08:00
_p9k_declare -b POWERLEVEL9K_BATTERY_VERBOSE 1
2019-07-23 21:47:25 +08:00
_p9k_declare -a POWERLEVEL9K_BATTERY_LEVEL_BACKGROUND --
2019-10-11 16:33:49 +08:00
_p9k_declare -a POWERLEVEL9K_BATTERY_LEVEL_FOREGROUND --
2020-02-03 14:30:45 +08:00
case $parameters [ POWERLEVEL9K_BATTERY_STAGES] in
scalar*) typeset -ga _POWERLEVEL9K_BATTERY_STAGES = ( " ${ (@s : : ) ${ (g : : )POWERLEVEL9K_BATTERY_STAGES } } " ) ; ;
array*) typeset -ga _POWERLEVEL9K_BATTERY_STAGES = ( " ${ (@g : : )POWERLEVEL9K_BATTERY_STAGES } " ) ; ;
esac
local state
for state in CHARGED CHARGING LOW DISCONNECTED; do
local var = POWERLEVEL9K_BATTERY_${ state } _STAGES
case $parameters [ $var ] in
scalar*) eval " typeset -ga _ $var =( ${ (@qq) ${ (@s : : ) ${ (g : : ) ${ (P)var } } } } ) " ; ;
array*) eval " typeset -ga _ $var =( ${ (@qq) ${ (@g : : ) ${ (@P)var } } } ) " ; ;
*) eval " typeset -ga _ $var =( ${ (@qq)_POWERLEVEL9K_BATTERY_STAGES } ) " ; ;
esac
local var = POWERLEVEL9K_BATTERY_${ state } _LEVEL_BACKGROUND
case $parameters [ $var ] in
array*) eval " typeset -ga _ $var =( ${ (@qq) ${ (@P)var } } ) " ; ;
*) eval " typeset -ga _ $var =( ${ (@qq)_POWERLEVEL9K_BATTERY_LEVEL_BACKGROUND } ) " ; ;
esac
local var = POWERLEVEL9K_BATTERY_${ state } _LEVEL_FOREGROUND
case $parameters [ $var ] in
array*) eval " typeset -ga _ $var =( ${ (@qq) ${ (@P)var } } ) " ; ;
*) eval " typeset -ga _ $var =( ${ (@qq)_POWERLEVEL9K_BATTERY_LEVEL_FOREGROUND } ) " ; ;
esac
done
2019-07-23 21:47:25 +08:00
_p9k_declare -F POWERLEVEL9K_PUBLIC_IP_TIMEOUT 300
_p9k_declare -a POWERLEVEL9K_PUBLIC_IP_METHODS -- dig curl wget
_p9k_declare -e POWERLEVEL9K_PUBLIC_IP_NONE ""
2020-01-26 21:46:50 +08:00
_p9k_declare -s POWERLEVEL9K_PUBLIC_IP_HOST "https://v4.ident.me/"
2019-07-23 21:47:25 +08:00
_p9k_declare -s POWERLEVEL9K_PUBLIC_IP_VPN_INTERFACE ""
2020-01-21 06:37:03 +08:00
_p9k_segment_in_use public_ip || _POWERLEVEL9K_PUBLIC_IP_VPN_INTERFACE =
2019-07-23 21:47:25 +08:00
_p9k_declare -b POWERLEVEL9K_ALWAYS_SHOW_CONTEXT 0
_p9k_declare -b POWERLEVEL9K_ALWAYS_SHOW_USER 0
_p9k_declare -e POWERLEVEL9K_CONTEXT_TEMPLATE "%n@%m"
_p9k_declare -e POWERLEVEL9K_USER_TEMPLATE "%n"
_p9k_declare -e POWERLEVEL9K_HOST_TEMPLATE "%m"
_p9k_declare -F POWERLEVEL9K_COMMAND_EXECUTION_TIME_THRESHOLD 3
_p9k_declare -i POWERLEVEL9K_COMMAND_EXECUTION_TIME_PRECISION 2
# Other options: "d h m s".
_p9k_declare -s POWERLEVEL9K_COMMAND_EXECUTION_TIME_FORMAT "H:M:S"
_p9k_declare -e POWERLEVEL9K_DIR_PATH_SEPARATOR "/"
_p9k_declare -e POWERLEVEL9K_HOME_FOLDER_ABBREVIATION "~"
_p9k_declare -b POWERLEVEL9K_DIR_PATH_HIGHLIGHT_BOLD 0
2019-09-16 02:50:08 +08:00
_p9k_declare -b POWERLEVEL9K_DIR_ANCHOR_BOLD 0
2019-07-23 21:47:25 +08:00
_p9k_declare -b POWERLEVEL9K_DIR_PATH_ABSOLUTE 0
_p9k_declare -b POWERLEVEL9K_DIR_SHOW_WRITABLE 0
_p9k_declare -b POWERLEVEL9K_DIR_OMIT_FIRST_CHARACTER 0
_p9k_declare -b POWERLEVEL9K_DIR_HYPERLINK 0
_p9k_declare -s POWERLEVEL9K_SHORTEN_STRATEGY ""
_p9k_declare -s POWERLEVEL9K_DIR_PATH_SEPARATOR_FOREGROUND
_p9k_declare -s POWERLEVEL9K_DIR_PATH_HIGHLIGHT_FOREGROUND
_p9k_declare -s POWERLEVEL9K_DIR_ANCHOR_FOREGROUND
_p9k_declare -s POWERLEVEL9K_DIR_SHORTENED_FOREGROUND
2019-08-28 21:41:59 +08:00
local markers = (
.bzr
.citc
.git
.hg
.node-version
.python-version
.ruby-version
.shorten_folder_marker
.svn
.terraform
CVS
Cargo.toml
composer.json
go.mod
package.json
)
_p9k_declare -s POWERLEVEL9K_SHORTEN_FOLDER_MARKER " ( ${ (j : | : )markers } ) "
2019-07-23 21:47:25 +08:00
# Shorten directory if it's longer than this even if there is space for it.
# The value can be either absolute (e.g., '80') or a percentage of terminal
# width (e.g, '50%'). If empty, directory will be shortened only when prompt
# doesn't fit. Applies only when POWERLEVEL9K_SHORTEN_STRATEGY=truncate_to_unique.
_p9k_declare -s POWERLEVEL9K_DIR_MAX_LENGTH 0
# Individual elements are patterns. They are expanded with the options set
# by `emulate zsh && setopt extended_glob`.
_p9k_declare -a POWERLEVEL9K_DIR_PACKAGE_FILES -- package.json composer.json
# When dir is on the last prompt line, try to shorten it enough to leave at least this many
# columns for typing commands. Applies only when POWERLEVEL9K_SHORTEN_STRATEGY=truncate_to_unique.
_p9k_declare -i POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS 40
# When dir is on the last prompt line, try to shorten it enough to leave at least
# COLUMNS * POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS_PCT * 0.01 columns for typing commands. Applies
# only when POWERLEVEL9K_SHORTEN_STRATEGY=truncate_to_unique.
_p9k_declare -F POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS_PCT 50
# POWERLEVEL9K_DIR_CLASSES allow you to specify custom styling and icons for different
# directories.
#
# POWERLEVEL9K_DIR_CLASSES must be an array with 3 * N elements. Each triplet consists of:
#
# 1. A pattern against which the current directory is matched. Matching is done with
# extended_glob option enabled.
# 2. Directory class for the purpose of styling.
# 3. Icon.
#
# Triplets are tried in order. The first triplet whose pattern matches $PWD wins. If there are no
# matches, there will be no icon and the styling is done according to POWERLEVEL9K_DIR_BACKGROUND,
# POWERLEVEL9K_DIR_FOREGROUND, etc.
#
# Example:
#
# POWERLEVEL9K_DIR_CLASSES=(
# '~/work(/*)#' WORK '(╯°□°)╯︵ ┻━┻'
# '~(/*)#' HOME '⌂'
# '*' DEFAULT '')
#
# POWERLEVEL9K_DIR_WORK_BACKGROUND=red
# POWERLEVEL9K_DIR_HOME_BACKGROUND=blue
# POWERLEVEL9K_DIR_DEFAULT_BACKGROUND=yellow
#
# With these settings, the current directory in the prompt may look like this:
#
# (╯°□°)╯︵ ┻━┻ ~/work/projects/important/urgent
#
# ⌂ ~/best/powerlevel10k
2019-07-24 20:34:26 +08:00
_p9k_declare -a POWERLEVEL9K_DIR_CLASSES
2019-07-23 21:47:25 +08:00
_p9k_declare -i POWERLEVEL9K_SHORTEN_DELIMITER_LENGTH
_p9k_declare -e POWERLEVEL9K_SHORTEN_DELIMITER
2020-01-23 22:25:13 +08:00
_p9k_declare -b POWERLEVEL9K_DIR_TRUNCATE_BEFORE_MARKER
[ [ -z $_POWERLEVEL9K_SHORTEN_FOLDER_MARKER ] ] && _POWERLEVEL9K_DIR_TRUNCATE_BEFORE_MARKER = 0
2019-07-23 21:47:25 +08:00
_p9k_declare -i POWERLEVEL9K_SHORTEN_DIR_LENGTH
2019-08-29 00:55:33 +08:00
_p9k_declare -s POWERLEVEL9K_IP_INTERFACE ""
2020-01-18 22:41:43 +08:00
: ${ _POWERLEVEL9K_IP_INTERFACE : = '.*' }
_p9k_segment_in_use ip || _POWERLEVEL9K_IP_INTERFACE =
2019-09-12 16:55:56 +08:00
_p9k_declare -s POWERLEVEL9K_VPN_IP_INTERFACE "(wg|(.*tun))[0-9]*"
2020-01-18 22:41:43 +08:00
: ${ _POWERLEVEL9K_VPN_IP_INTERFACE : = '.*' }
_p9k_segment_in_use vpn_ip || _POWERLEVEL9K_VPN_IP_INTERFACE =
2019-07-23 21:47:25 +08:00
_p9k_declare -i POWERLEVEL9K_LOAD_WHICH 5
2020-01-18 23:42:00 +08:00
case $_POWERLEVEL9K_LOAD_WHICH in
1) _POWERLEVEL9K_LOAD_WHICH = 1; ;
15) _POWERLEVEL9K_LOAD_WHICH = 3; ;
*) _POWERLEVEL9K_LOAD_WHICH = 2; ;
esac
2019-07-23 21:47:25 +08:00
_p9k_declare -b POWERLEVEL9K_NODENV_PROMPT_ALWAYS_SHOW 0
2019-07-24 05:17:01 +08:00
_p9k_declare -b POWERLEVEL9K_NODE_VERSION_PROJECT_ONLY 0
2020-02-15 20:46:42 +08:00
_p9k_declare -b POWERLEVEL9K_PHP_VERSION_PROJECT_ONLY 0
2019-09-24 16:17:54 +08:00
_p9k_declare -b POWERLEVEL9K_DOTNET_VERSION_PROJECT_ONLY 1
2019-08-12 14:56:47 +08:00
_p9k_declare -b POWERLEVEL9K_GO_VERSION_PROJECT_ONLY 1
_p9k_declare -b POWERLEVEL9K_RUST_VERSION_PROJECT_ONLY 1
2019-07-23 21:47:25 +08:00
_p9k_declare -b POWERLEVEL9K_RBENV_PROMPT_ALWAYS_SHOW 0
2019-11-18 18:32:53 +08:00
_p9k_declare -a POWERLEVEL9K_RBENV_SOURCES -- shell local global
2020-02-15 20:38:44 +08:00
_p9k_declare -b POWERLEVEL9K_PHPENV_PROMPT_ALWAYS_SHOW 0
_p9k_declare -a POWERLEVEL9K_PHPENV_SOURCES -- shell local global
2020-01-03 00:43:45 +08:00
_p9k_declare -b POWERLEVEL9K_LUAENV_PROMPT_ALWAYS_SHOW 0
_p9k_declare -a POWERLEVEL9K_LUAENV_SOURCES -- shell local global
2020-01-03 01:03:59 +08:00
_p9k_declare -b POWERLEVEL9K_JENV_PROMPT_ALWAYS_SHOW 0
_p9k_declare -a POWERLEVEL9K_JENV_SOURCES -- shell local global
2020-01-03 01:24:01 +08:00
_p9k_declare -b POWERLEVEL9K_PLENV_PROMPT_ALWAYS_SHOW 0
_p9k_declare -a POWERLEVEL9K_PLENV_SOURCES -- shell local global
2020-02-11 18:22:53 +08:00
_p9k_declare -b POWERLEVEL9K_ASDF_PROMPT_ALWAYS_SHOW 0
_p9k_declare -b POWERLEVEL9K_ASDF_SHOW_SYSTEM 1
_p9k_declare -a POWERLEVEL9K_ASDF_SOURCES -- shell local global
local var
for var in ${ parameters [(I)POWERLEVEL9K_ASDF_*_PROMPT_ALWAYS_SHOW] } ; do
_p9k_declare -b $var $_POWERLEVEL9K_ASDF_PROMPT_ALWAYS_SHOW
done
for var in ${ parameters [(I)POWERLEVEL9K_ASDF_*_SHOW_SYSTEM] } ; do
_p9k_declare -b $var $_POWERLEVEL9K_ASDF_SHOW_SYSTEM
done
for var in ${ parameters [(I)POWERLEVEL9K_ASDF_*_SOURCES] } ; do
_p9k_declare -a $var -- $_POWERLEVEL9K_ASDF_SOURCES
done
2019-08-10 16:47:22 +08:00
_p9k_declare -b POWERLEVEL9K_RVM_SHOW_GEMSET 0
_p9k_declare -b POWERLEVEL9K_RVM_SHOW_PREFIX 0
2019-07-23 21:47:25 +08:00
_p9k_declare -b POWERLEVEL9K_CHRUBY_SHOW_VERSION 1
_p9k_declare -b POWERLEVEL9K_CHRUBY_SHOW_ENGINE 1
_p9k_declare -b POWERLEVEL9K_STATUS_CROSS 0
_p9k_declare -b POWERLEVEL9K_STATUS_OK 1
2019-07-26 21:35:46 +08:00
_p9k_declare -b POWERLEVEL9K_STATUS_OK_PIPE 1
_p9k_declare -b POWERLEVEL9K_STATUS_ERROR 1
_p9k_declare -b POWERLEVEL9K_STATUS_ERROR_PIPE 1
_p9k_declare -b POWERLEVEL9K_STATUS_ERROR_SIGNAL 1
2019-07-23 21:47:25 +08:00
_p9k_declare -b POWERLEVEL9K_STATUS_SHOW_PIPESTATUS 1
_p9k_declare -b POWERLEVEL9K_STATUS_HIDE_SIGNAME 0
2019-07-26 21:35:46 +08:00
_p9k_declare -b POWERLEVEL9K_STATUS_VERBOSE_SIGNAME 1
_p9k_declare -b POWERLEVEL9K_STATUS_EXTENDED_STATES 0
2019-07-23 21:47:25 +08:00
_p9k_declare -b POWERLEVEL9K_STATUS_VERBOSE 1
_p9k_declare -b POWERLEVEL9K_STATUS_OK_IN_NON_VERBOSE 0
_p9k_declare -e POWERLEVEL9K_DATE_FORMAT "%D{%d.%m.%y}"
_p9k_declare -s POWERLEVEL9K_VCS_ACTIONFORMAT_FOREGROUND 1
_p9k_declare -b POWERLEVEL9K_SHOW_CHANGESET 0
_p9k_declare -e POWERLEVEL9K_VCS_LOADING_TEXT loading
_p9k_declare -a POWERLEVEL9K_VCS_GIT_HOOKS -- vcs-detect-changes git-untracked git-aheadbehind git-stash git-remotebranch git-tagname
_p9k_declare -a POWERLEVEL9K_VCS_HG_HOOKS -- vcs-detect-changes
_p9k_declare -a POWERLEVEL9K_VCS_SVN_HOOKS -- vcs-detect-changes svn-detect-changes
# If it takes longer than this to fetch git repo status, display the prompt with a greyed out
# vcs segment and fix it asynchronously when the results come it.
2019-11-11 18:54:07 +08:00
_p9k_declare -F POWERLEVEL9K_VCS_MAX_SYNC_LATENCY_SECONDS 0.02
2019-07-23 21:47:25 +08:00
_p9k_declare -a POWERLEVEL9K_VCS_BACKENDS -- git
_p9k_declare -b POWERLEVEL9K_VCS_DISABLE_GITSTATUS_FORMATTING 0
_p9k_declare -i POWERLEVEL9K_VCS_MAX_INDEX_SIZE_DIRTY -1
_p9k_declare -i POWERLEVEL9K_VCS_STAGED_MAX_NUM 1
_p9k_declare -i POWERLEVEL9K_VCS_UNSTAGED_MAX_NUM 1
_p9k_declare -i POWERLEVEL9K_VCS_UNTRACKED_MAX_NUM 1
2019-08-06 04:26:23 +08:00
_p9k_declare -i POWERLEVEL9K_VCS_CONFLICTED_MAX_NUM 1
2019-07-23 21:47:25 +08:00
_p9k_declare -i POWERLEVEL9K_VCS_COMMITS_AHEAD_MAX_NUM -1
_p9k_declare -i POWERLEVEL9K_VCS_COMMITS_BEHIND_MAX_NUM -1
2019-10-24 20:16:40 +08:00
_p9k_declare -b POWERLEVEL9K_VCS_RECURSE_UNTRACKED_DIRS 0
2019-07-23 21:47:25 +08:00
_p9k_declare -b POWERLEVEL9K_DISABLE_GITSTATUS 0
_p9k_declare -e POWERLEVEL9K_VI_INSERT_MODE_STRING "INSERT"
_p9k_declare -e POWERLEVEL9K_VI_COMMAND_MODE_STRING "NORMAL"
# VISUAL mode is shown as NORMAL unless POWERLEVEL9K_VI_VISUAL_MODE_STRING is explicitly set.
_p9k_declare -e POWERLEVEL9K_VI_VISUAL_MODE_STRING
2019-09-18 19:38:31 +08:00
# OVERWRITE mode is shown as INSERT unless POWERLEVEL9K_VI_OVERWRITE_MODE_STRING is explicitly set.
_p9k_declare -e POWERLEVEL9K_VI_OVERWRITE_MODE_STRING
2019-07-23 21:47:25 +08:00
_p9k_declare -b POWERLEVEL9K_VIRTUALENV_SHOW_PYTHON_VERSION 1
_p9k_declare -e POWERLEVEL9K_VIRTUALENV_LEFT_DELIMITER "("
_p9k_declare -e POWERLEVEL9K_VIRTUALENV_RIGHT_DELIMITER ")"
2019-11-27 18:01:57 +08:00
_p9k_declare -a POWERLEVEL9K_VIRTUALENV_GENERIC_NAMES -- virtualenv venv .venv
2019-07-23 21:47:25 +08:00
_p9k_declare -b POWERLEVEL9K_PYENV_PROMPT_ALWAYS_SHOW 0
2019-12-12 22:38:56 +08:00
_p9k_declare -a POWERLEVEL9K_PYENV_SOURCES -- shell local global
2019-12-01 19:47:03 +08:00
_p9k_declare -b POWERLEVEL9K_GOENV_PROMPT_ALWAYS_SHOW 0
2020-01-28 16:59:54 +08:00
_p9k_declare -a POWERLEVEL9K_GOENV_SOURCES -- shell local global
2019-07-29 22:10:28 +08:00
_p9k_declare -b POWERLEVEL9K_NODEENV_SHOW_NODE_VERSION 1
_p9k_declare -e POWERLEVEL9K_NODEENV_LEFT_DELIMITER "["
_p9k_declare -e POWERLEVEL9K_NODEENV_RIGHT_DELIMITER "]"
2019-07-23 21:47:25 +08:00
_p9k_declare -b POWERLEVEL9K_KUBECONTEXT_SHOW_DEFAULT_NAMESPACE 1
2019-07-30 13:14:51 +08:00
_p9k_declare -a POWERLEVEL9K_KUBECONTEXT_SHORTEN --
2019-07-23 21:47:25 +08:00
# Defines context classes for the purpose of applying different styling to different contexts.
#
# POWERLEVEL9K_KUBECONTEXT_CLASSES must be an array with even number of elements. The first
# element in each pair defines a pattern against which the current context (in the format it is
# displayed in the prompt) gets matched. The second element defines context class. Patterns are
# tried in order. The first match wins.
#
# If a non-empty class <C> is assigned to a context, the segment is styled with
# POWERLEVEL9K_KUBECONTEXT_<U>_BACKGROUND and POWERLEVEL9K_KUBECONTEXT_<U>_FOREGROUND where <U> is
# uppercased <C>. Otherwise with POWERLEVEL9K_KUBECONTEXT_BACKGROUND and
# POWERLEVEL9K_KUBECONTEXT_FOREGROUND.
#
# Example: Use red background for contexts containing "prod", green for "testing" and yellow for
# everything else.
#
# POWERLEVEL9K_KUBECONTEXT_CLASSES=(
# '*prod*' prod
# '*testing*' testing
# '*' other)
#
# POWERLEVEL9K_KUBECONTEXT_PROD_BACKGROUND=red
# POWERLEVEL9K_KUBECONTEXT_TESTING_BACKGROUND=green
# POWERLEVEL9K_KUBECONTEXT_OTHER_BACKGROUND=yellow
_p9k_declare -a POWERLEVEL9K_KUBECONTEXT_CLASSES --
2019-11-14 19:40:28 +08:00
_p9k_declare -a POWERLEVEL9K_AWS_CLASSES --
2019-12-16 04:15:48 +08:00
_p9k_declare -a POWERLEVEL9K_TERRAFORM_CLASSES --
2020-01-03 00:18:31 +08:00
_p9k_declare -a POWERLEVEL9K_GOOGLE_APP_CRED_CLASSES -- 'service_account:*' SERVICE_ACCOUNT
2019-07-23 21:47:25 +08:00
# Specifies the format of java version.
#
# POWERLEVEL9K_JAVA_VERSION_FULL=true => 1.8.0_212-8u212-b03-0ubuntu1.18.04.1-b03
# POWERLEVEL9K_JAVA_VERSION_FULL=false => 1.8.0_212
#
# These correspond to `java -fullversion` and `java -version` respectively.
_p9k_declare -b POWERLEVEL9K_JAVA_VERSION_FULL 1
2019-09-18 19:38:31 +08:00
_p9k_declare -b POWERLEVEL9K_PROMPT_CHAR_OVERWRITE_STATE 0
2019-09-07 16:05:56 +08:00
2020-01-18 02:00:29 +08:00
# Format for the current time: 09:51:02. See `man 3 strftime`.
_p9k_declare -e POWERLEVEL9K_TIME_FORMAT "%D{%H:%M:%S}"
# If set to true, time will update when you hit enter. This way prompts for the past
# commands will contain the start times of their commands as opposed to the default
# behavior where they contain the end times of their preceding commands.
_p9k_declare -b POWERLEVEL9K_TIME_UPDATE_ON_COMMAND 0
# If set to true, time will update every second.
_p9k_declare -b POWERLEVEL9K_EXPERIMENTAL_TIME_REALTIME 0
2019-09-07 16:05:56 +08:00
local -i i = 1
while ( ( i <= $# _POWERLEVEL9K_LEFT_PROMPT_ELEMENTS ) ) ; do
local segment = ${ (U)_POWERLEVEL9K_LEFT_PROMPT_ELEMENTS[i] }
local var = POWERLEVEL9K_${ segment } _LEFT_DISABLED
( ( $+parameters[ $var ] ) ) || var = POWERLEVEL9K_${ segment } _DISABLED
if [ [ ${ (P)var } = = true ] ] ; then
_POWERLEVEL9K_LEFT_PROMPT_ELEMENTS[ i,i] = ( )
else
( ( ++i ) )
fi
done
local -i i = 1
while ( ( i <= $# _POWERLEVEL9K_RIGHT_PROMPT_ELEMENTS ) ) ; do
local segment = ${ (U)_POWERLEVEL9K_RIGHT_PROMPT_ELEMENTS[i] }
local var = POWERLEVEL9K_${ segment } _RIGHT_DISABLED
( ( $+parameters[ $var ] ) ) || var = POWERLEVEL9K_${ segment } _DISABLED
if [ [ ${ (P)var } = = true ] ] ; then
_POWERLEVEL9K_RIGHT_PROMPT_ELEMENTS[ i,i] = ( )
else
( ( ++i ) )
fi
done
2019-11-06 17:22:51 +08:00
2020-02-11 18:22:53 +08:00
local var
for var in ${ (@) ${ parameters [(I)POWERLEVEL9K_*] } /(#m)*/ ${ (M) ${ parameters [_ $MATCH ]- $MATCH } : # $MATCH } } ; do
case $parameters [ $var ] in
( scalar| integer| float) *) typeset -g _$var = ${ (P)var } ; ;
array*) eval 'typeset -ga ' _$var '=("${' $var '[@]}")' ; ;
esac
2019-11-06 17:22:51 +08:00
done
2019-06-01 23:54:53 +08:00
}
2020-01-09 20:01:41 +08:00
function _p9k_on_widget_zle-keymap-select( ) { __p9k_reset_state = 2; }
function _p9k_on_widget_overwrite-mode( ) { __p9k_reset_state = 2; }
function _p9k_on_widget_vi-replace( ) { __p9k_reset_state = 2; }
function _p9k_check_visual_mode( ) {
[ [ ${ KEYMAP :- } = = vicmd ] ] || return 0
local region = ${ ${ REGION_ACTIVE :- 0 } /2/1 }
[ [ $region != $_p9k__region_active ] ] || return 0
_p9k__region_active = $region
__p9k_reset_state = 2
}
function _p9k_on_widget_visual-mode( ) { _p9k_check_visual_mode; }
function _p9k_on_widget_visual-line-mode( ) { _p9k_check_visual_mode; }
function _p9k_on_widget_deactivate-region( ) { _p9k_check_visual_mode; }
2019-07-12 17:55:32 +08:00
2020-01-09 03:16:52 +08:00
function _p9k_on_widget_zle-line-init( ) {
2019-12-14 21:57:30 +08:00
( ( _p9k__cursor_hidden ) ) || return 0
_p9k__cursor_hidden = 0
echoti cnorm
}
2020-01-09 03:16:52 +08:00
function _p9k_on_widget_zle-line-finish( ) {
2019-11-06 16:32:54 +08:00
( ( $+_p9k__line_finished ) ) && return
2019-10-25 19:22:50 +08:00
_p9k__line_finished =
2020-01-09 20:01:41 +08:00
( ( _p9k_reset_on_line_finish ) ) && __p9k_reset_state = 2
( ( $+functions[ p10k-on-post-prompt] ) ) && p10k-on-post-prompt
2019-11-03 20:56:51 +08:00
2019-11-06 16:21:12 +08:00
if [ [ -n $_p9k_transient_prompt ] ] ; then
2020-01-27 22:04:34 +08:00
if [ [ $_POWERLEVEL9K_TRANSIENT_PROMPT = = always || $_p9k__cwd = = $_p9k__last_prompt_pwd ] ] ; then
2019-11-06 16:21:12 +08:00
RPROMPT =
PROMPT = $_p9k_transient_prompt
2020-01-09 20:01:41 +08:00
__p9k_reset_state = 2
2019-11-06 16:21:12 +08:00
else
2020-01-27 22:04:34 +08:00
_p9k__last_prompt_pwd = $_p9k__cwd
2019-11-06 16:21:12 +08:00
fi
fi
2020-01-09 20:01:41 +08:00
if ( ( __p9k_reset_state = = 2 ) ) ; then
2020-01-02 23:17:56 +08:00
if [ [ $1 = = int ] ] ; then
_p9k__must_restore_prompt = 1
if ( ( !_p9k__restore_prompt_fd ) ) ; then
exec { _p9k__restore_prompt_fd} </dev/null
zle -F $_p9k__restore_prompt_fd _p9k_restore_prompt
fi
fi
if ( ( $+termcap[ up] ) ) ; then
2019-12-14 21:57:30 +08:00
( ( _p9k__can_hide_cursor ) ) && local hide = $terminfo [ civis] || local hide =
echo -nE - $hide $'\n' $termcap [ up]
fi
2019-09-20 17:22:14 +08:00
_p9k_reset_prompt
2020-01-09 20:01:41 +08:00
__p9k_reset_state = 0
2019-08-05 16:37:04 +08:00
fi
2019-11-06 16:32:54 +08:00
_p9k__line_finished = '%{%}'
2019-07-24 21:52:54 +08:00
}
2020-01-13 17:21:22 +08:00
# Usage example: _p9k_display_segment 58 _p9k__1rkubecontext hide
function _p9k_display_segment( ) {
[ [ $_p9k__display_v [ $1 ] = = $3 ] ] && return
_p9k__display_v[ $1 ] = $3
[ [ $3 = = hide ] ] && typeset -g $2 = || unset $2
__p9k_reset_state = 2
}
2020-01-09 03:16:52 +08:00
function _p9k_widget_hook( ) {
2020-01-13 00:33:33 +08:00
if ( ( $+functions[ p10k-on-post-widget] || $# _p9k_show_on_command ) ) ; then
local -a P9K_COMMANDS
if [ [ " $_p9k__last_buffer " = = " $PREBUFFER $BUFFER " ] ] ; then
P9K_COMMANDS = ( ${ _p9k__last_commands [@] } )
else
_p9k__last_buffer = " $PREBUFFER $BUFFER "
if [ [ -n " $_p9k__last_buffer " ] ] ; then
2020-01-13 00:48:04 +08:00
# this must run with user options
_p9k_parse_buffer " $_p9k__last_buffer " $_POWERLEVEL9K_COMMANDS_MAX_TOKEN_COUNT
2020-01-13 00:33:33 +08:00
fi
_p9k__last_commands = ( ${ P9K_COMMANDS [@] } )
fi
fi
2020-02-02 05:03:42 +08:00
eval " $__p9k_intro "
2020-01-10 02:01:53 +08:00
( ( _p9k__restore_prompt_fd ) ) && _p9k_restore_prompt $_p9k__restore_prompt_fd
2020-01-09 20:01:41 +08:00
__p9k_reset_state = 1
2020-01-13 17:21:22 +08:00
local pat idx var
for pat idx var in $_p9k_show_on_command ; do
if ( ( $P9K_COMMANDS [ ( I) $pat ] ) ) ; then
_p9k_display_segment $idx $var show
2020-01-13 00:33:33 +08:00
else
2020-01-13 17:21:22 +08:00
_p9k_display_segment $idx $var hide
2020-01-13 00:33:33 +08:00
fi
done
2020-01-09 03:16:52 +08:00
( ( $+functions[ p10k-on-post-widget] ) ) && p10k-on-post-widget " ${ @ : 2 } "
2020-01-09 20:01:41 +08:00
( ( $+functions[ _p9k_on_widget_$1 ] ) ) && _p9k_on_widget_$1
( ( __p9k_reset_state = = 2 ) ) && _p9k_reset_prompt
__p9k_reset_state = 0
2020-01-09 03:16:52 +08:00
}
function _p9k_widget( ) {
2020-01-09 06:00:00 +08:00
( ( ! ${ +widgets[._p9k_orig_ $1 ] } ) ) || zle ._p9k_orig_$1 " ${ @ : 2 } "
2020-01-09 03:16:52 +08:00
local res = $?
2020-01-12 02:24:51 +08:00
( ( ! __p9k_enabled ) ) || [ [ $CONTEXT != start ] ] || _p9k_widget_hook " $@ "
2020-01-09 03:16:52 +08:00
return res
}
typeset -gi __p9k_widgets_wrapped = 0
function _p9k_wrap_widgets( ) {
( ( __p9k_widgets_wrapped ) ) && return
typeset -gir __p9k_widgets_wrapped = 1
2020-01-09 20:01:41 +08:00
local -a widget_list
if is-at-least 5.3; then
local -aU widget_list = (
zle-line-pre-redraw
zle-line-init
zle-line-finish
zle-keymap-select
overwrite-mode
vi-replace
visual-mode
visual-line-mode
deactivate-region
$_POWERLEVEL9K_HOOK_WIDGETS
)
else
# There is no zle-line-pre-redraw in zsh < 5.3, so we have to wrap all widgets
# with key bindings. This costs extra 3ms: 1.5ms to fetch the list of widgets and
# another 1.5ms to wrap them.
local keymap tmp = ${ TMPDIR :- /tmp } /p10k.bindings.$sysparams [ pid]
2020-01-09 03:16:52 +08:00
{
2020-01-09 20:01:41 +08:00
for keymap in $keymaps ; do bindkey -M $keymap ; done >$tmp
local -aU widget_list = (
zle-isearch-exit
zle-isearch-update
zle-line-init
zle-line-finish
zle-history-line-set
zle-keymap-select
$_POWERLEVEL9K_HOOK_WIDGETS
${ ${ ${ (f) " $( <$tmp ) " } ##* } : #(* \" |.*) }
)
} always {
2020-02-18 22:47:24 +08:00
zf_rm -f -- $tmp
2020-01-09 20:01:41 +08:00
}
fi
local widget
for widget in $widget_list ; do
functions[ _p9k_widget_$widget ] = '_p9k_widget ' ${ (q)widget } ' "$@"'
# The leading dot is to work around bugs in zsh-syntax-highlighting.
zle -A $widget ._p9k_orig_$widget
zle -N $widget _p9k_widget_$widget
done 2>/dev/null # `zle -A` fails for inexisting widgets and complains to stderr
2020-01-09 03:16:52 +08:00
}
function _p9k_restore_prompt( ) {
2020-02-02 05:03:42 +08:00
eval " $__p9k_intro "
2020-01-09 03:16:52 +08:00
{
( ( _p9k__must_restore_prompt ) ) || return
_p9k__must_restore_prompt = 0
unset _p9k__line_finished
2020-02-10 19:59:37 +08:00
_p9k__refresh_reason = restore
2020-01-09 03:16:52 +08:00
_p9k_set_prompt
2020-02-10 19:59:37 +08:00
_p9k__refresh_reason =
2020-01-09 03:16:52 +08:00
local tty = $P9K_TTY
P9K_TTY = $_p9k__last_tty
_p9k__expanded = 0
_p9k_reset_prompt
P9K_TTY = $tty
} always {
zle -F $1
exec { 1} >& -
_p9k__restore_prompt_fd = 0
}
}
2020-02-10 19:59:37 +08:00
prompt__p9k_internal_nothing( ) { _p9k__prompt += '${_p9k__sss::=}' ; }
2019-10-16 23:36:54 +08:00
instant_prompt__p9k_internal_nothing( ) { prompt__p9k_internal_nothing; }
2019-07-16 22:19:16 +08:00
2019-11-03 02:03:45 +08:00
# _p9k_build_gap_post line_number
2019-07-21 16:48:57 +08:00
_p9k_build_gap_post( ) {
2019-11-03 02:03:45 +08:00
[ [ $1 = = 1 ] ] && local kind = first || local kind = newline
_p9k_get_icon '' MULTILINE_${ (U)kind } _PROMPT_GAP_CHAR
2020-02-10 19:59:37 +08:00
local char = ${ _p9k__ret :- }
2019-07-21 16:48:57 +08:00
_p9k_prompt_length $char
2020-02-10 19:59:37 +08:00
if ( ( _p9k__ret != 1 || $# char != 1 ) ) ; then
2020-01-13 15:50:50 +08:00
>& 2 print -rP -- " %F{red}WARNING!%f %BMULTILINE_ ${ (U)kind } _PROMPT_GAP_CHAR%b is not one character long. Will use ' '. "
>& 2 print -rP -- " Either change the value of %BPOWERLEVEL9K_MULTILINE_ ${ (U)kind } _PROMPT_GAP_CHAR%b or remove it. "
2019-07-21 16:48:57 +08:00
char = ' '
fi
local style
2019-11-03 02:03:45 +08:00
_p9k_color prompt_multiline_${ kind } _prompt_gap BACKGROUND ""
2020-02-10 19:59:37 +08:00
[ [ -n $_p9k__ret ] ] && _p9k_background $_p9k__ret
style += $_p9k__ret
2019-11-03 02:03:45 +08:00
_p9k_color prompt_multiline_${ kind } _prompt_gap FOREGROUND ""
2020-02-10 19:59:37 +08:00
[ [ -n $_p9k__ret ] ] && _p9k_foreground $_p9k__ret
style += $_p9k__ret
2019-10-25 20:43:36 +08:00
_p9k_escape_style $style
2020-02-10 19:59:37 +08:00
style = $_p9k__ret
2019-11-06 17:22:51 +08:00
local exp = _POWERLEVEL9K_MULTILINE_${ (U)kind } _PROMPT_GAP_EXPANSION
2019-07-22 00:54:08 +08:00
( ( $+parameters[ $exp ] ) ) && exp = ${ (P)exp } || exp = '${P9K_GAP}'
2019-07-21 16:48:57 +08:00
[ [ $char = = '.' ] ] && local s = ',' || local s = '.'
2020-02-10 19:59:37 +08:00
_p9k__ret = $'${${_p9k__g+\n}:-' $style '${${${_p9k__m:#-*}:+'
_p9k__ret += '${${_p9k__' $1 'g+${(pl.$((_p9k__m+1)).. .)}}:-'
2019-07-22 00:54:08 +08:00
if [ [ $exp = = '${P9K_GAP}' ] ] ; then
2020-02-10 19:59:37 +08:00
_p9k__ret += '${(pl' $s '$((_p9k__m+1))' $s $s $char $s ')}'
2019-07-22 00:54:08 +08:00
else
2020-02-10 19:59:37 +08:00
_p9k__ret += '${${P9K_GAP::=${(pl' $s '$((_p9k__m+1))' $s $s $char $s ')}}+}'
_p9k__ret += '${:-"' $exp '"}'
2019-07-22 00:54:08 +08:00
style = 1
fi
2020-02-10 19:59:37 +08:00
_p9k__ret += '}'
2019-09-20 17:22:14 +08:00
if ( ( __p9k_ksh_arrays ) ) ; then
2020-02-10 19:59:37 +08:00
_p9k__ret += $'$_p9k__rprompt${_p9k_t[$((!_p9k__ind))]}}:-\n}'
2019-09-20 17:22:14 +08:00
else
2020-02-10 19:59:37 +08:00
_p9k__ret += $'$_p9k__rprompt${_p9k_t[$((1+!_p9k__ind))]}}:-\n}'
2019-09-20 17:22:14 +08:00
fi
2020-02-10 19:59:37 +08:00
[ [ -n $style ] ] && _p9k__ret += '%b%k%f'
_p9k__ret += '}'
2019-07-21 16:48:57 +08:00
}
2019-07-16 22:19:16 +08:00
_p9k_init_lines( ) {
2019-07-23 21:47:25 +08:00
local -a left_segments = ( $_POWERLEVEL9K_LEFT_PROMPT_ELEMENTS )
local -a right_segments = ( $_POWERLEVEL9K_RIGHT_PROMPT_ELEMENTS )
2019-07-16 22:19:16 +08:00
2019-07-23 21:47:25 +08:00
if ( ( _POWERLEVEL9K_PROMPT_ON_NEWLINE ) ) ; then
2019-07-16 22:19:16 +08:00
left_segments += ( newline _p9k_internal_nothing)
fi
local -i num_left_lines = $(( 1 + ${# ${ (@M)left_segments : #newline } } ))
local -i num_right_lines = $(( 1 + ${# ${ (@M)right_segments : #newline } } ))
if ( ( num_right_lines > num_left_lines ) ) ; then
2019-07-17 02:03:56 +08:00
repeat $(( num_right_lines - num_left_lines)) left_segments = ( newline $left_segments )
2019-07-16 22:19:16 +08:00
local -i num_lines = num_right_lines
else
2019-07-23 21:47:25 +08:00
if ( ( _POWERLEVEL9K_RPROMPT_ON_NEWLINE ) ) ; then
2019-07-17 02:03:56 +08:00
repeat $(( num_left_lines - num_right_lines)) right_segments = ( newline $right_segments )
2019-07-16 22:19:16 +08:00
else
repeat $(( num_left_lines - num_right_lines)) right_segments += newline
fi
local -i num_lines = num_left_lines
fi
2019-11-03 02:03:45 +08:00
local -i i
for i in { 1..$num_lines } ; do
2019-07-16 22:19:16 +08:00
local -i left_end = ${ left_segments [(i)newline] }
local -i right_end = ${ right_segments [(i)newline] }
2019-07-24 20:34:26 +08:00
_p9k_line_segments_left += " ${ (pj : \0 : )left_segments[1,left_end-1] } "
_p9k_line_segments_right += " ${ (pj : \0 : )right_segments[1,right_end-1] } "
2019-07-16 22:19:16 +08:00
( ( left_end > $# left_segments ) ) && left_segments = ( ) || shift left_end left_segments
( ( right_end > $# right_segments ) ) && right_segments = ( ) || shift right_end right_segments
_p9k_get_icon '' LEFT_SEGMENT_SEPARATOR
2020-02-10 19:59:37 +08:00
_p9k_get_icon 'prompt_empty_line' LEFT_PROMPT_LAST_SEGMENT_END_SYMBOL $_p9k__ret
_p9k_escape $_p9k__ret
_p9k_line_prefix_left += '${_p9k__' $i 'l-${${:-${_p9k__bg::=NONE}${_p9k__i::=0}${_p9k__sss::=%f' $_p9k__ret '}}+}'
_p9k_line_suffix_left += '%b%k$_p9k__sss%b%k%f'
2019-07-16 22:19:16 +08:00
2019-11-06 17:22:51 +08:00
_p9k_escape ${ (g : : )_POWERLEVEL9K_EMPTY_LINE_RIGHT_PROMPT_FIRST_SEGMENT_START_SYMBOL }
2020-02-10 19:59:37 +08:00
[ [ -n $_p9k__ret ] ] && _p9k_line_never_empty_right += 1 || _p9k_line_never_empty_right += 0
_p9k_line_prefix_right += '${_p9k__' $i 'r-${${:-${_p9k__bg::=NONE}${_p9k__i::=0}${_p9k__sss::=' $_p9k__ret '}}+}'
_p9k_line_suffix_right += '$_p9k__sss%b%k%f}' # gets overridden for _p9k_emulate_zero_rprompt_indent
2020-02-04 20:07:05 +08:00
if ( ( i = = num_lines ) ) ; then
# it's safe to use _p9k_prompt_length on the last line because it cannot have prompt connection
2020-02-10 19:59:37 +08:00
_p9k_prompt_length ${ (e)_p9k__ret }
( ( _p9k__ret ) ) || _p9k_line_never_empty_right[ -1] = 0
2020-02-04 20:07:05 +08:00
fi
2019-07-16 22:19:16 +08:00
done
_p9k_get_icon '' LEFT_SEGMENT_END_SEPARATOR
2020-02-10 19:59:37 +08:00
if [ [ -n $_p9k__ret ] ] ; then
_p9k__ret += %b%k%f
2019-07-23 04:43:35 +08:00
# Not escaped for historical reasons.
2020-02-10 19:59:37 +08:00
_p9k__ret = '${:-"' $_p9k__ret '"}'
2019-07-23 21:47:25 +08:00
if ( ( _POWERLEVEL9K_PROMPT_ON_NEWLINE ) ) ; then
2020-02-10 19:59:37 +08:00
_p9k_line_suffix_left[ -2] += $_p9k__ret
2019-07-16 22:19:16 +08:00
else
2020-02-10 19:59:37 +08:00
_p9k_line_suffix_left[ -1] += $_p9k__ret
2019-07-16 22:19:16 +08:00
fi
fi
2019-11-03 20:14:16 +08:00
for i in { 1..$num_lines } ; do _p9k_line_suffix_left[ i] += '}' ; done
2019-07-16 22:19:16 +08:00
if ( ( num_lines > 1 ) ) ; then
2019-11-03 02:03:45 +08:00
for i in { 1..$(( num_lines-1)) } ; do
_p9k_build_gap_post $i
2020-02-10 19:59:37 +08:00
_p9k_line_gap_post += $_p9k__ret
2019-11-03 02:03:45 +08:00
done
2019-07-21 16:48:57 +08:00
2019-11-06 17:22:51 +08:00
if [ [ $+_POWERLEVEL9K_MULTILINE_FIRST_PROMPT_PREFIX = = 1 || $_POWERLEVEL9K_PROMPT_ON_NEWLINE = = 1 ] ] ; then
2019-07-16 22:19:16 +08:00
_p9k_get_icon '' MULTILINE_FIRST_PROMPT_PREFIX
2020-02-10 19:59:37 +08:00
if [ [ -n $_p9k__ret ] ] ; then
[ [ _p9k__ret = = *%* ] ] && _p9k__ret += %b%k%f
2019-11-07 17:01:37 +08:00
# Not escaped for historical reasons.
2020-02-10 19:59:37 +08:00
_p9k__ret = '${_p9k__1l_frame-"' $_p9k__ret '"}'
_p9k_line_prefix_left[ 1] = $_p9k__ret $_p9k_line_prefix_left [ 1]
2019-11-07 17:01:37 +08:00
fi
2019-07-16 22:19:16 +08:00
fi
2019-11-06 17:22:51 +08:00
if [ [ $+_POWERLEVEL9K_MULTILINE_LAST_PROMPT_PREFIX = = 1 || $_POWERLEVEL9K_PROMPT_ON_NEWLINE = = 1 ] ] ; then
2019-07-16 22:19:16 +08:00
_p9k_get_icon '' MULTILINE_LAST_PROMPT_PREFIX
2020-02-10 19:59:37 +08:00
if [ [ -n $_p9k__ret ] ] ; then
[ [ _p9k__ret = = *%* ] ] && _p9k__ret += %b%k%f
2019-11-07 17:01:37 +08:00
# Not escaped for historical reasons.
2020-02-10 19:59:37 +08:00
_p9k__ret = '${_p9k__' $num_lines 'l_frame-"' $_p9k__ret '"}'
_p9k_line_prefix_left[ -1] = $_p9k__ret $_p9k_line_prefix_left [ -1]
2019-11-07 17:01:37 +08:00
fi
2019-07-16 22:19:16 +08:00
fi
2019-07-17 16:31:59 +08:00
_p9k_get_icon '' MULTILINE_FIRST_PROMPT_SUFFIX
2020-02-10 19:59:37 +08:00
if [ [ -n $_p9k__ret ] ] ; then
[ [ _p9k__ret = = *%* ] ] && _p9k__ret += %b%k%f
_p9k_line_suffix_right[ 1] += '${_p9k__1r_frame-' ${ (qqq)_p9k__ret } '}'
2019-07-24 20:34:26 +08:00
_p9k_line_never_empty_right[ 1] = 1
2019-07-17 16:31:59 +08:00
fi
_p9k_get_icon '' MULTILINE_LAST_PROMPT_SUFFIX
2020-02-10 19:59:37 +08:00
if [ [ -n $_p9k__ret ] ] ; then
[ [ _p9k__ret = = *%* ] ] && _p9k__ret += %b%k%f
_p9k_line_suffix_right[ -1] += '${_p9k__' $num_lines 'r_frame-' ${ (qqq)_p9k__ret } '}'
2020-02-04 20:07:05 +08:00
# it's safe to use _p9k_prompt_length on the last line because it cannot have prompt connection
2020-02-10 19:59:37 +08:00
_p9k_prompt_length $_p9k__ret
( ( _p9k__ret ) ) && _p9k_line_never_empty_right[ -1] = 1
2019-07-17 16:31:59 +08:00
fi
2019-07-16 22:19:16 +08:00
if ( ( num_lines > 2 ) ) ; then
2019-11-06 17:22:51 +08:00
if [ [ $+_POWERLEVEL9K_MULTILINE_NEWLINE_PROMPT_PREFIX = = 1 || $_POWERLEVEL9K_PROMPT_ON_NEWLINE = = 1 ] ] ; then
2019-07-16 22:19:16 +08:00
_p9k_get_icon '' MULTILINE_NEWLINE_PROMPT_PREFIX
2020-02-10 19:59:37 +08:00
if [ [ -n $_p9k__ret ] ] ; then
[ [ _p9k__ret = = *%* ] ] && _p9k__ret += %b%k%f
2019-11-07 17:01:37 +08:00
for i in { 2..$(( num_lines-1)) } ; do
# Not escaped for historical reasons.
2020-02-10 19:59:37 +08:00
_p9k_line_prefix_left[ i] = '${_p9k__' $i 'l_frame-"' $_p9k__ret '"}' $_p9k_line_prefix_left [ i]
2019-11-07 17:01:37 +08:00
done
fi
2019-07-16 22:19:16 +08:00
fi
2019-07-17 16:31:59 +08:00
_p9k_get_icon '' MULTILINE_NEWLINE_PROMPT_SUFFIX
2020-02-10 19:59:37 +08:00
if [ [ -n $_p9k__ret ] ] ; then
[ [ _p9k__ret = = *%* ] ] && _p9k__ret += %b%k%f
2019-11-03 20:14:16 +08:00
for i in { 2..$(( num_lines-1)) } ; do
2020-02-10 19:59:37 +08:00
_p9k_line_suffix_right[ i] += '${_p9k__' $i 'r_frame-' ${ (qqq)_p9k__ret } '}'
2019-11-03 20:14:16 +08:00
done
2019-07-24 20:34:26 +08:00
_p9k_line_never_empty_right[ 2,-2] = ${ (@)_p9k_line_never_empty_right[2,-2]/0/1 }
2019-07-17 16:31:59 +08:00
fi
2019-07-16 22:19:16 +08:00
fi
fi
}
2019-08-19 18:18:11 +08:00
_p9k_all_params_eq( ) {
local key
for key in ${ parameters [(I) ${ ~1 } ] } ; do
[ [ ${ (P)key } = = $2 ] ] || return
done
}
2019-11-03 02:03:45 +08:00
_p9k_init_display( ) {
2020-01-13 17:21:22 +08:00
_p9k_display_k = ( empty_line 1 ruler 3)
2019-11-03 18:20:52 +08:00
local -i n = 3 i
2019-11-03 02:03:45 +08:00
local name
for i in { 1..$# _p9k_line_segments_left} ; do
2019-11-03 17:00:48 +08:00
local -i j = $(( - $# _p9k_line_segments_left+i-1))
2020-01-13 17:21:22 +08:00
_p9k_display_k += (
2019-11-03 20:14:16 +08:00
$i $(( n += 2 )) $j $n
$i /left_frame $(( n += 2 )) $j /left_frame $n
$i /right_frame $(( n += 2 )) $j /right_frame $n
$i /left $(( n += 2 )) $j /left $n
$i /right $(( n += 2 )) $j /right $n
$i /gap $(( n += 2 )) $j /gap $n )
2020-01-18 22:41:43 +08:00
for name in ${ ${ (@0)_p9k_line_segments_left[i] } %_joined } ; do
2020-01-13 17:21:22 +08:00
_p9k_display_k += ( $i /left/$name $(( n += 2 )) $j /left/$name $n )
2019-11-03 02:03:45 +08:00
done
2020-01-18 22:41:43 +08:00
for name in ${ ${ (@0)_p9k_line_segments_right[i] } %_joined } ; do
2020-01-13 17:21:22 +08:00
_p9k_display_k += ( $i /right/$name $(( n += 2 )) $j /right/$name $n )
2019-11-03 02:03:45 +08:00
done
done
}
2019-07-16 22:19:16 +08:00
_p9k_init_prompt( ) {
2019-11-06 20:56:58 +08:00
_p9k_t = ( $'\n' $'%{\n%}' '' )
2019-11-05 21:08:46 +08:00
_p9k_prompt_overflow_bug && _p9k_t[ 2] = $'%{%G\n%}'
2019-10-16 23:36:54 +08:00
2019-07-16 22:19:16 +08:00
_p9k_init_lines
2020-02-10 19:59:37 +08:00
_p9k_gap_pre = '${${:-${_p9k__x::=0}${_p9k__y::=1024}${_p9k__p::=$_p9k__lprompt$_p9k__rprompt}'
2019-07-16 22:19:16 +08:00
repeat 10; do
2020-02-10 19:59:37 +08:00
_p9k_gap_pre += '${_p9k__m::=$(((_p9k__x+_p9k__y)/2))}'
_p9k_gap_pre += '${_p9k__xy::=${${(%):-$_p9k__p%$_p9k__m(l./$_p9k__m;$_p9k__y./$_p9k__x;$_p9k__m)}##*/}}'
_p9k_gap_pre += '${_p9k__x::=${_p9k__xy%;*}}'
_p9k_gap_pre += '${_p9k__y::=${_p9k__xy#*;}}'
2019-07-16 22:19:16 +08:00
done
2020-02-10 19:59:37 +08:00
_p9k_gap_pre += '${_p9k__m::=$((_p9k__clm-_p9k__x-_p9k__ind-1))}'
2019-07-24 20:34:26 +08:00
_p9k_gap_pre += '}+}'
2019-07-16 22:19:16 +08:00
2020-02-10 19:59:37 +08:00
_p9k_prompt_prefix_left = '${${_p9k__clm::=$COLUMNS}+}${${COLUMNS::=1024}+}'
_p9k_prompt_prefix_right = '${_p9k__' $# _p9k_line_segments_left'-${${_p9k__clm::=$COLUMNS}+}${${COLUMNS::=1024}+}'
_p9k_prompt_suffix_left = '${${COLUMNS::=$_p9k__clm}+}'
_p9k_prompt_suffix_right = '${${COLUMNS::=$_p9k__clm}+}}'
2019-07-16 22:19:16 +08:00
2019-09-25 15:22:34 +08:00
if _p9k_segment_in_use vi_mode || _p9k_segment_in_use prompt_char; then
2019-10-25 19:22:50 +08:00
_p9k_prompt_prefix_left += '${${_p9k__keymap::=${KEYMAP:-$_p9k__keymap}}+}'
2019-09-18 19:38:31 +08:00
fi
if { _p9k_segment_in_use vi_mode && ( ( $+_POWERLEVEL9K_VI_OVERWRITE_MODE_STRING ) ) } ||
{ _p9k_segment_in_use prompt_char && ( ( _POWERLEVEL9K_PROMPT_CHAR_OVERWRITE_STATE ) ) } ; then
2019-10-25 19:22:50 +08:00
_p9k_prompt_prefix_left += '${${_p9k__zle_state::=${ZLE_STATE:-$_p9k__zle_state}}+}'
2019-09-18 19:38:31 +08:00
fi
2019-07-24 20:34:26 +08:00
_p9k_prompt_prefix_left += '%b%k%f'
2019-07-16 22:19:16 +08:00
# Bug fixed in: https://github.com/zsh-users/zsh/commit/3eea35d0853bddae13fa6f122669935a01618bf9.
# If affects most terminals when RPROMPT is non-empty and ZLE_RPROMPT_INDENT is zero.
# We can work around it as long as RPROMPT ends with a space.
2019-07-24 20:34:26 +08:00
if [ [ -n $_p9k_line_segments_right [ -1] && $_p9k_line_never_empty_right [ -1] = = 0 &&
2019-08-19 18:18:11 +08:00
$ZLE_RPROMPT_INDENT = = 0 ] ] &&
2019-11-06 17:22:51 +08:00
_p9k_all_params_eq '_POWERLEVEL9K_*WHITESPACE_BETWEEN_RIGHT_SEGMENTS' ' ' &&
_p9k_all_params_eq '_POWERLEVEL9K_*RIGHT_RIGHT_WHITESPACE' ' ' &&
_p9k_all_params_eq '_POWERLEVEL9K_*RIGHT_PROMPT_LAST_SEGMENT_END_SYMBOL' '' &&
2019-08-19 18:18:11 +08:00
! is-at-least 5.7.2; then
2019-07-24 20:34:26 +08:00
_p9k_emulate_zero_rprompt_indent = 1
2020-02-10 19:59:37 +08:00
_p9k_prompt_prefix_left += '${${:-${_p9k__real_zle_rprompt_indent:=$ZLE_RPROMPT_INDENT}${ZLE_RPROMPT_INDENT::=1}${_p9k__ind::=0}}+}'
_p9k_line_suffix_right[ -1] = '${_p9k__sss:+${_p9k__sss% }%E}}'
2019-07-16 22:19:16 +08:00
else
2019-07-24 20:34:26 +08:00
_p9k_emulate_zero_rprompt_indent = 0
2020-02-10 19:59:37 +08:00
_p9k_prompt_prefix_left += '${${_p9k__ind::=${${ZLE_RPROMPT_INDENT:-1}/#-*/0}}+}'
2019-07-16 22:19:16 +08:00
fi
2019-11-14 17:02:09 +08:00
if [ [ $ITERM_SHELL_INTEGRATION_INSTALLED = = Yes ] ] ; then
_p9k_prompt_prefix_left += $'%{\e]133;A\a%}'
_p9k_prompt_suffix_left += $'%{\e]133;B\a%}'
fi
2019-10-29 22:54:30 +08:00
if ( ( _POWERLEVEL9K_PROMPT_ADD_NEWLINE_COUNT > 0 ) ) ; then
_p9k_t += ${ (pl. $_POWERLEVEL9K_PROMPT_ADD_NEWLINE_COUNT .. \n .) }
else
_p9k_t += ''
fi
_p9k_empty_line_idx = $# _p9k_t
2019-11-03 02:03:45 +08:00
if ( ( __p9k_ksh_arrays ) ) ; then
2019-11-03 19:09:54 +08:00
_p9k_prompt_prefix_left += '${_p9k_t[${_p9k__empty_line_i:-' $# _p9k_t'}-1]}'
2019-11-03 02:03:45 +08:00
else
2019-11-03 19:09:54 +08:00
_p9k_prompt_prefix_left += '${_p9k_t[${_p9k__empty_line_i:-' $# _p9k_t'}]}'
2019-11-03 02:03:45 +08:00
fi
2019-10-29 22:54:30 +08:00
_p9k_get_icon '' RULER_CHAR
2020-02-10 19:59:37 +08:00
local ruler_char = $_p9k__ret
2019-10-29 22:54:30 +08:00
_p9k_prompt_length $ruler_char
2020-02-10 19:59:37 +08:00
( ( _p9k__ret = = 1 && $# ruler_char = = 1 ) ) || ruler_char = ' '
2019-10-29 22:54:30 +08:00
_p9k_color prompt_ruler BACKGROUND ""
2020-02-10 19:59:37 +08:00
if [ [ -z $_p9k__ret && $ruler_char = = ' ' ] ] ; then
2019-10-29 22:54:30 +08:00
local ruler = $'\n'
else
2020-02-10 19:59:37 +08:00
_p9k_background $_p9k__ret
local ruler = %b$_p9k__ret
2019-10-29 22:54:30 +08:00
_p9k_color prompt_ruler FOREGROUND ""
2020-02-10 19:59:37 +08:00
_p9k_foreground $_p9k__ret
ruler += $_p9k__ret
2019-10-29 22:54:30 +08:00
[ [ $ruler_char = = '.' ] ] && local sep = ',' || local sep = '.'
2020-02-10 19:59:37 +08:00
ruler += '${(pl' $sep '${$((_p9k__clm-_p9k__ind))/#-*/0}' $sep $sep $ruler_char $sep ')}%k%f'
2019-10-29 22:54:30 +08:00
if ( ( __p9k_ksh_arrays ) ) ; then
2020-02-10 19:59:37 +08:00
ruler += '${_p9k_t[$((!_p9k__ind))]}'
2019-07-16 22:19:16 +08:00
else
2020-02-10 19:59:37 +08:00
ruler += '${_p9k_t[$((1+!_p9k__ind))]}'
2019-07-16 22:19:16 +08:00
fi
fi
2019-10-29 22:54:30 +08:00
_p9k_t += $ruler
_p9k_ruler_idx = $# _p9k_t
2019-11-03 02:03:45 +08:00
if ( ( __p9k_ksh_arrays ) ) ; then
2019-11-03 19:09:54 +08:00
_p9k_prompt_prefix_left += '${(e)_p9k_t[${_p9k__ruler_i:-' $# _p9k_t'}-1]}'
2019-11-03 02:03:45 +08:00
else
2019-11-03 19:09:54 +08:00
_p9k_prompt_prefix_left += '${(e)_p9k_t[${_p9k__ruler_i:-' $# _p9k_t'}]}'
2019-11-03 02:03:45 +08:00
fi
2019-07-16 22:19:16 +08:00
2019-10-25 19:03:58 +08:00
( _p9k_segment_in_use time && ( ( _POWERLEVEL9K_TIME_UPDATE_ON_COMMAND ) ) )
2019-07-27 18:09:09 +08:00
_p9k_reset_on_line_finish = $(( !$? ))
2019-10-16 23:36:54 +08:00
_p9k_t += $_p9k_gap_pre
2019-10-19 20:55:38 +08:00
_p9k_gap_pre = '${(e)_p9k_t[' $(( $# _p9k_t - __p9k_ksh_arrays)) ']}'
2019-10-16 23:36:54 +08:00
_p9k_t += $_p9k_prompt_prefix_left
2019-10-19 20:55:38 +08:00
_p9k_prompt_prefix_left = '${(e)_p9k_t[' $(( $# _p9k_t - __p9k_ksh_arrays)) ']}'
2019-07-16 22:19:16 +08:00
}
2019-07-20 20:14:42 +08:00
_p9k_init_ssh( ) {
# The following code is based on Pure:
# https://github.com/sindresorhus/pure/blob/e8abf9d37185ec9b7b4398ca9c5eba555a1028eb/pure.zsh.
#
# License: https://github.com/sindresorhus/pure/blob/e8abf9d37185ec9b7b4398ca9c5eba555a1028eb/license.
2019-08-20 17:19:11 +08:00
[ [ -n $P9K_SSH ] ] && return
typeset -gix P9K_SSH = 0
2019-07-20 20:14:42 +08:00
if [ [ -n $SSH_CLIENT || -n $SSH_TTY || -n $SSH_CONNECTION ] ] ; then
2019-08-20 17:19:11 +08:00
P9K_SSH = 1
2019-11-04 16:07:06 +08:00
return 0
2019-07-20 20:14:42 +08:00
fi
# When changing user on a remote system, the $SSH_CONNECTION environment variable can be lost.
# Attempt detection via `who`.
( ( $+commands[ who] ) ) || return
local ipv6 = '(([0-9a-fA-F]+:)|:){2,}[0-9a-fA-F]+' # Simplified, only checks partial pattern.
local ipv4 = '([0-9]{1,3}\.){3}[0-9]+' # Simplified, allows invalid ranges.
# Assume two non-consecutive periods represents a hostname. Matches `x.y.z`, but not `x.y`.
local hostname = '([.][^. ]+){2}'
2019-08-20 17:19:11 +08:00
local w
w = " $( who -m 2>/dev/null) " || w = ${ (@M) ${ (f) " $( who 2>/dev/null) " } : #*[[ : space : ]] ${ TTY #/dev/ } [[ : space : ]]* }
2019-07-20 20:14:42 +08:00
# Usually the remote address is surrounded by parenthesis but not on all systems (e.g., Busybox).
2019-08-20 17:19:11 +08:00
[ [ $w = ~ " \(?( $ipv4 | $ipv6 | $hostname )\)?\$ " ] ] && P9K_SSH = 1
2019-07-20 20:14:42 +08:00
}
2019-07-25 00:34:29 +08:00
_p9k_must_init( ) {
2019-11-21 16:24:29 +08:00
( ( _POWERLEVEL9K_DISABLE_HOT_RELOAD && !_p9k__force_must_init ) ) && return 1
_p9k__force_must_init = 0
2019-10-28 00:16:44 +08:00
local IFS sig
if [ [ -n $_p9k__param_sig ] ] ; then
IFS = $'\2' sig = " ${ (e)_p9k__param_pat } "
[ [ $sig = = $_p9k__param_sig ] ] && return 1
_p9k_deinit
fi
2020-02-20 15:31:53 +08:00
_p9k__param_pat = $'v53\1' ${ ZSH_VERSION } $'\1' ${ ZSH_PATCHLEVEL } $'\1'
2019-10-28 00:16:44 +08:00
_p9k__param_pat += $'${#parameters[(I)POWERLEVEL9K_*]}\1${(%):-%n%#}\1$GITSTATUS_LOG_LEVEL\1'
_p9k__param_pat += $'$GITSTATUS_ENABLE_LOGGING\1$GITSTATUS_DAEMON\1$GITSTATUS_NUM_THREADS\1'
_p9k__param_pat += $'$DEFAULT_USER\1${ZLE_RPROMPT_INDENT:-1}\1$P9K_SSH\1$__p9k_ksh_arrays'
2020-02-18 21:53:12 +08:00
_p9k__param_pat += $'$__p9k_sh_glob\1$ITERM_SHELL_INTEGRATION_INSTALLED\1$commands[uname]'
2019-10-28 00:16:44 +08:00
_p9k__param_pat += $'${PROMPT_EOL_MARK-%B%S%#%s%b}\1$LANG\1$LC_ALL\1$LC_CTYPE\1'
2020-01-13 15:59:14 +08:00
_p9k__param_pat += $'$functions[p10k-on-init]$functions[p10k-on-pre-prompt]\1'
_p9k__param_pat += $'$functions[p10k-on-post-widget]$functions[p10k-on-post-prompt]\1'
2019-10-28 00:16:44 +08:00
local MATCH
IFS = $'\1' _p9k__param_pat += " ${ (@) ${ (@o)parameters[(I)POWERLEVEL9K_*] } : /(#m)*/ \$ { ${ (q)MATCH } - $IFS \} } "
IFS = $'\2' _p9k__param_sig = " ${ (e)_p9k__param_pat } "
2019-07-25 00:34:29 +08:00
}
function _p9k_set_os( ) {
_p9k_os = $1
_p9k_get_icon prompt_os_icon $2
2020-02-10 19:59:37 +08:00
_p9k_os_icon = $_p9k__ret
2019-07-25 00:34:29 +08:00
}
2019-10-03 15:42:02 +08:00
function _p9k_init_cacheable( ) {
2019-06-01 23:54:53 +08:00
_p9k_init_icons
2019-07-23 22:20:59 +08:00
_p9k_init_params
2019-07-16 22:19:16 +08:00
_p9k_init_prompt
2020-01-13 17:21:22 +08:00
_p9k_init_display
2019-06-01 23:54:53 +08:00
2020-01-18 22:41:43 +08:00
local elem func
2020-01-13 00:33:33 +08:00
local -i i = 0
for i in { 1..$# _p9k_line_segments_left} ; do
2020-01-18 22:41:43 +08:00
for elem in ${ ${ (@0)_p9k_line_segments_left[i] } %_joined } ; do
2020-01-13 00:33:33 +08:00
local var = POWERLEVEL9K_${ (U)elem } _SHOW_ON_COMMAND
( ( $+parameters[ $var ] ) ) || continue
2020-01-13 17:21:22 +08:00
_p9k_show_on_command += (
$'(|*[/\0])(' ${ (j.|.) ${ (P)var } } ')'
$(( 1 + _p9k_display_k[ $i / left/$elem ] ))
_p9k__${ i } l$elem )
2020-01-13 00:33:33 +08:00
done
2020-01-18 22:41:43 +08:00
for elem in ${ ${ (@0)_p9k_line_segments_right[i] } %_joined } ; do
2020-01-13 00:33:33 +08:00
local var = POWERLEVEL9K_${ (U)elem } _SHOW_ON_COMMAND
( ( $+parameters[ $var ] ) ) || continue
local cmds = ( ${ (P)var } )
2020-01-13 17:21:22 +08:00
_p9k_show_on_command += (
$'(|*[/\0])(' ${ (j.|.) ${ (P)var } } ')'
$(( 1 + $_p9k_display_k [ $i / right/$elem ] ))
_p9k__${ i } r$elem )
2020-01-13 00:33:33 +08:00
done
done
2019-11-06 16:21:12 +08:00
if [ [ $_POWERLEVEL9K_TRANSIENT_PROMPT != off ] ] ; then
_p9k_transient_prompt = '%b%k%s%u%F{%(?.'
_p9k_color prompt_prompt_char_OK_VIINS FOREGROUND 76
2020-02-10 19:59:37 +08:00
_p9k_transient_prompt += $_p9k__ret '.'
2019-11-06 16:21:12 +08:00
_p9k_color prompt_prompt_char_ERROR_VIINS FOREGROUND 196
2020-02-10 19:59:37 +08:00
_p9k_transient_prompt += $_p9k__ret ')}${${P9K_CONTENT::="❯ "}+}'
2019-11-06 16:21:12 +08:00
_p9k_param prompt_prompt_char_OK_VIINS CONTENT_EXPANSION '${P9K_CONTENT}'
2020-02-10 19:59:37 +08:00
_p9k_transient_prompt += '${:-"' $_p9k__ret '"}%b%k%f%s%u '
2019-11-13 22:04:41 +08:00
if [ [ $ITERM_SHELL_INTEGRATION_INSTALLED = = Yes ] ] ; then
2019-11-13 22:25:48 +08:00
_p9k_transient_prompt = $'%{\e]133;A\a%}' $_p9k_transient_prompt $'%{\e]133;B\a%}'
2019-11-13 22:04:41 +08:00
fi
2019-11-06 16:21:12 +08:00
fi
2019-10-03 15:42:02 +08:00
_p9k_uname = " $( uname) "
[ [ $_p9k_uname = = Linux ] ] && _p9k_uname_o = " $( uname -o 2>/dev/null) "
_p9k_uname_m = " $( uname -m) "
2019-10-13 17:48:29 +08:00
if [ [ $_p9k_uname = = Linux && $_p9k_uname_o = = Android ] ] ; then
2019-07-25 00:34:29 +08:00
_p9k_set_os Android ANDROID_ICON
2019-06-01 23:54:53 +08:00
else
2019-10-03 15:42:02 +08:00
case $_p9k_uname in
2019-07-25 00:34:29 +08:00
SunOS) _p9k_set_os Solaris SUNOS_ICON; ;
Darwin) _p9k_set_os OSX APPLE_ICON; ;
CYGWIN_NT-* | MSYS_NT-*) _p9k_set_os Windows WINDOWS_ICON; ;
FreeBSD| OpenBSD| DragonFly) _p9k_set_os BSD FREEBSD_ICON; ;
2019-06-01 23:54:53 +08:00
Linux)
2019-07-24 20:34:26 +08:00
_p9k_os = 'Linux'
2019-06-01 23:54:53 +08:00
local os_release_id
2019-08-07 17:04:35 +08:00
if [ [ -r /etc/os-release ] ] ; then
local lines = ( ${ (f) " $( </etc/os-release) " } )
lines = ( ${ (@M)lines : #ID=* } )
( ( $# lines = = 1 ) ) && os_release_id = ${ lines [1]#ID= }
fi
case $os_release_id in
2019-07-25 00:34:29 +08:00
*arch*) _p9k_set_os Linux LINUX_ARCH_ICON; ;
*debian*) _p9k_set_os Linux LINUX_DEBIAN_ICON; ;
*raspbian*) _p9k_set_os Linux LINUX_RASPBIAN_ICON; ;
*ubuntu*) _p9k_set_os Linux LINUX_UBUNTU_ICON; ;
*elementary*) _p9k_set_os Linux LINUX_ELEMENTARY_ICON; ;
*fedora*) _p9k_set_os Linux LINUX_FEDORA_ICON; ;
*coreos*) _p9k_set_os Linux LINUX_COREOS_ICON; ;
*gentoo*) _p9k_set_os Linux LINUX_GENTOO_ICON; ;
*mageia*) _p9k_set_os Linux LINUX_MAGEIA_ICON; ;
*centos*) _p9k_set_os Linux LINUX_CENTOS_ICON; ;
*opensuse*| *tumbleweed*) _p9k_set_os Linux LINUX_OPENSUSE_ICON; ;
*sabayon*) _p9k_set_os Linux LINUX_SABAYON_ICON; ;
*slackware*) _p9k_set_os Linux LINUX_SLACKWARE_ICON; ;
*linuxmint*) _p9k_set_os Linux LINUX_MINT_ICON; ;
*alpine*) _p9k_set_os Linux LINUX_ALPINE_ICON; ;
*aosc*) _p9k_set_os Linux LINUX_AOSC_ICON; ;
*nixos*) _p9k_set_os Linux LINUX_NIXOS_ICON; ;
*devuan*) _p9k_set_os Linux LINUX_DEVUAN_ICON; ;
*manjaro*) _p9k_set_os Linux LINUX_MANJARO_ICON; ;
2020-02-20 03:11:18 +08:00
*void*) _p9k_set_os Linux LINUX_VOID_ICON; ;
2019-07-25 00:34:29 +08:00
*) _p9k_set_os Linux LINUX_ICON; ;
2019-06-01 23:54:53 +08:00
esac
; ;
esac
fi
2019-07-23 21:47:25 +08:00
if [ [ $_POWERLEVEL9K_COLOR_SCHEME = = light ] ] ; then
2019-07-24 20:34:26 +08:00
_p9k_color1 = 7
_p9k_color2 = 0
2019-06-01 23:54:53 +08:00
else
2019-07-24 20:34:26 +08:00
_p9k_color1 = 0
_p9k_color2 = 7
2019-06-01 23:54:53 +08:00
fi
2019-07-24 20:34:26 +08:00
# Someone might be using these.
typeset -g OS = $_p9k_os
typeset -g DEFAULT_COLOR = $_p9k_color1
typeset -g DEFAULT_COLOR_INVERTED = $_p9k_color2
_p9k_battery_states = (
2019-07-20 21:40:15 +08:00
'LOW' 'red'
'CHARGING' 'yellow'
'CHARGED' 'green'
2019-07-24 20:34:26 +08:00
'DISCONNECTED' " $_p9k_color2 "
2019-06-15 22:10:51 +08:00
)
2019-10-19 22:01:21 +08:00
# This simpler construct doesn't work on zsh-5.1 with multi-line prompt:
#
# ${(@0)_p9k_line_segments_left[@]}
local -a left_segments = ( ${ (@0) ${ (pj : \0 : )_p9k_line_segments_left } } )
2019-07-25 00:34:29 +08:00
_p9k_left_join = ( 1)
2019-07-16 22:19:16 +08:00
for ( ( i = 2; i <= $# left_segments; ++i) ) ; do
2020-01-13 00:33:33 +08:00
elem = $left_segments [ i]
2019-06-01 23:54:53 +08:00
if [ [ $elem = = *_joined ] ] ; then
2019-07-24 20:34:26 +08:00
_p9k_left_join += $_p9k_left_join [ ( ( i-1) ) ]
2019-06-01 23:54:53 +08:00
else
2019-07-24 20:34:26 +08:00
_p9k_left_join += $i
2019-06-01 23:54:53 +08:00
fi
done
2019-10-19 22:01:21 +08:00
local -a right_segments = ( ${ (@0) ${ (pj : \0 : )_p9k_line_segments_right } } )
2019-07-25 00:34:29 +08:00
_p9k_right_join = ( 1)
2019-07-16 22:19:16 +08:00
for ( ( i = 2; i <= $# right_segments; ++i) ) ; do
2020-01-13 00:33:33 +08:00
elem = $right_segments [ i]
2019-06-01 23:54:53 +08:00
if [ [ $elem = = *_joined ] ] ; then
2019-07-24 20:34:26 +08:00
_p9k_right_join += $_p9k_right_join [ ( ( i-1) ) ]
2019-06-01 23:54:53 +08:00
else
2019-07-24 20:34:26 +08:00
_p9k_right_join += $i
2019-06-01 23:54:53 +08:00
fi
done
2019-10-03 15:42:02 +08:00
case $_p9k_os in
OSX) ( ( $+commands[ sysctl] ) ) && _p9k_num_cpus = " $( sysctl -n hw.logicalcpu 2>/dev/null) " ; ;
BSD) ( ( $+commands[ sysctl] ) ) && _p9k_num_cpus = " $( sysctl -n hw.ncpu 2>/dev/null) " ; ;
*) ( ( $+commands[ nproc] ) ) && _p9k_num_cpus = " $( nproc 2>/dev/null) " ; ;
esac
2020-01-18 23:42:00 +08:00
( ( _p9k_num_cpus ) ) || _p9k_num_cpus = 1
2019-10-03 15:42:02 +08:00
if _p9k_segment_in_use dir; then
if ( ( $+_POWERLEVEL9K_DIR_CLASSES ) ) ; then
local -i i = 3
for ( ( ; i <= $# _POWERLEVEL9K_DIR_CLASSES; i += 3) ) ; do
_POWERLEVEL9K_DIR_CLASSES[ i] = ${ (g : : )_POWERLEVEL9K_DIR_CLASSES[i] }
done
else
typeset -ga _POWERLEVEL9K_DIR_CLASSES = ( )
_p9k_get_icon prompt_dir_ETC ETC_ICON
2020-02-10 19:59:37 +08:00
_POWERLEVEL9K_DIR_CLASSES += ( '/etc|/etc/*' ETC " $_p9k__ret " )
2019-10-03 15:42:02 +08:00
_p9k_get_icon prompt_dir_HOME HOME_ICON
2020-02-10 19:59:37 +08:00
_POWERLEVEL9K_DIR_CLASSES += ( '~' HOME " $_p9k__ret " )
2019-10-03 15:42:02 +08:00
_p9k_get_icon prompt_dir_HOME_SUBFOLDER HOME_SUB_ICON
2020-02-10 19:59:37 +08:00
_POWERLEVEL9K_DIR_CLASSES += ( '~/*' HOME_SUBFOLDER " $_p9k__ret " )
2019-10-03 15:42:02 +08:00
_p9k_get_icon prompt_dir_DEFAULT FOLDER_ICON
2020-02-10 19:59:37 +08:00
_POWERLEVEL9K_DIR_CLASSES += ( '*' DEFAULT " $_p9k__ret " )
2019-10-03 15:42:02 +08:00
fi
fi
if _p9k_segment_in_use status; then
typeset -g _p9k_exitcode2str = ( { 0..255} )
local -i i = 2
if ( ( !_POWERLEVEL9K_STATUS_HIDE_SIGNAME ) ) ; then
for ( ( ; i <= $# signals; ++i) ) ; do
local sig = $signals [ i]
( ( _POWERLEVEL9K_STATUS_VERBOSE_SIGNAME ) ) && sig = " SIG ${ sig } ( $(( i-1)) ) "
_p9k_exitcode2str[ $(( 128 + i)) ] = $sig
done
fi
fi
}
2019-10-04 02:14:16 +08:00
_p9k_init_vcs( ) {
_p9k_segment_in_use vcs || return
_p9k_vcs_info_init
if ( ( $+functions[ _p9k_preinit] ) ) ; then
2019-10-25 19:22:50 +08:00
( ( $+GITSTATUS_DAEMON_PID_POWERLEVEL9K ) ) && gitstatus_start POWERLEVEL9K || _p9k__gitstatus_disabled = 1
2019-11-04 16:07:06 +08:00
return 0
2019-10-04 02:14:16 +08:00
fi
2019-10-07 17:32:00 +08:00
if ( ( _POWERLEVEL9K_DISABLE_GITSTATUS ) ) ; then
2019-10-25 19:22:50 +08:00
_p9k__gitstatus_disabled = 1
2019-11-04 16:07:06 +08:00
return 0
2019-10-07 17:32:00 +08:00
fi
2019-10-04 02:14:16 +08:00
( ( $_POWERLEVEL9K_VCS_BACKENDS [ ( I) git] ) ) || return
local gitstatus_dir = ${ _POWERLEVEL9K_GITSTATUS_DIR :- ${ __p9k_root_dir } /gitstatus }
2020-01-18 17:41:44 +08:00
if [ [ -z $GITSTATUS_DAEMON && $_p9k_uname_m = = ( i686| arm7l) && -z $gitstatus_dir /bin/*-$_p9k_uname_m ( -static| ) ( #qN) ]]; then
2019-10-25 19:22:50 +08:00
_p9k__gitstatus_disabled = 1
2019-10-04 02:14:16 +08:00
>& 2 echo -E - " ${ (%) :- [%1FERROR%f] : %BPowerlevel10k%b is unable to use %Bgitstatus%b. Git prompt will be slow. } "
>& 2 echo -E - ""
2020-01-18 17:41:44 +08:00
>& 2 echo -E - " ${ (%) :- Reason : There is no %Bgitstatusd%b binary for $_p9k_uname_m (32-bit architecture). } "
2019-10-04 02:14:16 +08:00
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- You can : } "
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- - Do nothing. } "
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- * You %Bwill%b see this error message every time you start zsh. } "
>& 2 echo -E - " ${ (%) :- * Git prompt will be %Bslow%b. } "
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- - Set %BPOWERLEVEL9K_DISABLE_GITSTATUS=true%b at the bottom of %B $__p9k_zshrc_u %b. } "
>& 2 echo -E - " ${ (%) :- You can do this by running the following command : } "
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- %2Fecho%f %3F 'POWERLEVEL9K_DISABLE_GITSTATUS=true' %f >>! $__p9k_zshrc_u } "
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- * You %Bwill not%b see this error message again. } "
>& 2 echo -E - " ${ (%) :- * Git prompt will be %Bslow%b. } "
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- - Upgrade to a 64-bit OS. } "
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- * You %Bwill not%b see this error message again. } "
>& 2 echo -E - " ${ (%) :- * Git prompt will be %Bfast%b. } "
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- - Compile %Bgitstatusd%b and set %BGITSTATUS_DAEMON=/path/to/gitstatusd%b at } "
>& 2 echo -E - " ${ (%) :- the bottom of %B $__p9k_zshrc_u %b. See instructions at } "
>& 2 echo -E - " ${ (%) :- https : //github.com/romkatv/gitstatus/blob/master/README.md#compiling. } "
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- * You %Bwill not%b see this error message again. } "
>& 2 echo -E - " ${ (%) :- * Git prompt will be %Bfast%b. } "
2019-11-04 16:07:06 +08:00
return 0
2019-10-04 02:14:16 +08:00
fi
local daemon = ${ GITSTATUS_DAEMON }
if [ [ -z $daemon ] ] ; then
daemon = $gitstatus_dir /bin/gitstatusd-
2019-11-05 02:43:07 +08:00
if [ [ $_p9k_uname_o = = Android ] ] ; then
daemon += android
2019-11-13 19:01:20 +08:00
elif [ [ ${ (L)_p9k_uname } = = ( mingw| msys) * ] ] ; then
2019-11-05 02:43:07 +08:00
daemon += msys_nt-10.0
else
daemon += ${ _p9k_uname : l }
fi
2019-10-04 02:14:16 +08:00
daemon += -${ _p9k_uname_m : l }
fi
local -i threads = ${ GITSTATUS_NUM_THREADS :- 0 }
if ( ( threads <= 0 ) ) ; then
threads = $(( _p9k_num_cpus * 2 ))
( ( threads > 0 ) ) || threads = 8
( ( threads <= 32 ) ) || threads = 32
fi
2019-10-06 16:29:23 +08:00
typeset -g _p9k_preinit = " function _p9k_preinit() {
2019-11-29 18:14:10 +08:00
[ [ \$ ZSH_VERSION = = ${ (q)ZSH_VERSION } ] ] || return
2019-10-08 19:02:44 +08:00
[ [ -r ${ (q)gitstatus_dir } /gitstatus.plugin.zsh ] ] || return
source ${ (q)gitstatus_dir } /gitstatus.plugin.zsh || return
GITSTATUS_DAEMON = ${ (q)daemon } GITSTATUS_NUM_THREADS = $threads \
GITSTATUS_LOG_LEVEL = ${ (q)GITSTATUS_LOG_LEVEL } \
GITSTATUS_ENABLE_LOGGING = ${ (q)GITSTATUS_ENABLE_LOGGING } gitstatus_start \
-s $_POWERLEVEL9K_VCS_STAGED_MAX_NUM \
-u $_POWERLEVEL9K_VCS_UNSTAGED_MAX_NUM \
-d $_POWERLEVEL9K_VCS_UNTRACKED_MAX_NUM \
-c $_POWERLEVEL9K_VCS_CONFLICTED_MAX_NUM \
-m $_POWERLEVEL9K_VCS_MAX_INDEX_SIZE_DIRTY \
2019-10-24 20:16:40 +08:00
${ ${ _POWERLEVEL9K_VCS_RECURSE_UNTRACKED_DIRS : #0 } : +-e } \
2019-10-08 19:02:44 +08:00
-a POWERLEVEL9K
2019-10-04 02:14:16 +08:00
} "
source ${ gitstatus_dir } /gitstatus.plugin.zsh
GITSTATUS_DAEMON = $daemon GITSTATUS_NUM_THREADS = $threads gitstatus_start \
2019-10-24 20:16:40 +08:00
-s $_POWERLEVEL9K_VCS_STAGED_MAX_NUM \
-u $_POWERLEVEL9K_VCS_UNSTAGED_MAX_NUM \
-d $_POWERLEVEL9K_VCS_UNTRACKED_MAX_NUM \
-c $_POWERLEVEL9K_VCS_CONFLICTED_MAX_NUM \
-m $_POWERLEVEL9K_VCS_MAX_INDEX_SIZE_DIRTY \
${ ${ _POWERLEVEL9K_VCS_RECURSE_UNTRACKED_DIRS : #0 } : +-e } \
2019-10-25 19:22:50 +08:00
POWERLEVEL9K || _p9k__gitstatus_disabled = 1
2019-10-04 02:14:16 +08:00
}
2019-10-03 15:42:02 +08:00
_p9k_init( ) {
_p9k_init_vars
_p9k_restore_state || _p9k_init_cacheable
2020-01-26 01:04:06 +08:00
local -i i
local elem
2020-02-10 19:59:37 +08:00
_p9k__prompt_side = left
_p9k__segment_index = 1
2020-01-26 01:04:06 +08:00
for i in { 1..$# _p9k_line_segments_left} ; do
for elem in ${ ${ (@0)_p9k_line_segments_left[i] } %_joined } ; do
local f_init = _p9k_prompt_${ elem } _init
( ( $+functions[ $f_init ] ) ) && $f_init
2020-02-10 19:59:37 +08:00
( ( ++_p9k__segment_index ) )
2020-01-26 01:04:06 +08:00
done
2020-01-21 03:12:05 +08:00
done
2020-02-10 19:59:37 +08:00
_p9k__prompt_side = right
_p9k__segment_index = 1
2020-01-26 01:04:06 +08:00
for i in { 1..$# _p9k_line_segments_right} ; do
for elem in ${ ${ (@0)_p9k_line_segments_right[i] } %_joined } ; do
local f_init = _p9k_prompt_${ elem } _init
( ( $+functions[ $f_init ] ) ) && $f_init
2020-02-10 19:59:37 +08:00
( ( ++_p9k__segment_index ) )
2020-01-26 01:04:06 +08:00
done
done
if [ [ -n $_POWERLEVEL9K_PUBLIC_IP_VPN_INTERFACE ||
-n $_POWERLEVEL9K_IP_INTERFACE ||
-n $_POWERLEVEL9K_VPN_IP_INTERFACE ] ] ; then
_p9k_prompt_net_iface_init
fi
2020-01-21 03:12:05 +08:00
( ( $# _p9k__async_segments_compute ) ) && _p9k_worker_start
2020-01-18 22:41:43 +08:00
2020-01-13 17:21:22 +08:00
local k v
for k v in ${ (kv)_p9k_display_k } ; do
[ [ $k = = -* ] ] && continue
_p9k__display_v[ v] = $k
_p9k__display_v[ v+1] = show
done
_p9k__display_v[ 2] = hide
_p9k__display_v[ 4] = hide
2019-11-03 02:03:45 +08:00
2019-11-13 22:01:00 +08:00
if ( ( $+functions[ iterm2_decorate_prompt] ) ) ; then
_p9k__iterm2_decorate_prompt = $functions [ iterm2_decorate_prompt]
function iterm2_decorate_prompt( ) {
2019-11-13 22:33:17 +08:00
typeset -g ITERM2_PRECMD_PS1 = $PROMPT
2019-11-13 22:01:00 +08:00
typeset -g ITERM2_SHOULD_DECORATE_PROMPT =
}
fi
if ( ( $+functions[ iterm2_precmd] ) ) ; then
_p9k__iterm2_precmd = $functions [ iterm2_precmd]
2019-11-13 22:08:48 +08:00
functions[ iterm2_precmd] = 'local _p9k_status=$?; zle && return; () { return $_p9k_status; }; ' $_p9k__iterm2_precmd
2019-11-13 22:01:00 +08:00
fi
2019-07-25 03:07:28 +08:00
if _p9k_segment_in_use todo; then
2019-07-24 20:34:26 +08:00
local todo = $commands [ todo.sh]
if [ [ -n $todo ] ] ; then
local bash = ${ commands [bash] :- : }
2020-02-10 19:59:37 +08:00
_p9k__todo_file = " $( exec -a $todo $bash 2>/dev/null -c "
2019-07-24 20:34:26 +08:00
[ -e \" \$ TODOTXT_CFG_FILE\" ] || TODOTXT_CFG_FILE = \$ HOME/.todo/config
[ -e \" \$ TODOTXT_CFG_FILE\" ] || TODOTXT_CFG_FILE = \$ HOME/todo.cfg
[ -e \" \$ TODOTXT_CFG_FILE\" ] || TODOTXT_CFG_FILE = \$ HOME/.todo.cfg
[ -e \" \$ TODOTXT_CFG_FILE\" ] || TODOTXT_CFG_FILE = \$ { XDG_CONFIG_HOME:-\$ HOME/.config} /todo/config
[ -e \" \$ TODOTXT_CFG_FILE\" ] || TODOTXT_CFG_FILE = ${ (qqq)todo : h } /todo.cfg
[ -e \" \$ TODOTXT_CFG_FILE\" ] || TODOTXT_CFG_FILE = \$ { TODOTXT_GLOBAL_CFG_FILE:-/etc/todo/config}
[ -r \" \$ TODOTXT_CFG_FILE\" ] || exit
source \" \$ TODOTXT_CFG_FILE\" & >/dev/null
2019-07-29 20:18:57 +08:00
echo \" \$ TODO_FILE\" ")"
2019-07-24 20:34:26 +08:00
fi
fi
2019-07-25 03:07:28 +08:00
if _p9k_segment_in_use dir &&
2019-07-23 21:47:25 +08:00
[ [ $_POWERLEVEL9K_SHORTEN_STRATEGY = = truncate_with_package_name && $+commands[ jq] = = 0 ] ] ; then
2019-08-05 16:37:04 +08:00
print -rP -- '%F{yellow}WARNING!%f %BPOWERLEVEL9K_SHORTEN_STRATEGY=truncate_with_package_name%b requires %F{green}jq%f.'
print -rP -- 'Either install %F{green}jq%f or change the value of %BPOWERLEVEL9K_SHORTEN_STRATEGY%b.'
2019-06-01 23:54:53 +08:00
fi
2019-10-04 02:14:16 +08:00
_p9k_init_vcs
2019-10-19 18:33:39 +08:00
if ( ( _POWERLEVEL9K_DISABLE_INSTANT_PROMPT ) ) ; then
unset __p9k_instant_prompt_erased
2019-10-27 02:43:38 +08:00
zf_rm -f -- ${ __p9k_dump_file : h } /p10k-instant-prompt-${ (%) :- %n } .zsh{ ,.zwc} 2>/dev/null
2019-10-19 18:33:39 +08:00
fi
if ( ( $+__p9k_instant_prompt_erased ) ) ; then
unset __p9k_instant_prompt_erased
2019-10-20 16:15:35 +08:00
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- [%1FERROR%f] : When using instant prompt, Powerlevel10k must be loaded before the first prompt. } "
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- You can : } "
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- - %BRecommended%b : Change the way Powerlevel10k is loaded from %B $__p9k_zshrc_u %b. } "
>& 2 echo - " ${ (%) :- See \e ]8;;https : //github.com/romkatv/powerlevel10k/blob/master/README.md#installation \a https : //github.com/romkatv/powerlevel10k/blob/master/README.md#installation \e ]8;; \a . } "
2019-10-20 22:46:05 +08:00
if ( ( $+functins[ zplugin] ) ) ; then
2019-10-20 16:15:35 +08:00
>& 2 echo -E - " ${ (%) :- NOTE : If using %2Fzplugin%f to load %3F 'romkatv/powerlevel10k' %f, %Bdo not apply%b %1Fice wait%f. } "
2019-10-19 18:33:39 +08:00
fi
2019-10-20 16:15:35 +08:00
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- * You %Bwill not%b see this error message again. } "
>& 2 echo -E - " ${ (%) :- * Zsh will start %Bquickly%b. } "
>& 2 echo -E - ""
2019-10-27 02:43:38 +08:00
>& 2 echo -E - " ${ (%) :- - Disable instant prompt either by running %Bp10k configure%b or by manually } "
>& 2 echo -E - " ${ (%) :- defining the following parameter : } "
2019-10-20 16:15:35 +08:00
>& 2 echo -E - ""
2019-10-27 02:43:38 +08:00
>& 2 echo -E - " ${ (%) :- %3Ftypeset%f -g POWERLEVEL9K_INSTANT_PROMPT=off } "
2019-10-20 16:15:35 +08:00
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- * You %Bwill not%b see this error message again. } "
>& 2 echo -E - " ${ (%) :- * Zsh will start %Bslowly%b. } "
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- - Do nothing. } "
>& 2 echo -E - ""
>& 2 echo -E - " ${ (%) :- * You %Bwill%b see this error message every time you start zsh. } "
>& 2 echo -E - " ${ (%) :- * Zsh will start %Bslowly%b. } "
>& 2 echo -E - ""
2019-10-19 18:33:39 +08:00
fi
2019-07-25 00:34:29 +08:00
}
2019-06-01 23:54:53 +08:00
2019-07-25 00:34:29 +08:00
_p9k_deinit( ) {
2019-10-25 00:01:44 +08:00
( ( $+functions[ _p9k_preinit] ) ) && unfunction _p9k_preinit
2019-07-25 00:34:29 +08:00
( ( $+functions[ gitstatus_stop] ) ) && gitstatus_stop POWERLEVEL9K
2020-01-18 22:41:43 +08:00
_p9k_worker_stop
2020-02-10 21:10:18 +08:00
( ( _p9k__state_dump_fd ) ) && exec { _p9k__state_dump_fd} >& -
2019-11-13 22:01:00 +08:00
( ( $+_p9k__iterm2_precmd ) ) && functions[ iterm2_precmd] = $_p9k__iterm2_precmd
( ( $+_p9k__iterm2_decorate_prompt ) ) && functions[ iterm2_decorate_prompt] = $_p9k__iterm2_decorate_prompt
2019-11-03 20:36:49 +08:00
unset -m '(_POWERLEVEL9K_|P9K_|_p9k_)*~(P9K_SSH|P9K_TTY)'
2020-02-20 15:31:53 +08:00
[ [ -n $__p9k_locale ] ] || unset __p9k_locale
2019-06-01 23:54:53 +08:00
}
2019-07-24 21:52:54 +08:00
typeset -gi __p9k_enabled = 0
2019-07-30 21:11:58 +08:00
typeset -gi __p9k_configured = 0
2019-10-18 22:22:11 +08:00
typeset -gri __p9k_instant_prompt_disabled = 1
2019-07-24 21:52:54 +08:00
2019-10-19 20:55:38 +08:00
# `typeset -g` doesn't roundtrip in zsh prior to 5.4.
if is-at-least 5.4; then
typeset -gri __p9k_dumps_enabled = 1
else
typeset -gri __p9k_dumps_enabled = 0
fi
2019-11-08 20:57:20 +08:00
_p9k_do_nothing( ) { true; }
2020-01-27 16:33:01 +08:00
_p9k_setup( ) {
2019-10-25 00:02:57 +08:00
( ( __p9k_enabled ) ) && return
2019-10-20 15:34:42 +08:00
prompt_opts = ( percent subst)
2020-01-26 23:54:52 +08:00
if ( ( ! $+__p9k_instant_prompt_active ) ) ; then
prompt_opts += sp
prompt_opts += cr
fi
2019-10-20 15:34:42 +08:00
2019-06-01 23:54:53 +08:00
prompt_powerlevel9k_teardown
2019-07-24 21:52:54 +08:00
__p9k_enabled = 1
2020-01-20 16:57:03 +08:00
typeset -ga preexec_functions = ( _p9k_preexec1 $preexec_functions _p9k_preexec2)
2019-11-12 18:03:49 +08:00
typeset -ga precmd_functions = ( _p9k_do_nothing $precmd_functions _p9k_precmd)
2019-06-01 23:54:53 +08:00
}
2020-02-15 16:25:44 +08:00
prompt_powerlevel9k_setup( ) {
eval " $__p9k_intro "
_p9k_setup
}
2020-01-27 16:33:01 +08:00
2019-06-01 23:54:53 +08:00
prompt_powerlevel9k_teardown( ) {
2020-02-02 05:03:42 +08:00
eval " $__p9k_intro "
2019-07-25 03:07:28 +08:00
add-zsh-hook -D precmd '(_p9k_|powerlevel9k_)*'
add-zsh-hook -D preexec '(_p9k_|powerlevel9k_)*'
2019-06-01 23:54:53 +08:00
PROMPT = '%m%# '
RPROMPT =
2019-07-24 21:52:54 +08:00
if ( ( __p9k_enabled ) ) ; then
2019-07-25 00:34:29 +08:00
_p9k_deinit
2019-07-24 21:52:54 +08:00
__p9k_enabled = 0
fi
2019-06-01 23:54:53 +08:00
}
2019-08-01 01:41:14 +08:00
typeset -gr __p9k_p10k_usage = " Usage: %2Fp10k%f %Bcommand%b [options]
Commands:
%Bconfigure%b run interactive configuration wizard
2019-11-21 16:24:29 +08:00
%Breload%b reload configuration
2019-08-01 01:41:14 +08:00
%Bsegment%b print a user-defined prompt segment
2019-10-29 05:12:42 +08:00
%Bdisplay%b show, hide or toggle prompt parts
%Bhelp%b print this help message
Print help for a specific command:
%2Fp10k%f %Bhelp%b command"
2019-08-01 01:41:14 +08:00
2019-08-01 01:54:49 +08:00
typeset -gr __p9k_p10k_segment_usage = " Usage: %2Fp10k%f %Bsegment%b [-h] [{+|-}re] [-s state] [-b bg] [-f fg] [-i icon] [-c cond] [-t text]
2019-08-01 01:41:14 +08:00
2019-08-01 01:54:49 +08:00
Print a user-defined prompt segment. Can be called only during prompt rendering.
2019-08-01 01:41:14 +08:00
Options:
-t text segment's main content; will undergo prompt expansion: ' %%F{ blue} %%*%%f' will
show as %F{ blue} %*%f; default is empty
-i icon segment' s icon; default is empty
-r icon is a symbolic reference that needs to be resolved; for example, 'LOCK_ICON'
+r icon is already resolved and should be printed literally; for example, '⭐' ;
this is the default; you can also use \$ '\u2B50' if you don' t want to have
non-ascii characters in source code
-b bg background color; for example, 'blue' , '4' , or '#0000ff' ; empty value means
transparent background, as in '%%k' ; default is black
-f fg foreground color; for example, 'blue' , '4' , or '#0000ff' ; empty value means
default foreground color, as in '%%f' ; default is empty
-s state segment' s state for the purpose of applying styling options; if you want to
to be able to use POWERLEVEL9K parameters to specify different colors or icons
depending on some property, use different states for different values of that
property
-c condition; if empty after parameter expansion and process substitution, the
segment is hidden; this is an advanced feature, use with caution; default is '1'
-e segment' s main content will undergo parameter expansion and process
substitution; the content will be surrounded with double quotes and thus
should quote its own double quotes; this is an advanced feature, use with
caution
+e segment' s main content should not undergo parameter expansion and process
substitution; this is the default
-h print this help message
Example: 'core' segment tells you if there is a file name 'core' in the current directory.
- Segment's icon is ' ⭐' .
- Segment's text is the file' s size in bytes.
- If you have permissions to delete the file, state is DELETABLE. If not, it' s PROTECTED.
zmodload -F zsh/stat b:zstat
function prompt_core( ) {
local size = ( )
if ! zstat -A size +size core 2>/dev/null; then
# No 'core' file in the current directory.
return
fi
if [ [ -w . ] ] ; then
local state = DELETABLE
else
local state = PROTECTED
fi
2020-01-26 23:54:52 +08:00
p10k segment -s \$ state -i '⭐' -f blue -t \$ { size[ 1] } b
2019-08-01 01:41:14 +08:00
}
To enable this segment, add 'core' to POWERLEVEL9K_LEFT_PROMPT_ELEMENTS or
POWERLEVEL9K_RIGHT_PROMPT_ELEMENTS.
Example customizations:
2019-08-01 01:54:49 +08:00
# Override default foreground.
2019-08-01 01:41:14 +08:00
POWERLEVEL9K_CORE_FOREGROUND = red
2019-08-01 01:54:49 +08:00
# Override foreground when DELETABLE.
2019-08-01 01:41:14 +08:00
POWERLEVEL9K_CORE_DELETABLE_BACKGROUND = green
# Override icon when PROTECTED.
POWERLEVEL9K_CORE_PROTECTED_VISUAL_IDENTIFIER_EXPANSION = '❎'
# Don't show file size when PROTECTED.
POWERLEVEL9K_CORE_PROTECTED_CONTENT_EXPANSION = '' "
typeset -gr __p9k_p10k_configure_usage = " Usage: %2Fp10k%f %Bconfigure%b
Run interactive configuration wizard."
2019-11-21 16:24:29 +08:00
typeset -gr __p9k_p10k_reload_usage = " Usage: %2Fp10k%f %Breload%b
Reload configuration."
2019-10-27 02:43:38 +08:00
typeset -gr __p9k_p10k_finalize_usage = " Usage: %2Fp10k%f %Bfinalize%b
Perform the final stage of initialization. Must be called at the very end of zshrc."
2019-11-07 16:27:10 +08:00
typeset -gr __p9k_p10k_display_usage = " Usage: %2Fp10k%f %Bdisplay%b part-pattern=state-list...
2019-10-29 05:12:42 +08:00
Show, hide or toggle prompt parts. If called from zle, the current
2019-11-07 16:27:10 +08:00
prompt is refreshed.
2019-10-29 05:12:42 +08:00
2020-01-13 02:37:06 +08:00
Usage: %2Fp10k%f %Bdisplay%b -a [ part-pattern] ...
2020-01-26 23:54:52 +08:00
Populate array \` reply\` with states of prompt parts matching the patterns.
If no patterns are supplied, assume \` *\` .
2020-01-13 02:37:06 +08:00
2019-10-29 05:12:42 +08:00
Parts:
2019-11-07 16:27:10 +08:00
empty_line empty line ( duh)
2020-01-13 02:37:06 +08:00
ruler ruler; if POWERLEVEL9K_RULER_CHAR = ' ' , it' s essentially another
new_line
2019-11-07 16:27:10 +08:00
N prompt line number N, 1-based; counting from the top if positive,
from the bottom if negative
N/left_frame left frame on the Nth line
N/left left prompt on the Nth line
N/gap gap between left and right prompts on the Nth line
N/right right prompt on the Nth line
N/right_frame right frame on the Nth line
N/left/S segment S within N/left ( dir, time, etc.)
N/right/S segment S within N/right ( dir, time, etc.)
Part States:
show the part is displayed
hide the part is not displayed
print the part is printed in precmd; only applicable to empty_line and
2020-01-26 23:54:52 +08:00
ruler; looks better than show after calling \` clear\` ; unlike
2020-01-13 02:37:06 +08:00
show, the effects of print cannot be undone with hide
part-pattern is a glob pattern for parts. Examples:
*/kubecontext all kubecontext prompt segments, regardless of where
they are
1/( right| right_frame) all prompt segments and frame from the right side of
the first line
state-list is a comma-separated list of states. Must have at least one element.
If more than one, states will rotate.
2019-10-29 05:12:42 +08:00
Example: Bind Ctrl+P to toggle right prompt.
2019-11-07 16:27:10 +08:00
function toggle-right-prompt( ) { p10k display '*/right' = hide,show; }
2019-10-29 05:12:42 +08:00
zle -N toggle-right-prompt
2020-01-13 02:37:06 +08:00
bindkey '^P' toggle-right-prompt
Example: Print the state of all prompt parts:
local -A reply
p10k display -a '*'
2020-01-26 23:54:52 +08:00
printf '%%32s = %%q\\n' \$ { ( @kv) reply}
2020-01-13 02:37:06 +08:00
"
2019-10-29 05:12:42 +08:00
2019-11-02 21:18:57 +08:00
# 0 -- reset-prompt not blocked
# 1 -- reset-prompt blocked and not needed
# 2 -- reset-prompt blocked and needed
typeset -gi __p9k_reset_state
2019-08-01 00:21:37 +08:00
function p10k( ) {
2019-11-04 16:07:06 +08:00
[ [ $# != 1 || $1 != finalize ] ] || { p10k-instant-prompt-finalize; return 0 }
2019-10-27 02:43:38 +08:00
2020-02-12 18:15:12 +08:00
eval " $__p9k_intro_no_reply "
2019-08-01 01:41:14 +08:00
if ( ( !ARGC ) ) ; then
2019-08-05 16:37:04 +08:00
print -rP -- $__p9k_p10k_usage >& 2
2019-08-01 00:21:37 +08:00
return 1
fi
2019-08-01 01:41:14 +08:00
case $1 in
segment)
2020-02-12 18:15:12 +08:00
local REPLY
local -a reply
2019-08-01 01:41:14 +08:00
shift
2020-01-13 02:37:06 +08:00
local -i OPTIND
local OPTARG opt state bg = 0 fg icon cond text ref = 0 expand = 0
2019-08-01 01:41:14 +08:00
while getopts ':s:b:f:i:c:t:reh' opt; do
case $opt in
s) state = $OPTARG ; ;
b) bg = $OPTARG ; ;
f) fg = $OPTARG ; ;
i) icon = $OPTARG ; ;
c) cond = ${ OPTARG :- '${:-}' } ; ;
t) text = $OPTARG ; ;
r) ref = 1; ;
e) expand = 1; ;
+r) ref = 0; ;
+e) expand = 0; ;
2019-08-05 16:37:04 +08:00
h) print -rP -- $__p9k_p10k_segment_usage ; return 0; ;
?) print -rP -- $__p9k_p10k_segment_usage >& 2; return 1; ;
2019-08-01 01:41:14 +08:00
esac
done
if ( ( OPTIND <= ARGC ) ) ; then
2019-08-05 16:37:04 +08:00
print -rP -- $__p9k_p10k_segment_usage >& 2
2019-08-01 01:54:49 +08:00
return 1
fi
2020-02-10 19:59:37 +08:00
if [ [ -z $_p9k__prompt_side ] ] ; then
2019-08-05 16:37:04 +08:00
print -rP -- "%1F[ERROR]%f %Bp10k segment%b: can be called only during prompt rendering." >& 2
2019-08-01 01:54:49 +08:00
if ( ( !ARGC ) ) ; then
2019-08-05 16:37:04 +08:00
print -rP -- ""
print -rP -- "For help, type:" >& 2
print -rP -- ""
print -rP -- " %2Fp10k%f %Bhelp%b %Bsegment%b" >& 2
2019-08-01 01:54:49 +08:00
fi
2019-08-01 01:41:14 +08:00
return 1
fi
( ( ref ) ) || icon = $'\1' $icon
2020-02-12 22:45:23 +08:00
typeset -i _p9k__has_upglob
2020-02-10 19:59:37 +08:00
" _p9k_ ${ _p9k__prompt_side } _prompt_segment " " prompt_ ${ _p9k__segment_name } ${ state : +_ ${ (U)state } } " \
2019-08-01 01:41:14 +08:00
" $bg " " ${ fg :- $_p9k_color1 } " " $icon " " $expand " " $cond " " $text "
return 0
; ;
2019-10-29 05:12:42 +08:00
display)
if ( ( ARGC = = 1 ) ) ; then
print -rP -- $__p9k_p10k_display_usage >& 2
return 1
fi
2020-01-13 02:37:06 +08:00
shift
2020-01-26 23:54:52 +08:00
local -i k dump
local opt prev new pair list name var
2020-01-13 02:37:06 +08:00
while getopts ':ha' opt; do
case $opt in
a) dump = 1; ;
h) print -rP -- $__p9k_p10k_display_usage ; return 0; ;
?) print -rP -- $__p9k_p10k_display_usage >& 2; return 1; ;
esac
done
if ( ( dump ) ) ; then
reply = ( )
shift $(( OPTIND-1))
( ( ARGC ) ) || set -- '*'
for opt; do
2020-01-13 17:21:22 +08:00
for k in ${ (u@)_p9k_display_k[(I) $opt ] : /(#m)*/ $_p9k_display_k [ $MATCH ] } ; do
2020-01-13 02:37:06 +08:00
reply += ( $_p9k__display_v [ k,k+1] )
done
done
2019-11-02 21:18:57 +08:00
return 0
fi
2020-02-12 18:15:12 +08:00
local REPLY
local -a reply
2020-01-13 02:37:06 +08:00
for opt in " ${ @ : $OPTIND } " ; do
2019-11-04 16:23:57 +08:00
pair = ( ${ (s : = : )opt } )
list = ( ${ (s : , : ) ${ pair [2] } } )
2020-01-13 17:21:22 +08:00
if [ [ ${ (b)pair[1] } = = $pair [ 1] ] ] ; then # this branch is purely for optimization
local ks = ( $_p9k_display_k [ $pair [ 1] ] )
else
local ks = ( ${ (u@)_p9k_display_k[(I) $pair [1]] : /(#m)*/ $_p9k_display_k [ $MATCH ] } )
fi
for k in $ks ; do
2019-11-04 16:23:57 +08:00
if ( ( $# list = = 1 ) ) ; then # this branch is purely for optimization
[ [ $_p9k__display_v [ k+1] = = $list [ 1] ] ] && continue
new = $list [ 1]
else
new = ${ list [list[(I) $_p9k__display_v [k+1]]+1] :- $list [1] }
[ [ $_p9k__display_v [ k+1] = = $new ] ] && continue
fi
2019-11-03 18:20:52 +08:00
_p9k__display_v[ k+1] = $new
2019-11-04 16:23:57 +08:00
name = $_p9k__display_v [ k]
2019-11-03 02:03:45 +08:00
if [ [ $name = = ( empty_line| ruler) ] ] ; then
2019-11-04 16:23:57 +08:00
var = _p9k__${ name } _i
2019-11-03 19:19:22 +08:00
[ [ $new = = show ] ] && unset $var || typeset -gi $var = 3
2019-11-04 16:23:57 +08:00
elif [ [ $name = = ( #b)(<->)(*) ]]; then
var = _p9k__${ match [1] } ${ ${ ${ ${ match [2]// \/ } /#left/l } /#right/r } /#gap/g }
2019-11-03 02:03:45 +08:00
[ [ $new = = hide ] ] && typeset -g $var = || unset $var
fi
if ( ( __p9k_reset_state > 0 ) ) ; then
__p9k_reset_state = 2
else
__p9k_reset_state = -1
fi
done
2019-10-29 05:12:42 +08:00
done
2019-11-02 21:18:57 +08:00
if ( ( __p9k_reset_state = = -1 ) ) ; then
_p9k_reset_prompt
__p9k_reset_state = 0
fi
2019-10-29 05:12:42 +08:00
; ;
2019-08-01 01:41:14 +08:00
configure)
if ( ( ARGC > 1 ) ) ; then
2019-08-05 16:37:04 +08:00
print -rP -- $__p9k_p10k_configure_usage >& 2
2019-08-01 01:41:14 +08:00
return 1
fi
2020-02-12 18:15:12 +08:00
local REPLY
local -a reply
2019-11-06 19:06:10 +08:00
p9k_configure " $@ " || return
2019-11-21 16:24:29 +08:00
; ;
reload)
if ( ( ARGC > 1 ) ) ; then
print -rP -- $__p9k_p10k_reload_usage >& 2
return 1
fi
( ( $+_p9k__force_must_init ) ) || return 0
_p9k__force_must_init = 1
2019-08-01 01:41:14 +08:00
; ;
help )
local var = __p9k_p10k_$2 _usage
if ( ( $+parameters[ $var ] ) ) ; then
2019-08-05 16:37:04 +08:00
print -rP -- ${ (P)var }
2019-08-01 01:41:14 +08:00
return 0
elif ( ( ARGC = = 1 ) ) ; then
2019-08-05 16:37:04 +08:00
print -rP -- $__p9k_p10k_usage
2019-08-01 01:41:14 +08:00
return 0
else
2019-08-05 16:37:04 +08:00
print -rP -- $__p9k_p10k_usage >& 2
2019-08-01 01:41:14 +08:00
return 1
fi
; ;
2019-10-27 02:43:38 +08:00
finalize)
print -rP -- $__p9k_p10k_finalize_usage >& 2
return 1
; ;
2019-08-01 01:41:14 +08:00
*)
2019-08-05 16:37:04 +08:00
print -rP -- $__p9k_p10k_usage >& 2
2019-08-01 01:41:14 +08:00
return 1
; ;
esac
2019-08-01 00:21:37 +08:00
}
2019-07-31 19:03:17 +08:00
# Hook for zplugin.
powerlevel10k_plugin_unload( ) { prompt_powerlevel9k_teardown; }
2019-10-20 16:56:11 +08:00
function p10k-instant-prompt-finalize( ) {
2020-02-15 16:25:44 +08:00
unsetopt local_options
( ( ${ +__p9k_instant_prompt_active } ) ) && unsetopt prompt_cr prompt_sp || setopt prompt_cr prompt_sp
2019-10-20 16:56:11 +08:00
}
2019-06-01 23:54:53 +08:00
autoload -Uz add-zsh-hook
zmodload zsh/datetime
zmodload zsh/mathfunc
2019-11-13 21:57:23 +08:00
zmodload zsh/parameter 2>/dev/null # https://github.com/romkatv/gitstatus/issues/58#issuecomment-553407177
2019-06-01 23:54:53 +08:00
zmodload zsh/system
2019-12-14 21:57:30 +08:00
zmodload zsh/termcap
zmodload zsh/terminfo
2020-01-09 03:16:52 +08:00
zmodload zsh/zleparameter
2019-06-01 23:54:53 +08:00
zmodload -F zsh/stat b:zstat
2019-07-25 20:11:04 +08:00
zmodload -F zsh/net/socket b:zsocket
2019-10-04 02:14:16 +08:00
zmodload -F zsh/files b:zf_mv b:zf_rm
2019-06-01 23:54:53 +08:00
2019-10-20 16:36:41 +08:00
if [ [ $__p9k_dump_file != $__p9k_instant_prompt_dump_file && -n $__p9k_instant_prompt_dump_file ] ] ; then
2020-02-18 22:47:24 +08:00
zf_rm -f -- $__p9k_instant_prompt_dump_file 2>/dev/null
2019-10-20 16:36:41 +08:00
fi
2019-10-27 02:43:38 +08:00
if [ [ $+__p9k_instant_prompt_sourced = = 1 && $__p9k_instant_prompt_sourced != $__p9k_instant_prompt_version ] ] ; then
zf_rm -f -- ${ __p9k_dump_file : h } /p10k-instant-prompt-${ (%) :- %n } .zsh{ ,.zwc} 2>/dev/null
fi
2019-08-20 17:19:11 +08:00
_p9k_init_ssh
2019-07-02 14:38:35 +08:00
prompt_powerlevel9k_setup