summaryrefslogtreecommitdiff
path: root/plugins
diff options
context:
space:
mode:
authorMarc Cornellà <hello@mcornella.com>2023-03-31 07:51:10 +0200
committerGitHub <noreply@github.com>2023-03-31 07:51:10 +0200
commitcc9913210498e2d527486310f1e8a53b93f55ca8 (patch)
tree95617f22431f974d60ae5fcf45808c8ba1e69dad /plugins
parentb9c4e2e82337594c2899db1f9ca005bb02fe20cd (diff)
downloadzsh-cc9913210498e2d527486310f1e8a53b93f55ca8.tar.gz
zsh-cc9913210498e2d527486310f1e8a53b93f55ca8.tar.bz2
zsh-cc9913210498e2d527486310f1e8a53b93f55ca8.zip
fix(vi-mode): fix check for prompt redisplay on mode change (#11547)
Diffstat (limited to 'plugins')
-rw-r--r--plugins/vi-mode/vi-mode.plugin.zsh27
1 files changed, 16 insertions, 11 deletions
diff --git a/plugins/vi-mode/vi-mode.plugin.zsh b/plugins/vi-mode/vi-mode.plugin.zsh
index 9a410c1fb..d44be69d4 100644
--- a/plugins/vi-mode/vi-mode.plugin.zsh
+++ b/plugins/vi-mode/vi-mode.plugin.zsh
@@ -43,12 +43,25 @@ function _vi-mode-set-cursor-shape-for-keymap() {
printf $'\e[%d q' "${_shape}"
}
+function _vi-mode-should-reset-prompt() {
+ # If $VI_MODE_RESET_PROMPT_ON_MODE_CHANGE is unset (default), dynamically
+ # check whether we're using the prompt to display vi-mode info
+ if [[ -z "${VI_MODE_RESET_PROMPT_ON_MODE_CHANGE:-}" ]]; then
+ [[ "${PS1} ${RPS1}" = *'$(vi_mode_prompt_info)'* ]]
+ return $?
+ fi
+
+ # If $VI_MODE_RESET_PROMPT_ON_MODE_CHANGE was manually set, let's check
+ # if it was specifically set to true or it was disabled with any other value
+ [[ "${VI_MODE_RESET_PROMPT_ON_MODE_CHANGE}" = true ]]
+}
+
# Updates editor information when the keymap changes.
function zle-keymap-select() {
# update keymap variable for the prompt
typeset -g VI_KEYMAP=$KEYMAP
- if [[ "${VI_MODE_RESET_PROMPT_ON_MODE_CHANGE:-}" = true ]]; then
+ if _vi-mode-should-reset-prompt; then
zle reset-prompt
zle -R
fi
@@ -59,10 +72,9 @@ zle -N zle-keymap-select
# These "echoti" statements were originally set in lib/key-bindings.zsh
# Not sure the best way to extend without overriding.
function zle-line-init() {
- local prev_vi_keymap
- prev_vi_keymap="${VI_KEYMAP:-}"
+ local prev_vi_keymap="${VI_KEYMAP:-}"
typeset -g VI_KEYMAP=main
- [[ "$prev_vi_keymap" != 'main' ]] && [[ "${VI_MODE_RESET_PROMPT_ON_MODE_CHANGE:-}" = true ]] && zle reset-prompt
+ [[ "$prev_vi_keymap" != 'main' ]] && _vi-mode-should-reset-prompt && zle reset-prompt
(( ! ${+terminfo[smkx]} )) || echoti smkx
_vi-mode-set-cursor-shape-for-keymap "${VI_KEYMAP}"
}
@@ -138,13 +150,6 @@ if [[ -z "$MODE_INDICATOR" ]]; then
fi
function vi_mode_prompt_info() {
- # If we're using the prompt to display mode info, and we haven't explicitly
- # disabled "reset prompt on mode change", then set it here.
- #
- # We do that here instead of the `if` statement below because the user may
- # set RPS1/RPROMPT to something else in their custom config.
- : "${VI_MODE_RESET_PROMPT_ON_MODE_CHANGE:=true}"
-
echo "${${VI_KEYMAP/vicmd/$MODE_INDICATOR}/(main|viins)/$INSERT_MODE_INDICATOR}"
}