mirror of
https://github.com/neovim/neovim.git
synced 2025-02-25 18:55:25 -06:00
vim-patch:9.0.1312: Cursor position wrong when splitting window in insert mode
Problem: Cursor position wrong when splitting window in insert mode.
Solution: Pass the actual mode to win_fix_cursor(). (Luuk van Baal,
closes vim/vim#11999,
bc3dc298b3
Co-authored-by: Luuk van Baal <luukvbaal@gmail.com>
This commit is contained in:
parent
a2dd7fa97b
commit
0bb3a373d3
@ -1653,14 +1653,7 @@ func Test_splitkeep_options()
|
||||
|
||||
" Scroll when cursor becomes invalid in insert mode.
|
||||
norm Lic
|
||||
call assert_equal(curpos[0], getcurpos()[0], 'run ' .. run)
|
||||
|
||||
" The line number might be one less because of round-off.
|
||||
call assert_inrange(curpos[1] - 1, curpos[1], getcurpos()[1], 'run ' .. run)
|
||||
|
||||
call assert_equal(curpos[2], getcurpos()[2], 'run ' .. run)
|
||||
call assert_equal(curpos[3], getcurpos()[3], 'run ' .. run)
|
||||
call assert_equal(curpos[4], getcurpos()[4], 'run ' .. run)
|
||||
call assert_equal(curpos, getcurpos(), 'run ' .. run)
|
||||
|
||||
" No scroll when topline not equal to 1
|
||||
only | execute "norm gg5\<C-e>" | split | wincmd k
|
||||
|
@ -4835,7 +4835,9 @@ static void win_enter_ext(win_T *const wp, const int flags)
|
||||
if (*p_spk == 'c') {
|
||||
changed_line_abv_curs(); // assume cursor position needs updating
|
||||
} else {
|
||||
win_fix_cursor(true);
|
||||
// Make sure the cursor position is valid, either by moving the cursor
|
||||
// or by scrolling the text.
|
||||
win_fix_cursor(get_real_state() & (MODE_NORMAL|MODE_CMDLINE|MODE_TERMINAL));
|
||||
}
|
||||
|
||||
fix_current_dir();
|
||||
@ -6407,7 +6409,8 @@ void win_fix_scroll(int resize)
|
||||
|
||||
/// Make sure the cursor position is valid for 'splitkeep'.
|
||||
/// If it is not, put the cursor position in the jumplist and move it.
|
||||
/// If we are not in normal mode, scroll to make valid instead.
|
||||
/// If we are not in normal mode ("normal" is zero), make it valid by scrolling
|
||||
/// instead.
|
||||
static void win_fix_cursor(int normal)
|
||||
{
|
||||
win_T *wp = curwin;
|
||||
|
Loading…
Reference in New Issue
Block a user