neovim

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

commit 35ffe58ea4a32719e6776f7b6ef710299f78342a
parent 18e62c1bdbbb6b93bfb74d974bc511fc4c03748e
Author: zeertzjq <zeertzjq@outlook.com>
Date:   Mon,  5 Feb 2024 12:13:21 +0800

fix(inccommand): update topline after moving cursor (#27341)


Diffstat:
Msrc/nvim/ex_cmds.c | 6+++---
Mtest/functional/ui/inccommand_spec.lua | 2+-
2 files changed, 4 insertions(+), 4 deletions(-)

diff --git a/src/nvim/ex_cmds.c b/src/nvim/ex_cmds.c @@ -4592,9 +4592,6 @@ static int show_sub(exarg_T *eap, pos_T old_cusr, PreviewLines *preview_lines, i // disable file info message set_string_option_direct(kOptShortmess, "F", 0, SID_NONE); - // Update the topline to ensure that main window is on the correct line - update_topline(curwin); - // Place cursor on nearest matching line, to undo do_sub() cursor placement. for (size_t i = 0; i < lines.subresults.size; i++) { SubResult curres = lines.subresults.items[i]; @@ -4605,6 +4602,9 @@ static int show_sub(exarg_T *eap, pos_T old_cusr, PreviewLines *preview_lines, i } // Else: All matches are above, do_sub() already placed cursor. } + // Update the topline to ensure that main window is on the correct line + update_topline(curwin); + // Width of the "| lnum|..." column which displays the line numbers. int col_width = 0; // Use preview window only when inccommand=split and range is not just the current line diff --git a/test/functional/ui/inccommand_spec.lua b/test/functional/ui/inccommand_spec.lua @@ -1064,11 +1064,11 @@ describe(':substitute, inccommand=split', function() feed(':%s/tw/X') screen:expect([[ + Inc substitution on | BBo lines | Inc substitution on | {12:X}o lines | Inc substitution on | - {12:X}o lines | {11:[No Name] [+] }| |1001| {12:X}o lines | |1003| {12:X}o lines |