1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-25 01:02:24 +00:00

Don't unconditionally reset scrollback on certain escape sequences.

Handlers for a number of escape sequences, notably including ESC[J and
the sequences that switch to/from the alternate screen, were
unconditionally resetting the scrollback instead of first checking the
'Reset scrollback on display activity' configuration option. I've
added the missing if statements, so now 'Reset scrollback on display
activity' should actually mean what it says.

For example, this would have inconvenienced an mplayer user, who
wouldn't be able to go up and check their scrollback while mplayer was
repeatedly redisplaying its status line, because mplayer uses ESC[J to
erase each version of the status line before printing the next
version.

[originally from svn r10125]
This commit is contained in:
Simon Tatham 2014-01-25 18:38:38 +00:00
parent ee83fb6fdb
commit c29ab648b9

View File

@ -2517,7 +2517,8 @@ static void toggle_mode(Terminal *term, int mode, int query, int state)
compatibility(OTHER); compatibility(OTHER);
deselect(term); deselect(term);
swap_screen(term, term->no_alt_screen ? 0 : state, FALSE, FALSE); swap_screen(term, term->no_alt_screen ? 0 : state, FALSE, FALSE);
term->disptop = 0; if (term->scroll_on_disp)
term->disptop = 0;
break; break;
case 1000: /* xterm mouse 1 (normal) */ case 1000: /* xterm mouse 1 (normal) */
term->xterm_mouse = state ? 1 : 0; term->xterm_mouse = state ? 1 : 0;
@ -2537,7 +2538,8 @@ static void toggle_mode(Terminal *term, int mode, int query, int state)
compatibility(OTHER); compatibility(OTHER);
deselect(term); deselect(term);
swap_screen(term, term->no_alt_screen ? 0 : state, TRUE, TRUE); swap_screen(term, term->no_alt_screen ? 0 : state, TRUE, TRUE);
term->disptop = 0; if (term->scroll_on_disp)
term->disptop = 0;
break; break;
case 1048: /* save/restore cursor */ case 1048: /* save/restore cursor */
if (!term->no_alt_screen) if (!term->no_alt_screen)
@ -2553,7 +2555,8 @@ static void toggle_mode(Terminal *term, int mode, int query, int state)
swap_screen(term, term->no_alt_screen ? 0 : state, TRUE, FALSE); swap_screen(term, term->no_alt_screen ? 0 : state, TRUE, FALSE);
if (!state && !term->no_alt_screen) if (!state && !term->no_alt_screen)
save_cursor(term, state); save_cursor(term, state);
term->disptop = 0; if (term->scroll_on_disp)
term->disptop = 0;
break; break;
case 2004: /* xterm bracketed paste */ case 2004: /* xterm bracketed paste */
term->bracketed_paste = state ? TRUE : FALSE; term->bracketed_paste = state ? TRUE : FALSE;
@ -3015,7 +3018,8 @@ static void term_out(Terminal *term)
if (has_compat(SCOANSI)) { if (has_compat(SCOANSI)) {
move(term, 0, 0, 0); move(term, 0, 0, 0);
erase_lots(term, FALSE, FALSE, TRUE); erase_lots(term, FALSE, FALSE, TRUE);
term->disptop = 0; if (term->scroll_on_disp)
term->disptop = 0;
term->wrapnext = FALSE; term->wrapnext = FALSE;
seen_disp_event(term); seen_disp_event(term);
break; break;
@ -3295,7 +3299,8 @@ static void term_out(Terminal *term)
request_resize(term->frontend, 80, term->rows); request_resize(term->frontend, 80, term->rows);
term->reset_132 = 0; term->reset_132 = 0;
} }
term->disptop = 0; if (term->scroll_on_disp)
term->disptop = 0;
seen_disp_event(term); seen_disp_event(term);
break; break;
case 'H': /* HTS: set a tab */ case 'H': /* HTS: set a tab */
@ -3319,7 +3324,8 @@ static void term_out(Terminal *term)
} }
ldata->lattr = LATTR_NORM; ldata->lattr = LATTR_NORM;
} }
term->disptop = 0; if (term->scroll_on_disp)
term->disptop = 0;
seen_disp_event(term); seen_disp_event(term);
scrtop.x = scrtop.y = 0; scrtop.x = scrtop.y = 0;
scrbot.x = 0; scrbot.x = 0;
@ -3517,7 +3523,8 @@ static void term_out(Terminal *term)
erase_lots(term, FALSE, !!(i & 2), !!(i & 1)); erase_lots(term, FALSE, !!(i & 2), !!(i & 1));
} }
} }
term->disptop = 0; if (term->scroll_on_disp)
term->disptop = 0;
seen_disp_event(term); seen_disp_event(term);
break; break;
case 'K': /* EL: erase line or parts of it */ case 'K': /* EL: erase line or parts of it */
@ -4424,7 +4431,8 @@ static void term_out(Terminal *term)
break; break;
case 'J': case 'J':
erase_lots(term, FALSE, FALSE, TRUE); erase_lots(term, FALSE, FALSE, TRUE);
term->disptop = 0; if (term->scroll_on_disp)
term->disptop = 0;
break; break;
case 'K': case 'K':
erase_lots(term, TRUE, FALSE, TRUE); erase_lots(term, TRUE, FALSE, TRUE);
@ -4479,7 +4487,8 @@ static void term_out(Terminal *term)
/* compatibility(ATARI) */ /* compatibility(ATARI) */
move(term, 0, 0, 0); move(term, 0, 0, 0);
erase_lots(term, FALSE, FALSE, TRUE); erase_lots(term, FALSE, FALSE, TRUE);
term->disptop = 0; if (term->scroll_on_disp)
term->disptop = 0;
break; break;
case 'L': case 'L':
/* compatibility(ATARI) */ /* compatibility(ATARI) */
@ -4502,7 +4511,8 @@ static void term_out(Terminal *term)
case 'd': case 'd':
/* compatibility(ATARI) */ /* compatibility(ATARI) */
erase_lots(term, FALSE, TRUE, FALSE); erase_lots(term, FALSE, TRUE, FALSE);
term->disptop = 0; if (term->scroll_on_disp)
term->disptop = 0;
break; break;
case 'e': case 'e':
/* compatibility(ATARI) */ /* compatibility(ATARI) */