projects
/
u
/
mdw
/
putty
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Make the text about our interest in new mirror sites significantly
[u/mdw/putty]
/
terminal.c
diff --git
a/terminal.c
b/terminal.c
index
92c3f03
..
079a738
100644
(file)
--- a/
terminal.c
+++ b/
terminal.c
@@
-1223,6
+1223,8
@@
static void power_on(Terminal *term, int clear)
term->erase_char = term->basic_erase_char;
term->alt_which = 0;
term_print_finish(term);
term->erase_char = term->basic_erase_char;
term->alt_which = 0;
term_print_finish(term);
+ term->xterm_mouse = FALSE;
+ set_raw_mouse_mode(term->frontend, FALSE);
{
int i;
for (i = 0; i < 256; i++)
{
int i;
for (i = 0; i < 256; i++)
@@
-1448,7
+1450,7
@@
Terminal *term_init(Config *mycfg, struct unicode_data *ucsdata,
term->vt52_mode = FALSE;
term->cr_lf_return = FALSE;
term->seen_disp_event = FALSE;
term->vt52_mode = FALSE;
term->cr_lf_return = FALSE;
term->seen_disp_event = FALSE;
- term->
xterm_mouse = term->
mouse_is_down = FALSE;
+ term->mouse_is_down = FALSE;
term->reset_132 = FALSE;
term->cblinker = term->tblinker = 0;
term->has_focus = 1;
term->reset_132 = FALSE;
term->cblinker = term->tblinker = 0;
term->has_focus = 1;
@@
-1722,7
+1724,7
@@
void term_provide_resize_fn(Terminal *term,
{
term->resize_fn = resize_fn;
term->resize_ctx = resize_ctx;
{
term->resize_fn = resize_fn;
term->resize_ctx = resize_ctx;
- if (term->cols > 0 && term->rows > 0)
+ if (
resize_fn &&
term->cols > 0 && term->rows > 0)
resize_fn(resize_ctx, term->cols, term->rows);
}
resize_fn(resize_ctx, term->cols, term->rows);
}
@@
-2850,6
+2852,13
@@
static void term_out(Terminal *term)
term->wrapnext = FALSE;
seen_disp_event(term);
term->paste_hold = 0;
term->wrapnext = FALSE;
seen_disp_event(term);
term->paste_hold = 0;
+
+ if (term->cfg.crhaslf) {
+ if (term->curs.y == term->marg_b)
+ scroll(term, term->marg_t, term->marg_b, 1, TRUE);
+ else if (term->curs.y < term->rows - 1)
+ term->curs.y++;
+ }
if (term->logctx)
logtraffic(term->logctx, (unsigned char) c, LGTYP_ASCII);
break;
if (term->logctx)
logtraffic(term->logctx, (unsigned char) c, LGTYP_ASCII);
break;
@@
-6398,6
+6407,7
@@
char *term_get_ttymode(Terminal *term, const char *mode)
val = term->cfg.bksp_is_delete ? "^?" : "^H";
}
/* FIXME: perhaps we should set ONLCR based on cfg.lfhascr as well? */
val = term->cfg.bksp_is_delete ? "^?" : "^H";
}
/* FIXME: perhaps we should set ONLCR based on cfg.lfhascr as well? */
+ /* FIXME: or ECHO and friends based on local echo state? */
return dupstr(val);
}
return dupstr(val);
}