neovim

Neovim text editor
git clone https://git.dasho.dev/neovim.git
Log | Files | Refs | README

commit 17e13ce3b65a2993ee4f7e8d1e9e39626bd6a692
parent f87b6230f12419ecc64bc304fabb6c41913dafe4
Author: zeertzjq <zeertzjq@outlook.com>
Date:   Thu, 15 May 2025 20:42:49 +0800

fix(tui): clear primary device callback before invoking it (#34032)

A primary device callback may set a new callback (e.g. when suspending),
so clearing it after invoking it is too late.

While at it, add missing reset of did_set_grapheme_cluster_mode in
terminfo_start().
Diffstat:
Msrc/nvim/tui/input.c | 4+++-
Msrc/nvim/tui/tui.c | 1+
2 files changed, 4 insertions(+), 1 deletion(-)

diff --git a/src/nvim/tui/input.c b/src/nvim/tui/input.c @@ -658,8 +658,10 @@ static void handle_unknown_csi(TermInput *input, const TermKeyKey *key) case '?': // Primary Device Attributes (DA1) response if (input->callbacks.primary_device_attr) { - input->callbacks.primary_device_attr(input->tui_data); + void (*cb_save)(TUIData *) = input->callbacks.primary_device_attr; + // Clear the callback before invoking it, as it may set a new callback. #34031 input->callbacks.primary_device_attr = NULL; + cb_save(input->tui_data); } break; diff --git a/src/nvim/tui/tui.c b/src/nvim/tui/tui.c @@ -358,6 +358,7 @@ static void terminfo_start(TUIData *tui) tui->overflow = false; tui->set_cursor_color_as_str = false; tui->cursor_has_color = false; + tui->did_set_grapheme_cluster_mode = false; tui->showing_mode = SHAPE_IDX_N; tui->unibi_ext.enable_mouse = -1; tui->unibi_ext.disable_mouse = -1;