Don't truncate cursor arithmetic to 16 bits.
When updating the row number when the cursor position escape sequence is issued, we should make sure to store the intermediate result in a 32-bit integer. If we fail to do this, the cursor may be set above the origin region, which is bad. This could cause libteken to crash when INVARIANTS is enabled, due to the strict set of assertions that libteken has. PR: 202540 Reported by: kcwu csie org MFC after: 1 month
This commit is contained in:
parent
328b9e0bca
commit
9a71fa376b
@ -324,13 +324,13 @@ static void
|
|||||||
teken_subr_cursor_position(teken_t *t, unsigned int row, unsigned int col)
|
teken_subr_cursor_position(teken_t *t, unsigned int row, unsigned int col)
|
||||||
{
|
{
|
||||||
|
|
||||||
t->t_cursor.tp_row = t->t_originreg.ts_begin + row - 1;
|
row = row - 1 + t->t_originreg.ts_begin;
|
||||||
if (t->t_cursor.tp_row >= t->t_originreg.ts_end)
|
t->t_cursor.tp_row = row < t->t_originreg.ts_end ?
|
||||||
t->t_cursor.tp_row = t->t_originreg.ts_end - 1;
|
row : t->t_originreg.ts_end - 1;
|
||||||
|
|
||||||
t->t_cursor.tp_col = col - 1;
|
col--;
|
||||||
if (t->t_cursor.tp_col >= t->t_winsize.tp_col)
|
t->t_cursor.tp_col = col < t->t_winsize.tp_col ?
|
||||||
t->t_cursor.tp_col = t->t_winsize.tp_col - 1;
|
col : t->t_winsize.tp_col - 1;
|
||||||
|
|
||||||
t->t_stateflags &= ~TS_WRAPPED;
|
t->t_stateflags &= ~TS_WRAPPED;
|
||||||
teken_funcs_cursor(t);
|
teken_funcs_cursor(t);
|
||||||
|
Loading…
Reference in New Issue
Block a user