1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-10 01:48:00 +00:00

Move echo/edit state change functionality out of ldisc_send.

I'm not actually sure why we've always had back ends notify ldisc of
changes to echo/edit settings by giving ldisc_send(ldisc,NULL,0,0) a
special meaning, instead of by having a separate dedicated notify
function with its own prototype and parameter set. Coverity's recent
observation that the two kinds of call don't even have the same
requirements on the ldisc (particularly, whether ldisc->term can be
NULL) makes me realise that it's really high time I separated the two
conceptually different operations into actually different functions.

While I'm here, I've renamed the confusing ldisc_update() function
which that special operation ends up feeding to, because it's not
actually a function applying to an ldisc - it applies to a front end.
So ldisc_send(ldisc,NULL,0,0) is now ldisc_echoedit_update(ldisc), and
that in turn figures out the current echo/edit settings before passing
them on to frontend_echoedit_update(). I think that should be clearer.
This commit is contained in:
Simon Tatham 2014-11-22 16:12:47 +00:00
parent d870b5650e
commit c269dd0135
12 changed files with 32 additions and 57 deletions

23
ldisc.c
View File

@ -128,28 +128,19 @@ void ldisc_free(void *handle)
sfree(ldisc); sfree(ldisc);
} }
void ldisc_echoedit_update(void *handle)
{
Ldisc ldisc = (Ldisc) handle;
frontend_echoedit_update(ldisc->frontend, ECHOING, EDITING);
}
void ldisc_send(void *handle, char *buf, int len, int interactive) void ldisc_send(void *handle, char *buf, int len, int interactive)
{ {
Ldisc ldisc = (Ldisc) handle; Ldisc ldisc = (Ldisc) handle;
int keyflag = 0; int keyflag = 0;
/*
* Called with len=0 when the options change. We must inform
* the front end in case it needs to know.
*/
if (len == 0) {
ldisc_update(ldisc->frontend, ECHOING, EDITING);
return;
}
/*
* If that wasn't true, then we expect ldisc->term to be non-NULL
* hereafter. (The only front ends which have an ldisc but no term
* are those which do networking but no terminal emulation, in
* which case they need the above if statement to handle
* ldisc_updates passed from the back ends, but should never send
* any actual input through this function.)
*/
assert(ldisc->term); assert(ldisc->term);
assert(len);
/* /*
* Notify the front end that something was pressed, in case * Notify the front end that something was pressed, in case

View File

@ -907,7 +907,7 @@ void notify_remote_exit(void *frontend)
[win notifyRemoteExit]; [win notifyRemoteExit];
} }
void ldisc_update(void *frontend, int echo, int edit) void frontend_echoedit_update(void *frontend, int echo, int edit)
{ {
//SessionWindow *win = (SessionWindow *)frontend; //SessionWindow *win = (SessionWindow *)frontend;
/* /*

11
pscp.c
View File

@ -60,16 +60,7 @@ const char *const appname = "PSCP";
*/ */
#define MAX_SCP_BUFSIZE 16384 #define MAX_SCP_BUFSIZE 16384
void ldisc_send(void *handle, char *buf, int len, int interactive) void ldisc_echoedit_update(void *handle) { }
{
/*
* This is only here because of the calls to ldisc_send(NULL,
* 0) in ssh.c. Nothing in PSCP actually needs to use the ldisc
* as an ldisc. So if we get called with any real data, I want
* to know about it.
*/
assert(len == 0);
}
static void tell_char(FILE * stream, char c) static void tell_char(FILE * stream, char c)
{ {

11
psftp.c
View File

@ -2506,16 +2506,7 @@ void connection_fatal(void *frontend, char *fmt, ...)
cleanup_exit(1); cleanup_exit(1);
} }
void ldisc_send(void *handle, char *buf, int len, int interactive) void ldisc_echoedit_update(void *handle) { }
{
/*
* This is only here because of the calls to ldisc_send(NULL,
* 0) in ssh.c. Nothing in PSFTP actually needs to use the
* ldisc as an ldisc. So if we get called with any real data, I
* want to know about it.
*/
assert(len == 0);
}
/* /*
* In psftp, all agent requests should be synchronous, so this is a * In psftp, all agent requests should be synchronous, so this is a

View File

@ -602,7 +602,7 @@ void begin_session(void *frontend);
void sys_cursor(void *frontend, int x, int y); void sys_cursor(void *frontend, int x, int y);
void request_paste(void *frontend); void request_paste(void *frontend);
void frontend_keypress(void *frontend); void frontend_keypress(void *frontend);
void ldisc_update(void *frontend, int echo, int edit); void frontend_echoedit_update(void *frontend, int echo, int edit);
/* It's the backend's responsibility to invoke this at the start of a /* It's the backend's responsibility to invoke this at the start of a
* connection, if necessary; it can also invoke it later if the set of * connection, if necessary; it can also invoke it later if the set of
* special commands changes. It does not need to invoke it at session * special commands changes. It does not need to invoke it at session
@ -1067,6 +1067,7 @@ void *ldisc_create(Conf *, Terminal *, Backend *, void *, void *);
void ldisc_configure(void *, Conf *); void ldisc_configure(void *, Conf *);
void ldisc_free(void *); void ldisc_free(void *);
void ldisc_send(void *handle, char *buf, int len, int interactive); void ldisc_send(void *handle, char *buf, int len, int interactive);
void ldisc_echoedit_update(void *handle);
/* /*
* Exports from ldiscucs.c. * Exports from ldiscucs.c.

4
ssh.c
View File

@ -5832,7 +5832,7 @@ static void do_ssh1_connection(Ssh ssh, unsigned char *in, int inlen,
ssh_special(ssh, TS_EOF); ssh_special(ssh, TS_EOF);
if (ssh->ldisc) if (ssh->ldisc)
ldisc_send(ssh->ldisc, NULL, 0, 0);/* cause ldisc to notice changes */ ldisc_echoedit_update(ssh->ldisc); /* cause ldisc to notice changes */
ssh->send_ok = 1; ssh->send_ok = 1;
ssh->channels = newtree234(ssh_channelcmp); ssh->channels = newtree234(ssh_channelcmp);
while (1) { while (1) {
@ -10326,7 +10326,7 @@ static void do_ssh2_authconn(Ssh ssh, unsigned char *in, int inlen,
* Transfer data! * Transfer data!
*/ */
if (ssh->ldisc) if (ssh->ldisc)
ldisc_send(ssh->ldisc, NULL, 0, 0);/* cause ldisc to notice changes */ ldisc_echoedit_update(ssh->ldisc); /* cause ldisc to notice changes */
if (ssh->mainchan) if (ssh->mainchan)
ssh->send_ok = 1; ssh->send_ok = 1;
while (1) { while (1) {

View File

@ -264,7 +264,7 @@ static void option_side_effects(Telnet telnet, const struct Opt *o, int enabled)
else if (o->option == TELOPT_SGA && o->send == DO) else if (o->option == TELOPT_SGA && o->send == DO)
telnet->editing = !enabled; telnet->editing = !enabled;
if (telnet->ldisc) /* cause ldisc to notice the change */ if (telnet->ldisc) /* cause ldisc to notice the change */
ldisc_send(telnet->ldisc, NULL, 0, 0); ldisc_echoedit_update(telnet->ldisc);
/* Ensure we get the minimum options */ /* Ensure we get the minimum options */
if (!telnet->activated) { if (!telnet->activated) {

View File

@ -1350,7 +1350,7 @@ void term_pwron(Terminal *term, int clear)
{ {
power_on(term, clear); power_on(term, clear);
if (term->ldisc) /* cause ldisc to notice changes */ if (term->ldisc) /* cause ldisc to notice changes */
ldisc_send(term->ldisc, NULL, 0, 0); ldisc_echoedit_update(term->ldisc);
term->disptop = 0; term->disptop = 0;
deselect(term); deselect(term);
term_update(term); term_update(term);
@ -2574,7 +2574,7 @@ static void toggle_mode(Terminal *term, int mode, int query, int state)
case 10: /* DECEDM: set local edit mode */ case 10: /* DECEDM: set local edit mode */
term->term_editing = state; term->term_editing = state;
if (term->ldisc) /* cause ldisc to notice changes */ if (term->ldisc) /* cause ldisc to notice changes */
ldisc_send(term->ldisc, NULL, 0, 0); ldisc_echoedit_update(term->ldisc);
break; break;
case 25: /* DECTCEM: enable/disable cursor */ case 25: /* DECTCEM: enable/disable cursor */
compatibility2(OTHER, VT220); compatibility2(OTHER, VT220);
@ -2638,7 +2638,7 @@ static void toggle_mode(Terminal *term, int mode, int query, int state)
case 12: /* SRM: set echo mode */ case 12: /* SRM: set echo mode */
term->term_echoing = !state; term->term_echoing = !state;
if (term->ldisc) /* cause ldisc to notice changes */ if (term->ldisc) /* cause ldisc to notice changes */
ldisc_send(term->ldisc, NULL, 0, 0); ldisc_echoedit_update(term->ldisc);
break; break;
case 20: /* LNM: Return sends ... */ case 20: /* LNM: Return sends ... */
term->cr_lf_return = state; term->cr_lf_return = state;
@ -3361,7 +3361,7 @@ static void term_out(Terminal *term)
compatibility(VT100); compatibility(VT100);
power_on(term, TRUE); power_on(term, TRUE);
if (term->ldisc) /* cause ldisc to notice changes */ if (term->ldisc) /* cause ldisc to notice changes */
ldisc_send(term->ldisc, NULL, 0, 0); ldisc_echoedit_update(term->ldisc);
if (term->reset_132) { if (term->reset_132) {
if (!term->no_remote_resize) if (!term->no_remote_resize)
request_resize(term->frontend, 80, term->rows); request_resize(term->frontend, 80, term->rows);

View File

@ -194,7 +194,7 @@ int platform_default_i(const char *name, int def)
} }
/* Dummy routine, only required in plink. */ /* Dummy routine, only required in plink. */
void ldisc_update(void *frontend, int echo, int edit) void frontend_echoedit_update(void *frontend, int echo, int edit)
{ {
} }
@ -3020,7 +3020,7 @@ void reset_terminal_menuitem(GtkMenuItem *item, gpointer data)
struct gui_data *inst = (struct gui_data *)data; struct gui_data *inst = (struct gui_data *)data;
term_pwron(inst->term, TRUE); term_pwron(inst->term, TRUE);
if (inst->ldisc) if (inst->ldisc)
ldisc_send(inst->ldisc, NULL, 0, 0); ldisc_echoedit_update(inst->ldisc);
} }
void copy_all_menuitem(GtkMenuItem *item, gpointer data) void copy_all_menuitem(GtkMenuItem *item, gpointer data)
@ -3088,7 +3088,7 @@ void change_settings_menuitem(GtkMenuItem *item, gpointer data)
*/ */
if (inst->ldisc) { if (inst->ldisc) {
ldisc_configure(inst->ldisc, inst->conf); ldisc_configure(inst->ldisc, inst->conf);
ldisc_send(inst->ldisc, NULL, 0, 0); ldisc_echoedit_update(inst->ldisc);
} }
/* Pass new config data to the terminal */ /* Pass new config data to the terminal */
term_reconfig(inst->term, inst->conf); term_reconfig(inst->term, inst->conf);
@ -3924,7 +3924,7 @@ int pt_main(int argc, char **argv)
start_backend(inst); start_backend(inst);
ldisc_send(inst->ldisc, NULL, 0, 0);/* cause ldisc to notice changes */ ldisc_echoedit_update(inst->ldisc); /* cause ldisc to notice changes */
/* now we're reday to deal with the child exit handler being /* now we're reday to deal with the child exit handler being
* called */ * called */

View File

@ -152,7 +152,7 @@ int term_ldisc(Terminal *term, int mode)
{ {
return FALSE; return FALSE;
} }
void ldisc_update(void *frontend, int echo, int edit) void frontend_echoedit_update(void *frontend, int echo, int edit)
{ {
/* Update stdin read mode to reflect changes in line discipline. */ /* Update stdin read mode to reflect changes in line discipline. */
struct termios mode; struct termios mode;
@ -178,8 +178,9 @@ void ldisc_update(void *frontend, int echo, int edit)
mode.c_cc[VMIN] = 1; mode.c_cc[VMIN] = 1;
mode.c_cc[VTIME] = 0; mode.c_cc[VTIME] = 0;
/* FIXME: perhaps what we do with IXON/IXOFF should be an /* FIXME: perhaps what we do with IXON/IXOFF should be an
* argument to ldisc_update(), to allow implementation of SSH-2 * argument to frontend_echoedit_update(), to allow
* "xon-xoff" and Rlogin's equivalent? */ * implementation of SSH-2 "xon-xoff" and Rlogin's
* equivalent? */
mode.c_iflag &= ~IXON; mode.c_iflag &= ~IXON;
mode.c_iflag &= ~IXOFF; mode.c_iflag &= ~IXOFF;
} }
@ -981,7 +982,7 @@ int main(int argc, char **argv)
*/ */
local_tty = (tcgetattr(STDIN_FILENO, &orig_termios) == 0); local_tty = (tcgetattr(STDIN_FILENO, &orig_termios) == 0);
atexit(cleanup_termios); atexit(cleanup_termios);
ldisc_update(NULL, 1, 1); frontend_echoedit_update(NULL, 1, 1);
sending = FALSE; sending = FALSE;
now = GETTICKCOUNT(); now = GETTICKCOUNT();

View File

@ -219,7 +219,7 @@ const int share_can_be_downstream = TRUE;
const int share_can_be_upstream = TRUE; const int share_can_be_upstream = TRUE;
/* Dummy routine, only required in plink. */ /* Dummy routine, only required in plink. */
void ldisc_update(void *frontend, int echo, int edit) void frontend_echoedit_update(void *frontend, int echo, int edit)
{ {
} }
@ -2236,7 +2236,7 @@ static LRESULT CALLBACK WndProc(HWND hwnd, UINT message,
*/ */
if (ldisc) { if (ldisc) {
ldisc_configure(ldisc, conf); ldisc_configure(ldisc, conf);
ldisc_send(ldisc, NULL, 0, 0); ldisc_echoedit_update(ldisc);
} }
if (pal) if (pal)
DeleteObject(pal); DeleteObject(pal);
@ -2379,7 +2379,7 @@ static LRESULT CALLBACK WndProc(HWND hwnd, UINT message,
case IDM_RESET: case IDM_RESET:
term_pwron(term, TRUE); term_pwron(term, TRUE);
if (ldisc) if (ldisc)
ldisc_send(ldisc, NULL, 0, 0); ldisc_echoedit_update(ldisc);
break; break;
case IDM_ABOUT: case IDM_ABOUT:
showabout(hwnd); showabout(hwnd);

View File

@ -98,7 +98,7 @@ int term_ldisc(Terminal *term, int mode)
{ {
return FALSE; return FALSE;
} }
void ldisc_update(void *frontend, int echo, int edit) void frontend_echoedit_update(void *frontend, int echo, int edit)
{ {
/* Update stdin read mode to reflect changes in line discipline. */ /* Update stdin read mode to reflect changes in line discipline. */
DWORD mode; DWORD mode;