This commit is contained in:
Kovid Goyal 2022-01-25 11:33:06 +05:30
commit 0648b4f568
No known key found for this signature in database
GPG Key ID: 06BC317B515ACE7C
2 changed files with 34 additions and 29 deletions

View File

@ -61,7 +61,7 @@ _ksi_main() {
if [[ "${_ksi_prompt[cursor]}" == "y" ]]; then
_ksi_prompt[ps1]+="\[\e[5 q\]" # blinking bar cursor
_ksi_prompt[ps0]+="\[\e[5 q\]" # blinking block cursor
_ksi_prompt[ps0]+="\[\e[1 q\]" # blinking block cursor
fi
if [[ "${_ksi_prompt[title]}" == "y" ]]; then

View File

@ -7,6 +7,9 @@ function __ksi_schedule --on-event fish_prompt -d "Setup kitty integration after
functions --erase __ksi_schedule
test -n "$KITTY_SHELL_INTEGRATION" || return 0
# To use fish's autoloading feature, kitty prepends the vendored integration script directory to XDG_DATA_DIRS.
# The original paths needs to be restored here to not affect other programs.
# In particular, if the original XDG_DATA_DIRS does not exist, it needs to be removed.
if set -q XDG_DATA_DIRS KITTY_FISH_XDG_DATA_DIR
set --global --export --path XDG_DATA_DIRS "$XDG_DATA_DIRS"
if set -l index (contains -i "$KITTY_FISH_XDG_DATA_DIR" $XDG_DATA_DIRS)
@ -20,46 +23,48 @@ function __ksi_schedule --on-event fish_prompt -d "Setup kitty integration after
set --local _ksi (string split " " -- "$KITTY_SHELL_INTEGRATION")
set --erase KITTY_SHELL_INTEGRATION KITTY_FISH_XDG_DATA_DIR
function __ksi_osc
printf "\e]%s\a" "$argv[1]"
end
# Enable cursor shape changes for default mode and vi mode
if not contains "no-cursor" $_ksi
and not functions -q __ksi_set_cursor
function __ksi_set_cursor --on-variable fish_key_bindings -d "Set cursor shape for fish default mode"
if test "$fish_key_bindings" = fish_default_key_bindings
not functions -q __ksi_bar_cursor __ksi_block_cursor || return
function __ksi_block_cursor --on-event fish_preexec -d "Set cursor shape to blinking block before executing command"
printf "\e[1 q"
end
function __ksi_bar_cursor --on-event fish_prompt
function __ksi_set_cursor --on-variable fish_key_bindings -d "Set the cursor shape for different modes when switching key bindings"
if test "$fish_key_bindings" = fish_default_key_bindings
not functions -q __ksi_bar_cursor || return
function __ksi_bar_cursor --on-event fish_prompt -d "Set cursor shape to blinking bar on prompt"
printf "\e[5 q"
end
function __ksi_block_cursor --on-event fish_preexec
printf "\e[2 q"
end
else
functions --erase __ksi_bar_cursor __ksi_block_cursor
functions --erase __ksi_bar_cursor
contains "$fish_key_bindings" fish_vi_key_bindings fish_hybrid_key_bindings
and __ksi_set_vi_cursor
end
end
__ksi_set_cursor
functions -q __ksi_bar_cursor
and __ksi_bar_cursor
# Set the vi mode cursor shapes only when none of them are configured
set --local vi_modes fish_cursor_{default,insert,replace_one,visual}
set --local vi_cursor_shapes block line underscore block
set -q $vi_modes
if test "$status" -eq 4
function __ksi_set_vi_cursor -d "Set the vi mode cursor shapes"
# Set the vi mode cursor shapes only when none of them are configured
set --local vi_modes fish_cursor_{default,insert,replace_one,visual}
set -q $vi_modes
test "$status" -eq 4 || return
set --local vi_cursor_shapes block line underscore block
for i in 1 2 3 4
set --global $vi_modes[$i] $vi_cursor_shapes[$i] blink
end
# Change the vi mode cursor shape on the first run
contains "$fish_key_bindings" fish_vi_key_bindings fish_hybrid_key_bindings
and test "$fish_bind_mode" = "insert" && printf "\e[5 q" || printf "\e[1 q"
# Change the cursor shape for current mode
test "$fish_bind_mode" = "insert" && printf "\e[5 q" || printf "\e[1 q"
end
__ksi_set_cursor
functions -q __ksi_bar_cursor
and __ksi_bar_cursor
end
# Enable prompt marking with OSC 133
if not contains "no-prompt-mark" $_ksi
and not set -q __ksi_prompt_state
set --global __ksi_prompt_state first-run
@ -69,11 +74,11 @@ function __ksi_schedule --on-event fish_prompt -d "Setup kitty integration after
end
function __ksi_mark -d "Tell kitty to mark the current cursor position using OSC 133"
__ksi_osc "133;$argv[1]"
printf "\e]133;%s\a" "$argv[1]"
end
function __ksi_prompt_start
# preserve the command exit code from $status
# Preserve the command exit code from $status
set --local cmd_status $status
if contains "$__ksi_prompt_state" post-exec first-run
__ksi_mark D
@ -100,7 +105,7 @@ function __ksi_schedule --on-event fish_prompt -d "Setup kitty integration after
functions -c fish_prompt __ksi_original_fish_prompt
if __ksi_function_is_not_empty fish_mode_prompt
# see https://github.com/starship/starship/issues/1283
# See https://github.com/starship/starship/issues/1283
# for why we have to test for a non-empty fish_mode_prompt
functions -c fish_mode_prompt __ksi_original_fish_mode_prompt
function fish_mode_prompt
@ -126,7 +131,7 @@ function __ksi_schedule --on-event fish_prompt -d "Setup kitty integration after
set --global __ksi_prompt_state post-exec
__ksi_mark "D;$status"
end
# with prompt marking kitty clears the current prompt on resize so we need
# With prompt marking kitty clears the current prompt on resize so we need
# fish to redraw it
set --global fish_handle_reflow 1