summaryrefslogtreecommitdiff
path: root/plugins/vi-mode/vi-mode.plugin.zsh
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/vi-mode/vi-mode.plugin.zsh')
-rw-r--r--plugins/vi-mode/vi-mode.plugin.zsh46
1 files changed, 33 insertions, 13 deletions
diff --git a/plugins/vi-mode/vi-mode.plugin.zsh b/plugins/vi-mode/vi-mode.plugin.zsh
index 9a410c1fb..8fefaf86c 100644
--- a/plugins/vi-mode/vi-mode.plugin.zsh
+++ b/plugins/vi-mode/vi-mode.plugin.zsh
@@ -43,12 +43,32 @@ function _vi-mode-set-cursor-shape-for-keymap() {
printf $'\e[%d q' "${_shape}"
}
+function _visual-mode {
+ typeset -g VI_KEYMAP=visual
+ _vi-mode-set-cursor-shape-for-keymap "$VI_KEYMAP"
+ zle .visual-mode
+}
+zle -N visual-mode _visual-mode
+
+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 +79,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}"
}
@@ -128,8 +147,16 @@ function wrap_clipboard_widgets() {
done
}
-wrap_clipboard_widgets copy vi-yank vi-yank-eol vi-backward-kill-word vi-change-whole-line vi-delete vi-delete-char
-wrap_clipboard_widgets paste vi-put-{before,after}
+wrap_clipboard_widgets copy \
+ vi-yank vi-yank-eol vi-yank-whole-line \
+ vi-change vi-change-eol vi-change-whole-line \
+ vi-kill-line vi-kill-eol vi-backward-kill-word \
+ vi-delete vi-delete-char vi-backward-delete-char
+
+wrap_clipboard_widgets paste \
+ vi-put-{before,after} \
+ put-replace-selection
+
unfunction wrap_clipboard_widgets
# if mode indicator wasn't setup by theme, define default, we'll leave INSERT_MODE_INDICATOR empty by default
@@ -138,13 +165,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}"
}