1
0
Fork 0
mirror of https://github.com/romkatv/powerlevel10k.git synced 2024-12-25 16:31:57 +00:00

wip: dynamic shit

This commit is contained in:
romkatv 2019-10-29 15:54:30 +01:00
parent 37fbc8c7ea
commit 3377990a6f

View file

@ -3458,8 +3458,10 @@ function _p9k_set_prompt() {
IFS=$' \t\n\0' IFS=$' \t\n\0'
_p9k_pwd=${(%):-%/} _p9k_pwd=${(%):-%/}
_p9k_pwd_a=${_p9k_pwd:A} _p9k_pwd_a=${_p9k_pwd:A}
PROMPT=$_p9k_prompt_prefix_left PROMPT=
RPROMPT= RPROMPT=
[[ $1 == instant_ ]] || PROMPT+='${$((_p9k_on_expand()))+}'
PROMPT+=$_p9k_prompt_prefix_left
(( _p9k_fetch_iface )) && _p9k_set_iface (( _p9k_fetch_iface )) && _p9k_set_iface
@ -3834,15 +3836,12 @@ function _p9k_restore_state() {
} }
function _p9k_clear_instant_prompt() { function _p9k_clear_instant_prompt() {
(( $+__p9k_instant_prompt_active )) || return 0
() {
emulate -L zsh
if (( $+__p9k_fd_0 )); then if (( $+__p9k_fd_0 )); then
exec 0<&$__p9k_fd_0 {__p9k_fd_0}>&- exec 0<&$__p9k_fd_0 {__p9k_fd_0}>&-
unset __p9k_fd_0 unset __p9k_fd_0
fi fi
exec 1>&$__p9k_fd_1 2>&$__p9k_fd_2 {__p9k_fd_1}>&- {__p9k_fd_2}>&- exec 1>&$__p9k_fd_1 2>&$__p9k_fd_2 {__p9k_fd_1}>&- {__p9k_fd_2}>&-
unset __p9k_fd_1 __p9k_fd_2 __p9k_instant_prompt_active unset __p9k_fd_1 __p9k_fd_2
if [[ -s $__p9k_instant_prompt_output ]]; then if [[ -s $__p9k_instant_prompt_output ]]; then
{ {
local content local content
@ -3938,9 +3937,81 @@ function _p9k_clear_instant_prompt() {
fi fi
} }
function _p9k_maybe_dump() {
(( __p9k_dumps_enabled )) || return 0
_p9k__instant_prompt_sig=$_p9k_pwd:$P9K_SSH:${(%):-%#}
if (( ! _p9k__dump_pid )) || ! kill -0 $_p9k__dump_pid 2>/dev/null; then
_p9k__dump_pid=0
if (( _p9k__prompt_idx == 1 )) then
(( _p9k__instant_prompt_disabled )) || _p9k_set_instant_prompt
if (( !_p9k_state_restored )); then
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
elif [[ $_p9k__instant_prompt_disabled == 0 &&
"${(pj:\x1f:)__p9k_used_instant_prompt}" != "${(e)_p9k_instant_prompt}" ]]; then
_p9k_dump_instant_prompt
if (( ! $+_p9k_dumped_instant_prompt_sigs[$_p9k__instant_prompt_sig] )); then
_p9k_dump_state
_p9k__state_dump_scheduled=0
_p9k_dumped_instant_prompt_sigs[$_p9k__instant_prompt_sig]=1
fi
fi
elif (( _p9k__state_dump_scheduled || ! (_p9k__instant_prompt_disabled || $+_p9k_dumped_instant_prompt_sigs[$_p9k__instant_prompt_sig]) )); then
setopt no_bg_nice
(
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__dump_pid=$!
_p9k__state_dump_scheduled=0
(( _p9k__instant_prompt_disabled )) || _p9k_dumped_instant_prompt_sigs[$_p9k__instant_prompt_sig]=1
fi
fi
}
typeset -gA __p9k_display
function _p9k_on_expand() {
(( _p9k__expanded && ! $+__p9k_instant_prompt_active )) && return
() {
emulate -L zsh
setopt no_hist_expand extended_glob no_prompt_bang prompt_{percent,subst} no_aliases
_p9k_maybe_dump
(( $+__p9k_instant_prompt_active )) && _p9k_clear_instant_prompt
(( _p9k__expanded )) && return
_p9k__expanded=1
[[ $__p9k_display[empty_line] == print ]] && print -rn -- $_p9k_t[_p9k_empty_line_idx]
if [[ $__p9k_display[ruler] == print ]]; then
local ruler=$_p9k_t[_p9k_ruler_idx]
() {
(( __p9k_ksh_arrays )) && setopt ksh_arrays
(( __p9k_sh_glob )) && setopt sh_glob
print -rP -- $ruler
}
fi
}
if (( $+__p9k_instant_prompt_active )); then
unset __p9k_instant_prompt_active
unsetopt localoptions unsetopt localoptions
setopt prompt_sp prompt_cr setopt prompt_sp prompt_cr
fi
} }
functions -M _p9k_on_expand
_p9k_precmd_impl() { _p9k_precmd_impl() {
emulate -L zsh emulate -L zsh
@ -3952,8 +4023,9 @@ _p9k_precmd_impl() {
if zle; then if zle; then
__p9k_new_status=0 __p9k_new_status=0
__p9k_new_pipestatus=(0) __p9k_new_pipestatus=(0)
_p9k__expanded=1
else else
print -rn "${_p9k_prompt_newline:-}" _p9k__expanded=0
fi fi
if (( _p9k__transient_rprompt_active )); then if (( _p9k__transient_rprompt_active )); then
@ -4028,51 +4100,6 @@ _p9k_precmd_impl() {
if [[ $precmd_functions[-1] != _p9k_precmd && $precmd_functions[(I)_p9k_precmd] != 0 ]]; then if [[ $precmd_functions[-1] != _p9k_precmd && $precmd_functions[(I)_p9k_precmd] != 0 ]]; then
precmd_functions=(${(@)precmd_functions:#_p9k_precmd} _p9k_precmd) precmd_functions=(${(@)precmd_functions:#_p9k_precmd} _p9k_precmd)
fi fi
if (( $+__p9k_instant_prompt_active )); then
functions -M _p9k_clear_instant_prompt
PROMPT+='${$((_p9k_clear_instant_prompt()))+}'
fi
(( __p9k_dumps_enabled )) || return 0
_p9k__instant_prompt_sig=$_p9k_pwd:$P9K_SSH:${(%):-%#}
if (( ! _p9k__dump_pid )) || ! kill -0 $_p9k__dump_pid 2>/dev/null; then
_p9k__dump_pid=0
if (( _p9k__prompt_idx == 1 )) then
(( _p9k__instant_prompt_disabled )) || _p9k_set_instant_prompt
if (( !_p9k_state_restored )); then
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
elif [[ $_p9k__instant_prompt_disabled == 0 &&
"${(pj:\x1f:)__p9k_used_instant_prompt}" != "${(e)_p9k_instant_prompt}" ]]; then
_p9k_dump_instant_prompt
if (( ! $+_p9k_dumped_instant_prompt_sigs[$_p9k__instant_prompt_sig] )); then
_p9k_dump_state
_p9k__state_dump_scheduled=0
_p9k_dumped_instant_prompt_sigs[$_p9k__instant_prompt_sig]=1
fi
fi
elif (( _p9k__state_dump_scheduled || ! (_p9k__instant_prompt_disabled || $+_p9k_dumped_instant_prompt_sigs[$_p9k__instant_prompt_sig]) )); then
setopt no_bg_nice
(
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__dump_pid=$!
_p9k__state_dump_scheduled=0
(( _p9k__instant_prompt_disabled )) || _p9k_dumped_instant_prompt_sigs[$_p9k__instant_prompt_sig]=1
fi
fi
} }
_p9k_precmd() { _p9k_precmd() {
@ -4353,7 +4380,10 @@ _p9k_init_vars() {
typeset -gi _p9k_g typeset -gi _p9k_g
typeset -gi _p9k_ind typeset -gi _p9k_ind
typeset -g _p9k_gap_pre typeset -g _p9k_gap_pre
typeset -g _p9k_prompt_newline typeset -gi _p9k_ruler_i
typeset -gi _p9k_ruler_idx
typeset -gi _p9k_empty_line_i
typeset -gi _p9k_empty_line_idx
typeset -g _p9k_prompt_prefix_left typeset -g _p9k_prompt_prefix_left
typeset -g _p9k_prompt_prefix_right typeset -g _p9k_prompt_prefix_right
typeset -g _p9k_prompt_suffix_left typeset -g _p9k_prompt_suffix_left
@ -4386,6 +4416,7 @@ _p9k_init_vars() {
typeset -gi _p9k__transient_rprompt_active typeset -gi _p9k__transient_rprompt_active
typeset -gA _p9k__dotnet_stat_cache typeset -gA _p9k__dotnet_stat_cache
typeset -gA _p9k__dir_stat_cache typeset -gA _p9k__dir_stat_cache
typeset -gi _p9k__expanded
typeset -g P9K_VISUAL_IDENTIFIER typeset -g P9K_VISUAL_IDENTIFIER
typeset -g P9K_CONTENT typeset -g P9K_CONTENT
@ -4646,6 +4677,7 @@ _p9k_init_params() {
# These correspond to `java -fullversion` and `java -version` respectively. # These correspond to `java -fullversion` and `java -version` respectively.
_p9k_declare -b POWERLEVEL9K_JAVA_VERSION_FULL 1 _p9k_declare -b POWERLEVEL9K_JAVA_VERSION_FULL 1
_p9k_declare -b POWERLEVEL9K_PROMPT_CHAR_OVERWRITE_STATE 0 _p9k_declare -b POWERLEVEL9K_PROMPT_CHAR_OVERWRITE_STATE 0
_p9k_declare -F POWERLEVEL9K_NEW_TTY_MAX_AGE_SECONDS
local -i i=1 local -i i=1
while (( i <= $#_POWERLEVEL9K_LEFT_PROMPT_ELEMENTS )); do while (( i <= $#_POWERLEVEL9K_LEFT_PROMPT_ELEMENTS )); do
@ -4886,7 +4918,7 @@ _p9k_all_params_eq() {
} }
_p9k_init_prompt() { _p9k_init_prompt() {
_p9k_t=($'\n' '') _p9k_t=($'\n' '' '')
_p9k_prompt_overflow_bug && _p9k_t[2]='%{%G%}' _p9k_prompt_overflow_bug && _p9k_t[2]='%{%G%}'
_p9k_init_lines _p9k_init_lines
@ -4932,43 +4964,40 @@ _p9k_init_prompt() {
_p9k_prompt_prefix_left+='${${_p9k_ind::=${${ZLE_RPROMPT_INDENT:-1}/#-*/0}}+}' _p9k_prompt_prefix_left+='${${_p9k_ind::=${${ZLE_RPROMPT_INDENT:-1}/#-*/0}}+}'
fi fi
if (( _POWERLEVEL9K_PROMPT_ADD_NEWLINE )); then if (( _POWERLEVEL9K_PROMPT_ADD_NEWLINE_COUNT > 0 )); then
repeat $_POWERLEVEL9K_PROMPT_ADD_NEWLINE_COUNT _p9k_prompt_newline+=$'\n' _p9k_t+=${(pl.$_POWERLEVEL9K_PROMPT_ADD_NEWLINE_COUNT..\n.)}
else
_p9k_t+=''
fi fi
_p9k_empty_line_idx=$#_p9k_t
_p9k_empty_line_i=3
_p9k_prompt_prefix_left+='${_p9k_t[_p9k_empty_line_i-__p9k_ksh_arrays]}'
if (( _POWERLEVEL9K_SHOW_RULER )); then
_p9k_get_icon '' RULER_CHAR _p9k_get_icon '' RULER_CHAR
local ruler_char=$_p9k_ret local ruler_char=$_p9k_ret
_p9k_prompt_length $ruler_char _p9k_prompt_length $ruler_char
if (( _p9k_ret == 1 && $#ruler_char == 1 )); then (( _p9k_ret == 1 && $#ruler_char == 1 )) || ruler_char=' '
_p9k_prompt_prefix_left+=$'${${__p9k_x_ruler+\n}:-'
_p9k_color prompt_ruler BACKGROUND "" _p9k_color prompt_ruler BACKGROUND ""
if [[ -z $_p9k_ret && $ruler_char == ' ' ]]; then if [[ -z $_p9k_ret && $ruler_char == ' ' ]]; then
_p9k_prompt_prefix_left+=$'\n' local ruler=$'\n'
else else
_p9k_background $_p9k_ret _p9k_background $_p9k_ret
_p9k_escape_style $_p9k_ret local ruler=%b$_p9k_ret
_p9k_prompt_prefix_left+=%b$_p9k_ret
_p9k_color prompt_ruler FOREGROUND "" _p9k_color prompt_ruler FOREGROUND ""
_p9k_foreground $_p9k_ret _p9k_foreground $_p9k_ret
_p9k_escape_style $_p9k_ret ruler+=$_p9k_ret
_p9k_prompt_prefix_left+=$_p9k_ret
[[ $ruler_char == '.' ]] && local sep=',' || local sep='.' [[ $ruler_char == '.' ]] && local sep=',' || local sep='.'
local ruler_len='${$((_p9k_clm-_p9k_ind))/#-*/0}' ruler+='${(pl'$sep'${$((_p9k_clm-_p9k_ind))/#-*/0}'$sep$sep$ruler_char$sep')}%k%f'
_p9k_prompt_prefix_left+="\${(pl$sep$ruler_len$sep$sep${(q)ruler_char}$sep)}%k%f"
if (( __p9k_ksh_arrays )); then if (( __p9k_ksh_arrays )); then
_p9k_prompt_prefix_left+='${_p9k_t[$((!_p9k_ind))]}' ruler+='${_p9k_t[$((!_p9k_ind))]}'
else else
_p9k_prompt_prefix_left+='${_p9k_t[$((1+!_p9k_ind))]}' ruler+='${_p9k_t[$((1+!_p9k_ind))]}'
fi
fi
_p9k_prompt_prefix_left+='}'
else
print -rP -- "%F{red}WARNING!%f %BPOWERLEVEL9K_RULER_CHAR%b is not one character long. Ruler won't be rendered."
print -rP -- "Either change the value of %BPOWERLEVEL9K_RULER_CHAR%b or set %BPOWERLEVEL9K_SHOW_RULER=false%b to"
print -rP -- "disable ruler."
fi fi
fi fi
_p9k_t+=$ruler
_p9k_ruler_idx=$#_p9k_t
_p9k_ruler_i=3
_p9k_prompt_prefix_left+='${(e)_p9k_t[_p9k_ruler_i-__p9k_ksh_arrays]}'
if [[ $ITERM_SHELL_INTEGRATION_INSTALLED == Yes ]]; then if [[ $ITERM_SHELL_INTEGRATION_INSTALLED == Yes ]]; then
_p9k_prompt_prefix_left+=$'%{\e]133;A\a%}' _p9k_prompt_prefix_left+=$'%{\e]133;A\a%}'