summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorromkatv <roman.perepelitsa@gmail.com>2019-10-19 17:47:19 +0300
committerromkatv <roman.perepelitsa@gmail.com>2019-10-19 17:47:19 +0300
commita1bab30690ff4d7162ed42dba97f1e488f13b21a (patch)
tree02b829a021bdffc28c4fb608b719b6a2e0864c3f
parent148a8500c172a4a6ff74fc6a5f6c3e38818de5b9 (diff)
don't use prompt segments with non-hermetic expansions in instant prompt
-rw-r--r--internal/p10k.zsh23
1 files changed, 20 insertions, 3 deletions
diff --git a/internal/p10k.zsh b/internal/p10k.zsh
index 21059708..95a4d1bb 100644
--- a/internal/p10k.zsh
+++ b/internal/p10k.zsh
@@ -533,6 +533,8 @@ _p9k_left_prompt_segment() {
local s='<_p9k_s>' ss='<_p9k_ss>'
+ local -i non_hermetic=0
+
# Segment separator logic:
#
# if [[ $_p9k_bg == NONE ]]; then
@@ -585,9 +587,11 @@ _p9k_left_prompt_segment() {
p+="\${_p9k_n:=$((t+4))}" # 4
_p9k_param $1 VISUAL_IDENTIFIER_EXPANSION '${P9K_VISUAL_IDENTIFIER}'
+ [[ $_p9k_ret == (|*[^\\])'$('* ]] && non_hermetic=1
local icon_exp_=${_p9k_ret:+\"$_p9k_ret\"}
_p9k_param $1 CONTENT_EXPANSION '${P9K_CONTENT}'
+ [[ $_p9k_ret == (|*[^\\])'$('* ]] && non_hermetic=1
local content_exp_=${_p9k_ret:+\"$_p9k_ret\"}
if [[ ( $icon_exp_ != '"${P9K_VISUAL_IDENTIFIER}"' && $icon_exp_ == *'$'* ) ||
@@ -691,9 +695,11 @@ _p9k_left_prompt_segment() {
p+='}'
- _p9k_cache_set "$p"
+ _p9k_cache_set "$p" $non_hermetic
fi
+ _p9k_non_hermetic_expansion=$_p9k_cache_val[2]
+
(( $5 )) && _p9k_ret=\"$7\" || _p9k_escape $7
if [[ -z $6 ]]; then
_p9k_prompt+="\${\${:-\${P9K_CONTENT::=$_p9k_ret}$_p9k_cache_val[1]"
@@ -756,6 +762,8 @@ _p9k_right_prompt_segment() {
local w='<_p9k_w>' s='<_p9k_s>'
+ local -i non_hermetic=0
+
# Segment separator logic:
#
# if [[ $_p9k_bg == NONE ]]; then
@@ -797,9 +805,11 @@ _p9k_right_prompt_segment() {
p+="\${_p9k_n:=$((t+4))}" # 4
_p9k_param $1 VISUAL_IDENTIFIER_EXPANSION '${P9K_VISUAL_IDENTIFIER}'
+ [[ $_p9k_ret == (|*[^\\])'$('* ]] && non_hermetic=1
local icon_exp_=${_p9k_ret:+\"$_p9k_ret\"}
_p9k_param $1 CONTENT_EXPANSION '${P9K_CONTENT}'
+ [[ $_p9k_ret == (|*[^\\])'$('* ]] && non_hermetic=1
local content_exp_=${_p9k_ret:+\"$_p9k_ret\"}
if [[ ( $icon_exp_ != '"${P9K_VISUAL_IDENTIFIER}"' && $icon_exp_ == *'$'* ) ||
@@ -921,9 +931,11 @@ _p9k_right_prompt_segment() {
p+='}+}'
p+='}'
- _p9k_cache_set "$p"
+ _p9k_cache_set "$p" $non_hermetic
fi
+ _p9k_non_hermetic_expansion=$_p9k_cache_val[2]
+
(( $5 )) && _p9k_ret=\"$7\" || _p9k_escape $7
if [[ -z $6 ]]; then
_p9k_prompt+="\${\${:-\${P9K_CONTENT::=$_p9k_ret}$_p9k_cache_val[1]"
@@ -3373,8 +3385,12 @@ function _p9k_build_segment() {
function _p9k_build_instant_segment() {
_p9k_segment_name=${_p9k_segment_name%_joined}
if (( $+functions[instant_prompt_$_p9k_segment_name] )); then
- # TODO: Drop segment if it has '$(' in CONTEXT_EXPANSION or VISUAL_IDENTIFIER_EXPANSION.
+ local -i len=$#_p9k_prompt
+ _p9k_non_hermetic_expansion=0
instant_prompt_$_p9k_segment_name
+ if (( _p9k_non_hermetic_expansion )); then
+ _p9k_prompt[len+1,-1]=
+ fi
fi
((++_p9k_segment_index))
}
@@ -4046,6 +4062,7 @@ function _p9k_prompt_overflow_bug() {
}
_p9k_init_vars() {
+ typeset -gi _p9k_non_hermetic_expansion
typeset -g _p9k_time
typeset -g _p9k_date
typeset -gA _p9k_dumped_instant_prompt_sigs