patch 9.1.0320: Wrong cursor position after using setcellwidths()

Problem:  Wrong cursor position after using setcellwidths().
Solution: Invalidate cursor position in addition to redrawing.
          (zeertzjq)

closes: #14545

Signed-off-by: zeertzjq <zeertzjq@outlook.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
zeertzjq
2024-04-14 18:52:49 +02:00
committed by Christian Brabandt
parent 3d93630605
commit 05aacec6ab
5 changed files with 31 additions and 0 deletions

View File

@ -5733,6 +5733,7 @@ f_setcellwidths(typval_T *argvars, typval_T *rettv UNUSED)
}
vim_free(cw_table_save);
changed_window_setting_all();
redraw_all_later(UPD_CLEAR);
}

View File

@ -677,6 +677,19 @@ changed_window_setting_buf(buf_T *buf)
}
#endif
/*
* Call changed_window_setting_win() for every window.
*/
void
changed_window_setting_all(void)
{
tabpage_T *tp;
win_T *wp;
FOR_ALL_TAB_WINDOWS(tp, wp)
changed_window_setting_win(wp);
}
/*
* Set wp->w_topline to a certain number.
*/

View File

@ -9,6 +9,7 @@ void check_cursor_moved(win_T *wp);
void changed_window_setting(void);
void changed_window_setting_win(win_T *wp);
void changed_window_setting_buf(buf_T *buf);
void changed_window_setting_all(void);
void set_topline(win_T *wp, linenr_T lnum);
void changed_cline_bef_curs(void);
void changed_cline_bef_curs_win(win_T *wp);

View File

@ -170,6 +170,7 @@ func Test_screenchar_utf8()
endfunc
func Test_setcellwidths()
new
call setcellwidths([
\ [0x1330, 0x1330, 2],
\ [9999, 10000, 1],
@ -212,6 +213,18 @@ func Test_setcellwidths()
" Ambiguous width chars
call assert_equal(2, strwidth("\u00A1"))
call assert_equal(2, strwidth("\u2010"))
call setcellwidths([])
call setline(1, repeat("\u2103", 10))
normal! $
redraw
call assert_equal((aw == 'single') ? 10 : 19, wincol())
call setcellwidths([[0x2103, 0x2103, 1]])
redraw
call assert_equal(10, wincol())
call setcellwidths([[0x2103, 0x2103, 2]])
redraw
call assert_equal(19, wincol())
endfor
set ambiwidth& isprint&
@ -245,6 +258,7 @@ func Test_setcellwidths()
set listchars&
set fillchars&
call setcellwidths([])
bwipe!
endfunc
func Test_getcellwidths()

View File

@ -704,6 +704,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
320,
/**/
319,
/**/