X-Git-Url: https://git.distorted.org.uk/u/mdw/putty/blobdiff_plain/2c94fd1cbf32093be173ea6c4378caa109f73dd4..142329905de1d9ebe4e3dc9409a6131c291c6539:/raw.c diff --git a/raw.c b/raw.c index c3545803..7990d1de 100644 --- a/raw.c +++ b/raw.c @@ -24,18 +24,17 @@ static void c_write (char *buf, int len) { from_backend(0, buf, len); } -static int raw_receive (Socket s, int urgent, char *data, int len) { - if (urgent==3) { +static int raw_closing (Plug plug, char *error_msg, int error_code, int calling_back) { + sk_close(s); + s = NULL; + if (error_msg) { /* A socket error has occurred. */ - connection_fatal(data); - len = 0; - } - if (!len) { - /* Connection has closed. */ - sk_close(s); - s = NULL; - return 0; - } + connection_fatal (error_msg); + } /* Otherwise, the remote side closed the connection normally. */ + return 0; +} + +static int raw_receive (Plug plug, int urgent, char *data, int len) { c_write(data, len); return 1; } @@ -48,6 +47,11 @@ static int raw_receive (Socket s, int urgent, char *data, int len) { * Also places the canonical host name into `realhost'. */ static char *raw_init (char *host, int port, char **realhost) { + static struct plug_function_table fn_table = { + raw_closing, + raw_receive + }, *fn_table_ptr = &fn_table; + SockAddr addr; char *err; @@ -64,17 +68,12 @@ static char *raw_init (char *host, int port, char **realhost) { /* * Open socket. */ - s = sk_new(addr, port, 0, raw_receive); + s = sk_new(addr, port, 0, 1, &fn_table_ptr); if ( (err = sk_socket_error(s)) ) return err; sk_addr_free(addr); - /* - * We have no pre-session phase. - */ - begin_session(); - return NULL; } @@ -109,6 +108,12 @@ static Socket raw_socket(void) { return s; } static int raw_sendok(void) { return 1; } +static int raw_ldisc(int option) { + if (option == LD_EDIT || option == LD_ECHO) + return 1; + return 0; +} + Backend raw_backend = { raw_init, raw_send, @@ -116,5 +121,6 @@ Backend raw_backend = { raw_special, raw_socket, raw_sendok, + raw_ldisc, 1 };