diff options
author | romkatv <roman.perepelitsa@gmail.com> | 2020-02-24 08:51:13 +0300 |
---|---|---|
committer | romkatv <roman.perepelitsa@gmail.com> | 2020-02-24 08:51:27 +0300 |
commit | a2689e757d5bc2fb792379fe2998b370e4f6a169 (patch) | |
tree | ef2b5cf1fe6c8dc9df4d89edf0d9fd1d9b4bd6fa /internal/p10k.zsh | |
parent | 4b4f514c1586f343a714949efa2e0686b291f7d2 (diff) |
don't reset prompt when precmd is called from zle
Diffstat (limited to 'internal/p10k.zsh')
-rw-r--r-- | internal/p10k.zsh | 17 |
1 files changed, 11 insertions, 6 deletions
diff --git a/internal/p10k.zsh b/internal/p10k.zsh index a67a5091..d6707fbf 100644 --- a/internal/p10k.zsh +++ b/internal/p10k.zsh @@ -6041,7 +6041,9 @@ _p9k_precmd_impl() { preexec_functions=(${(@)preexec_functions:#_p9k_preexec2} _p9k_preexec2) fi + __p9k_reset_state=1 _p9k_worker_receive + __p9k_reset_state=0 } _p9k_trapint() { @@ -6067,14 +6069,19 @@ _p9k_precmd() { } function _p9k_reset_prompt() { - if zle && [[ -z $_p9k__line_finished ]]; then + if (( __p9k_reset_state != 1 )) && zle && [[ -z $_p9k__line_finished ]]; then + __p9k_reset_state=0 setopt prompt_subst (( __p9k_ksh_arrays )) && setopt ksh_arrays (( __p9k_sh_glob )) && setopt sh_glob (( _p9k__can_hide_cursor )) && echoti civis - zle .reset-prompt - zle -R - (( _p9k__can_hide_cursor )) && echoti cnorm + { + zle .reset-prompt + zle -R + } always { + (( _p9k__can_hide_cursor )) && echoti cnorm + _p9k__cursor_hidden=0 + } fi } @@ -6699,7 +6706,6 @@ function _p9k_on_widget_zle-line-finish() { echo -nE - $hide$'\n'$termcap[up] fi _p9k_reset_prompt - __p9k_reset_state=0 fi _p9k__line_finished='%{%}' @@ -7898,7 +7904,6 @@ function p10k() { done if (( __p9k_reset_state == -1 )); then _p9k_reset_prompt - __p9k_reset_state=0 fi ;; configure) |