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

Make Socket and Plug into structs.

I think that means that _every_ one of my traitoids is now a struct
containing a vtable pointer as one of its fields (albeit sometimes the
only field), and never just a bare pointer.
This commit is contained in:
Simon Tatham 2018-10-05 07:24:16 +01:00
parent b798230844
commit 884a7df94b
20 changed files with 222 additions and 209 deletions

7
defs.h
View File

@ -42,8 +42,8 @@ typedef struct IdempotentCallback IdempotentCallback;
typedef struct SockAddr SockAddr; typedef struct SockAddr SockAddr;
typedef struct SocketVtable SocketVtable; typedef struct Socket Socket;
typedef struct PlugVtable PlugVtable; typedef struct Plug Plug;
typedef struct Backend Backend; typedef struct Backend Backend;
typedef struct BackendVtable BackendVtable; typedef struct BackendVtable BackendVtable;
@ -74,9 +74,6 @@ typedef struct settings_e settings_e;
typedef struct SessionSpecial SessionSpecial; typedef struct SessionSpecial SessionSpecial;
typedef const SocketVtable *Socket;
typedef const PlugVtable *Plug;
/* /*
* A small structure wrapping up a (pointer, length) pair so that it * A small structure wrapping up a (pointer, length) pair so that it
* can be conveniently passed to or from a function. * can be conveniently passed to or from a function.

View File

@ -14,12 +14,12 @@ typedef struct {
char *error; char *error;
Plug *plug; Plug *plug;
const SocketVtable *sockvt; Socket sock;
} ErrorSocket; } ErrorSocket;
static Plug *sk_error_plug(Socket *s, Plug *p) static Plug *sk_error_plug(Socket *s, Plug *p)
{ {
ErrorSocket *es = FROMFIELD(s, ErrorSocket, sockvt); ErrorSocket *es = FROMFIELD(s, ErrorSocket, sock);
Plug *ret = es->plug; Plug *ret = es->plug;
if (p) if (p)
es->plug = p; es->plug = p;
@ -28,7 +28,7 @@ static Plug *sk_error_plug(Socket *s, Plug *p)
static void sk_error_close(Socket *s) static void sk_error_close(Socket *s)
{ {
ErrorSocket *es = FROMFIELD(s, ErrorSocket, sockvt); ErrorSocket *es = FROMFIELD(s, ErrorSocket, sock);
sfree(es->error); sfree(es->error);
sfree(es); sfree(es);
@ -36,7 +36,7 @@ static void sk_error_close(Socket *s)
static const char *sk_error_socket_error(Socket *s) static const char *sk_error_socket_error(Socket *s)
{ {
ErrorSocket *es = FROMFIELD(s, ErrorSocket, sockvt); ErrorSocket *es = FROMFIELD(s, ErrorSocket, sock);
return es->error; return es->error;
} }
@ -60,8 +60,8 @@ static const SocketVtable ErrorSocket_sockvt = {
Socket *new_error_socket(const char *errmsg, Plug *plug) Socket *new_error_socket(const char *errmsg, Plug *plug)
{ {
ErrorSocket *es = snew(ErrorSocket); ErrorSocket *es = snew(ErrorSocket);
es->sockvt = &ErrorSocket_sockvt; es->sock.vt = &ErrorSocket_sockvt;
es->plug = plug; es->plug = plug;
es->error = dupstr(errmsg); es->error = dupstr(errmsg);
return &es->sockvt; return &es->sock;
} }

View File

@ -15,6 +15,13 @@
#include "defs.h" #include "defs.h"
typedef struct SocketVtable SocketVtable;
typedef struct PlugVtable PlugVtable;
struct Socket {
const struct SocketVtable *vt;
};
struct SocketVtable { struct SocketVtable {
Plug *(*plug) (Socket *s, Plug *p); Plug *(*plug) (Socket *s, Plug *p);
/* use a different plug (return the old one) */ /* use a different plug (return the old one) */
@ -34,6 +41,10 @@ struct SocketVtable {
typedef union { void *p; int i; } accept_ctx_t; typedef union { void *p; int i; } accept_ctx_t;
typedef Socket *(*accept_fn_t)(accept_ctx_t ctx, Plug *plug); typedef Socket *(*accept_fn_t)(accept_ctx_t ctx, Plug *plug);
struct Plug {
const struct PlugVtable *vt;
};
struct PlugVtable { struct PlugVtable {
void (*log)(Plug *p, int type, SockAddr *addr, int port, void (*log)(Plug *p, int type, SockAddr *addr, int port,
const char *error_msg, int error_code); const char *error_msg, int error_code);
@ -138,19 +149,24 @@ Socket *sk_new(SockAddr *addr, int port, int privport, int oobinline,
Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug, Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
int local_host_only, int address_family); int local_host_only, int address_family);
#define sk_plug(s,p) (((*s)->plug) (s, p)) #define sk_plug(s,p) (((s)->vt->plug) (s, p))
#define sk_close(s) (((*s)->close) (s)) #define sk_close(s) (((s)->vt->close) (s))
#define sk_write(s,buf,len) (((*s)->write) (s, buf, len)) #define sk_write(s,buf,len) (((s)->vt->write) (s, buf, len))
#define sk_write_oob(s,buf,len) (((*s)->write_oob) (s, buf, len)) #define sk_write_oob(s,buf,len) (((s)->vt->write_oob) (s, buf, len))
#define sk_write_eof(s) (((*s)->write_eof) (s)) #define sk_write_eof(s) (((s)->vt->write_eof) (s))
#define sk_flush(s) (((*s)->flush) (s)) #define sk_flush(s) (((s)->vt->flush) (s))
#ifdef DEFINE_PLUG_METHOD_MACROS #ifdef DEFINE_PLUG_METHOD_MACROS
#define plug_log(p,type,addr,port,msg,code) (((*p)->log) (p, type, addr, port, msg, code)) #define plug_log(p,type,addr,port,msg,code) \
#define plug_closing(p,msg,code,callback) (((*p)->closing) (p, msg, code, callback)) (((p)->vt->log) (p, type, addr, port, msg, code))
#define plug_receive(p,urgent,buf,len) (((*p)->receive) (p, urgent, buf, len)) #define plug_closing(p,msg,code,callback) \
#define plug_sent(p,bufsize) (((*p)->sent) (p, bufsize)) (((p)->vt->closing) (p, msg, code, callback))
#define plug_accepting(p, constructor, ctx) (((*p)->accepting)(p, constructor, ctx)) #define plug_receive(p,urgent,buf,len) \
(((p)->vt->receive) (p, urgent, buf, len))
#define plug_sent(p,bufsize) \
(((p)->vt->sent) (p, bufsize))
#define plug_accepting(p, constructor, ctx) \
(((p)->vt->accepting)(p, constructor, ctx))
#endif #endif
/* /*
@ -159,7 +175,7 @@ Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
* or return NULL if there's no problem. * or return NULL if there's no problem.
*/ */
const char *sk_addr_error(SockAddr *addr); const char *sk_addr_error(SockAddr *addr);
#define sk_socket_error(s) (((*s)->socket_error) (s)) #define sk_socket_error(s) (((s)->vt->socket_error) (s))
/* /*
* Set the `frozen' flag on a socket. A frozen socket is one in * Set the `frozen' flag on a socket. A frozen socket is one in
@ -178,14 +194,14 @@ const char *sk_addr_error(SockAddr *addr);
* associated local socket in order to avoid unbounded buffer * associated local socket in order to avoid unbounded buffer
* growth. * growth.
*/ */
#define sk_set_frozen(s, is_frozen) (((*s)->set_frozen) (s, is_frozen)) #define sk_set_frozen(s, is_frozen) (((s)->vt->set_frozen) (s, is_frozen))
/* /*
* Return a (dynamically allocated) string giving some information * Return a (dynamically allocated) string giving some information
* about the other end of the socket, suitable for putting in log * about the other end of the socket, suitable for putting in log
* files. May be NULL if nothing is available at all. * files. May be NULL if nothing is available at all.
*/ */
#define sk_peer_info(s) (((*s)->peer_info) (s)) #define sk_peer_info(s) (((s)->vt->peer_info) (s))
/* /*
* Simple wrapper on getservbyname(), needed by ssh.c. Returns the * Simple wrapper on getservbyname(), needed by ssh.c. Returns the
@ -211,7 +227,7 @@ Socket *new_error_socket(const char *errmsg, Plug *plug);
/* /*
* Trivial plug that does absolutely nothing. Found in nullplug.c. * Trivial plug that does absolutely nothing. Found in nullplug.c.
*/ */
extern Plug *nullplug; extern Plug *const nullplug;
/* ---------------------------------------------------------------------- /* ----------------------------------------------------------------------
* Functions defined outside the network code, which have to be * Functions defined outside the network code, which have to be

View File

@ -33,10 +33,10 @@ static const PlugVtable nullplug_plugvt = {
NULL NULL
}; };
static const PlugVtable *nullplug_plugvt_ptr = &nullplug_plugvt; static Plug nullplug_plug = { &nullplug_plugvt };
/* /*
* There's a singleton instance of nullplug, because it's not * There's a singleton instance of nullplug, because it's not
* interesting enough to worry about making more than one of them. * interesting enough to worry about making more than one of them.
*/ */
Plug *nullplug = &nullplug_plugvt_ptr; Plug *const nullplug = &nullplug_plug;

View File

@ -707,14 +707,14 @@ struct pageant_conn_state {
int real_packet; int real_packet;
int crLine; /* for coroutine in pageant_conn_receive */ int crLine; /* for coroutine in pageant_conn_receive */
const PlugVtable *plugvt; Plug plug;
}; };
static void pageant_conn_closing(Plug *plug, const char *error_msg, static void pageant_conn_closing(Plug *plug, const char *error_msg,
int error_code, int calling_back) int error_code, int calling_back)
{ {
struct pageant_conn_state *pc = FROMFIELD( struct pageant_conn_state *pc = FROMFIELD(
plug, struct pageant_conn_state, plugvt); plug, struct pageant_conn_state, plug);
if (error_msg) if (error_msg)
plog(pc->logctx, pc->logfn, "%p: error: %s", pc, error_msg); plog(pc->logctx, pc->logfn, "%p: error: %s", pc, error_msg);
else else
@ -726,7 +726,7 @@ static void pageant_conn_closing(Plug *plug, const char *error_msg,
static void pageant_conn_sent(Plug *plug, int bufsize) static void pageant_conn_sent(Plug *plug, int bufsize)
{ {
/* struct pageant_conn_state *pc = FROMFIELD( /* struct pageant_conn_state *pc = FROMFIELD(
plug, struct pageant_conn_state, plugvt); */ plug, struct pageant_conn_state, plug); */
/* /*
* We do nothing here, because we expect that there won't be a * We do nothing here, because we expect that there won't be a
@ -748,7 +748,7 @@ static void pageant_conn_log(void *logctx, const char *fmt, va_list ap)
static void pageant_conn_receive(Plug *plug, int urgent, char *data, int len) static void pageant_conn_receive(Plug *plug, int urgent, char *data, int len)
{ {
struct pageant_conn_state *pc = FROMFIELD( struct pageant_conn_state *pc = FROMFIELD(
plug, struct pageant_conn_state, plugvt); plug, struct pageant_conn_state, plug);
char c; char c;
crBegin(pc->crLine); crBegin(pc->crLine);
@ -801,14 +801,14 @@ struct pageant_listen_state {
void *logctx; void *logctx;
pageant_logfn_t logfn; pageant_logfn_t logfn;
const PlugVtable *plugvt; Plug plug;
}; };
static void pageant_listen_closing(Plug *plug, const char *error_msg, static void pageant_listen_closing(Plug *plug, const char *error_msg,
int error_code, int calling_back) int error_code, int calling_back)
{ {
struct pageant_listen_state *pl = FROMFIELD( struct pageant_listen_state *pl = FROMFIELD(
plug, struct pageant_listen_state, plugvt); plug, struct pageant_listen_state, plug);
if (error_msg) if (error_msg)
plog(pl->logctx, pl->logfn, "listening socket: error: %s", error_msg); plog(pl->logctx, pl->logfn, "listening socket: error: %s", error_msg);
sk_close(pl->listensock); sk_close(pl->listensock);
@ -827,18 +827,18 @@ static int pageant_listen_accepting(Plug *plug,
accept_fn_t constructor, accept_ctx_t ctx) accept_fn_t constructor, accept_ctx_t ctx)
{ {
struct pageant_listen_state *pl = FROMFIELD( struct pageant_listen_state *pl = FROMFIELD(
plug, struct pageant_listen_state, plugvt); plug, struct pageant_listen_state, plug);
struct pageant_conn_state *pc; struct pageant_conn_state *pc;
const char *err; const char *err;
char *peerinfo; char *peerinfo;
pc = snew(struct pageant_conn_state); pc = snew(struct pageant_conn_state);
pc->plugvt = &pageant_connection_plugvt; pc->plug.vt = &pageant_connection_plugvt;
pc->logfn = pl->logfn; pc->logfn = pl->logfn;
pc->logctx = pl->logctx; pc->logctx = pl->logctx;
pc->crLine = 0; pc->crLine = 0;
pc->connsock = constructor(ctx, &pc->plugvt); pc->connsock = constructor(ctx, &pc->plug);
if ((err = sk_socket_error(pc->connsock)) != NULL) { if ((err = sk_socket_error(pc->connsock)) != NULL) {
sk_close(pc->connsock); sk_close(pc->connsock);
sfree(pc); sfree(pc);
@ -869,11 +869,11 @@ static const PlugVtable pageant_listener_plugvt = {
struct pageant_listen_state *pageant_listener_new(Plug **plug) struct pageant_listen_state *pageant_listener_new(Plug **plug)
{ {
struct pageant_listen_state *pl = snew(struct pageant_listen_state); struct pageant_listen_state *pl = snew(struct pageant_listen_state);
pl->plugvt = &pageant_listener_plugvt; pl->plug.vt = &pageant_listener_plugvt;
pl->logctx = NULL; pl->logctx = NULL;
pl->logfn = NULL; pl->logfn = NULL;
pl->listensock = NULL; pl->listensock = NULL;
*plug = &pl->plugvt; *plug = &pl->plug;
return pl; return pl;
} }

View File

@ -56,7 +56,7 @@ typedef struct PortForwarding {
strbuf *socksbuf; strbuf *socksbuf;
size_t socksbuf_consumed; size_t socksbuf_consumed;
const PlugVtable *plugvt; Plug plug;
Channel chan; Channel chan;
} PortForwarding; } PortForwarding;
@ -71,7 +71,7 @@ struct PortListener {
char *hostname; char *hostname;
int port; int port;
const PlugVtable *plugvt; Plug plug;
}; };
static struct PortForwarding *new_portfwd_state(void) static struct PortForwarding *new_portfwd_state(void)
@ -124,7 +124,7 @@ static void pfd_close(struct PortForwarding *pf);
static void pfd_closing(Plug *plug, const char *error_msg, int error_code, static void pfd_closing(Plug *plug, const char *error_msg, int error_code,
int calling_back) int calling_back)
{ {
struct PortForwarding *pf = FROMFIELD(plug, struct PortForwarding, plugvt); struct PortForwarding *pf = FROMFIELD(plug, struct PortForwarding, plug);
if (error_msg) { if (error_msg) {
/* /*
@ -205,7 +205,7 @@ static char *ipv6_to_string(ptrlen ipv6)
static void pfd_receive(Plug *plug, int urgent, char *data, int len) static void pfd_receive(Plug *plug, int urgent, char *data, int len)
{ {
struct PortForwarding *pf = FROMFIELD(plug, struct PortForwarding, plugvt); struct PortForwarding *pf = FROMFIELD(plug, struct PortForwarding, plug);
if (len == 0) if (len == 0)
return; return;
@ -429,7 +429,7 @@ static void pfd_receive(Plug *plug, int urgent, char *data, int len)
static void pfd_sent(Plug *plug, int bufsize) static void pfd_sent(Plug *plug, int bufsize)
{ {
struct PortForwarding *pf = FROMFIELD(plug, struct PortForwarding, plugvt); struct PortForwarding *pf = FROMFIELD(plug, struct PortForwarding, plug);
if (pf->c) if (pf->c)
sshfwd_unthrottle(pf->c, bufsize); sshfwd_unthrottle(pf->c, bufsize);
@ -473,9 +473,9 @@ static int pfl_accepting(Plug *p, accept_fn_t constructor, accept_ctx_t ctx)
Socket *s; Socket *s;
const char *err; const char *err;
pl = FROMFIELD(p, struct PortListener, plugvt); pl = FROMFIELD(p, struct PortListener, plug);
pf = new_portfwd_state(); pf = new_portfwd_state();
pf->plugvt = &PortForwarding_plugvt; pf->plug.vt = &PortForwarding_plugvt;
pf->chan.initial_fixed_window_size = 0; pf->chan.initial_fixed_window_size = 0;
pf->chan.vt = &PortForwarding_channelvt; pf->chan.vt = &PortForwarding_channelvt;
pf->input_wanted = TRUE; pf->input_wanted = TRUE;
@ -483,7 +483,7 @@ static int pfl_accepting(Plug *p, accept_fn_t constructor, accept_ctx_t ctx)
pf->c = NULL; pf->c = NULL;
pf->cl = pl->cl; pf->cl = pl->cl;
pf->s = s = constructor(ctx, &pf->plugvt); pf->s = s = constructor(ctx, &pf->plug);
if ((err = sk_socket_error(s)) != NULL) { if ((err = sk_socket_error(s)) != NULL) {
free_portfwd_state(pf); free_portfwd_state(pf);
return err != NULL; return err != NULL;
@ -536,7 +536,7 @@ static char *pfl_listen(char *desthost, int destport, char *srcaddr,
* Open socket. * Open socket.
*/ */
pl = *pl_ret = new_portlistener_state(); pl = *pl_ret = new_portlistener_state();
pl->plugvt = &PortListener_plugvt; pl->plug.vt = &PortListener_plugvt;
if (desthost) { if (desthost) {
pl->hostname = dupstr(desthost); pl->hostname = dupstr(desthost);
pl->port = destport; pl->port = destport;
@ -545,7 +545,7 @@ static char *pfl_listen(char *desthost, int destport, char *srcaddr,
pl->is_dynamic = TRUE; pl->is_dynamic = TRUE;
pl->cl = cl; pl->cl = cl;
pl->s = new_listener(srcaddr, port, &pl->plugvt, pl->s = new_listener(srcaddr, port, &pl->plug,
!conf_get_int(conf, CONF_lport_acceptall), !conf_get_int(conf, CONF_lport_acceptall),
conf, address_family); conf, address_family);
if ((err = sk_socket_error(pl->s)) != NULL) { if ((err = sk_socket_error(pl->s)) != NULL) {
@ -1042,7 +1042,7 @@ char *portfwdmgr_connect(PortFwdManager *mgr, Channel **chan_ret,
*/ */
pf = new_portfwd_state(); pf = new_portfwd_state();
*chan_ret = &pf->chan; *chan_ret = &pf->chan;
pf->plugvt = &PortForwarding_plugvt; pf->plug.vt = &PortForwarding_plugvt;
pf->chan.initial_fixed_window_size = 0; pf->chan.initial_fixed_window_size = 0;
pf->chan.vt = &PortForwarding_channelvt; pf->chan.vt = &PortForwarding_channelvt;
pf->input_wanted = TRUE; pf->input_wanted = TRUE;
@ -1052,7 +1052,7 @@ char *portfwdmgr_connect(PortFwdManager *mgr, Channel **chan_ret,
pf->socks_state = SOCKS_NONE; pf->socks_state = SOCKS_NONE;
pf->s = new_connection(addr, dummy_realhost, port, pf->s = new_connection(addr, dummy_realhost, port,
0, 1, 0, 0, &pf->plugvt, mgr->conf); 0, 1, 0, 0, &pf->plug, mgr->conf);
sfree(dummy_realhost); sfree(dummy_realhost);
if ((err = sk_socket_error(pf->s)) != NULL) { if ((err = sk_socket_error(pf->s)) != NULL) {
char *err_ret = dupstr(err); char *err_ret = dupstr(err);

42
proxy.c
View File

@ -73,14 +73,14 @@ void proxy_activate (ProxySocket *p)
* unfreezing the actual underlying socket. * unfreezing the actual underlying socket.
*/ */
if (!p->freeze) if (!p->freeze)
sk_set_frozen(&p->sockvt, 0); sk_set_frozen(&p->sock, 0);
} }
/* basic proxy socket functions */ /* basic proxy socket functions */
static Plug *sk_proxy_plug (Socket *s, Plug *p) static Plug *sk_proxy_plug (Socket *s, Plug *p)
{ {
ProxySocket *ps = FROMFIELD(s, ProxySocket, sockvt); ProxySocket *ps = FROMFIELD(s, ProxySocket, sock);
Plug *ret = ps->plug; Plug *ret = ps->plug;
if (p) if (p)
ps->plug = p; ps->plug = p;
@ -89,7 +89,7 @@ static Plug *sk_proxy_plug (Socket *s, Plug *p)
static void sk_proxy_close (Socket *s) static void sk_proxy_close (Socket *s)
{ {
ProxySocket *ps = FROMFIELD(s, ProxySocket, sockvt); ProxySocket *ps = FROMFIELD(s, ProxySocket, sock);
sk_close(ps->sub_socket); sk_close(ps->sub_socket);
sk_addr_free(ps->remote_addr); sk_addr_free(ps->remote_addr);
@ -98,7 +98,7 @@ static void sk_proxy_close (Socket *s)
static int sk_proxy_write (Socket *s, const void *data, int len) static int sk_proxy_write (Socket *s, const void *data, int len)
{ {
ProxySocket *ps = FROMFIELD(s, ProxySocket, sockvt); ProxySocket *ps = FROMFIELD(s, ProxySocket, sock);
if (ps->state != PROXY_STATE_ACTIVE) { if (ps->state != PROXY_STATE_ACTIVE) {
bufchain_add(&ps->pending_output_data, data, len); bufchain_add(&ps->pending_output_data, data, len);
@ -109,7 +109,7 @@ static int sk_proxy_write (Socket *s, const void *data, int len)
static int sk_proxy_write_oob (Socket *s, const void *data, int len) static int sk_proxy_write_oob (Socket *s, const void *data, int len)
{ {
ProxySocket *ps = FROMFIELD(s, ProxySocket, sockvt); ProxySocket *ps = FROMFIELD(s, ProxySocket, sock);
if (ps->state != PROXY_STATE_ACTIVE) { if (ps->state != PROXY_STATE_ACTIVE) {
bufchain_clear(&ps->pending_output_data); bufchain_clear(&ps->pending_output_data);
@ -122,7 +122,7 @@ static int sk_proxy_write_oob (Socket *s, const void *data, int len)
static void sk_proxy_write_eof (Socket *s) static void sk_proxy_write_eof (Socket *s)
{ {
ProxySocket *ps = FROMFIELD(s, ProxySocket, sockvt); ProxySocket *ps = FROMFIELD(s, ProxySocket, sock);
if (ps->state != PROXY_STATE_ACTIVE) { if (ps->state != PROXY_STATE_ACTIVE) {
ps->pending_eof = 1; ps->pending_eof = 1;
@ -133,7 +133,7 @@ static void sk_proxy_write_eof (Socket *s)
static void sk_proxy_flush (Socket *s) static void sk_proxy_flush (Socket *s)
{ {
ProxySocket *ps = FROMFIELD(s, ProxySocket, sockvt); ProxySocket *ps = FROMFIELD(s, ProxySocket, sock);
if (ps->state != PROXY_STATE_ACTIVE) { if (ps->state != PROXY_STATE_ACTIVE) {
ps->pending_flush = 1; ps->pending_flush = 1;
@ -144,7 +144,7 @@ static void sk_proxy_flush (Socket *s)
static void sk_proxy_set_frozen (Socket *s, int is_frozen) static void sk_proxy_set_frozen (Socket *s, int is_frozen)
{ {
ProxySocket *ps = FROMFIELD(s, ProxySocket, sockvt); ProxySocket *ps = FROMFIELD(s, ProxySocket, sock);
if (ps->state != PROXY_STATE_ACTIVE) { if (ps->state != PROXY_STATE_ACTIVE) {
ps->freeze = is_frozen; ps->freeze = is_frozen;
@ -183,7 +183,7 @@ static void sk_proxy_set_frozen (Socket *s, int is_frozen)
static const char * sk_proxy_socket_error (Socket *s) static const char * sk_proxy_socket_error (Socket *s)
{ {
ProxySocket *ps = FROMFIELD(s, ProxySocket, sockvt); ProxySocket *ps = FROMFIELD(s, ProxySocket, sock);
if (ps->error != NULL || ps->sub_socket == NULL) { if (ps->error != NULL || ps->sub_socket == NULL) {
return ps->error; return ps->error;
} }
@ -195,7 +195,7 @@ static const char * sk_proxy_socket_error (Socket *s)
static void plug_proxy_log(Plug *plug, int type, SockAddr *addr, int port, static void plug_proxy_log(Plug *plug, int type, SockAddr *addr, int port,
const char *error_msg, int error_code) const char *error_msg, int error_code)
{ {
ProxySocket *ps = FROMFIELD(plug, ProxySocket, plugvt); ProxySocket *ps = FROMFIELD(plug, ProxySocket, plugimpl);
plug_log(ps->plug, type, addr, port, error_msg, error_code); plug_log(ps->plug, type, addr, port, error_msg, error_code);
} }
@ -203,7 +203,7 @@ static void plug_proxy_log(Plug *plug, int type, SockAddr *addr, int port,
static void plug_proxy_closing (Plug *p, const char *error_msg, static void plug_proxy_closing (Plug *p, const char *error_msg,
int error_code, int calling_back) int error_code, int calling_back)
{ {
ProxySocket *ps = FROMFIELD(p, ProxySocket, plugvt); ProxySocket *ps = FROMFIELD(p, ProxySocket, plugimpl);
if (ps->state != PROXY_STATE_ACTIVE) { if (ps->state != PROXY_STATE_ACTIVE) {
ps->closing_error_msg = error_msg; ps->closing_error_msg = error_msg;
@ -217,7 +217,7 @@ static void plug_proxy_closing (Plug *p, const char *error_msg,
static void plug_proxy_receive (Plug *p, int urgent, char *data, int len) static void plug_proxy_receive (Plug *p, int urgent, char *data, int len)
{ {
ProxySocket *ps = FROMFIELD(p, ProxySocket, plugvt); ProxySocket *ps = FROMFIELD(p, ProxySocket, plugimpl);
if (ps->state != PROXY_STATE_ACTIVE) { if (ps->state != PROXY_STATE_ACTIVE) {
/* we will lose the urgentness of this data, but since most, /* we will lose the urgentness of this data, but since most,
@ -236,7 +236,7 @@ static void plug_proxy_receive (Plug *p, int urgent, char *data, int len)
static void plug_proxy_sent (Plug *p, int bufsize) static void plug_proxy_sent (Plug *p, int bufsize)
{ {
ProxySocket *ps = FROMFIELD(p, ProxySocket, plugvt); ProxySocket *ps = FROMFIELD(p, ProxySocket, plugimpl);
if (ps->state != PROXY_STATE_ACTIVE) { if (ps->state != PROXY_STATE_ACTIVE) {
ps->sent_bufsize = bufsize; ps->sent_bufsize = bufsize;
@ -249,7 +249,7 @@ static void plug_proxy_sent (Plug *p, int bufsize)
static int plug_proxy_accepting(Plug *p, static int plug_proxy_accepting(Plug *p,
accept_fn_t constructor, accept_ctx_t ctx) accept_fn_t constructor, accept_ctx_t ctx)
{ {
ProxySocket *ps = FROMFIELD(p, ProxySocket, plugvt); ProxySocket *ps = FROMFIELD(p, ProxySocket, plugimpl);
if (ps->state != PROXY_STATE_ACTIVE) { if (ps->state != PROXY_STATE_ACTIVE) {
ps->accepting_constructor = constructor; ps->accepting_constructor = constructor;
@ -438,8 +438,8 @@ Socket *new_connection(SockAddr *addr, const char *hostname,
return sret; return sret;
ret = snew(ProxySocket); ret = snew(ProxySocket);
ret->sockvt = &ProxySocket_sockvt; ret->sock.vt = &ProxySocket_sockvt;
ret->plugvt = &ProxySocket_plugvt; ret->plugimpl.vt = &ProxySocket_plugvt;
ret->conf = conf_copy(conf); ret->conf = conf_copy(conf);
ret->plug = plug; ret->plug = plug;
ret->remote_addr = addr; /* will need to be freed on close */ ret->remote_addr = addr; /* will need to be freed on close */
@ -473,7 +473,7 @@ Socket *new_connection(SockAddr *addr, const char *hostname,
proxy_type = "Telnet"; proxy_type = "Telnet";
} else { } else {
ret->error = "Proxy error: Unknown proxy method"; ret->error = "Proxy error: Unknown proxy method";
return &ret->sockvt; return &ret->sock;
} }
{ {
@ -501,7 +501,7 @@ Socket *new_connection(SockAddr *addr, const char *hostname,
if (sk_addr_error(proxy_addr) != NULL) { if (sk_addr_error(proxy_addr) != NULL) {
ret->error = "Proxy error: Unable to resolve proxy host name"; ret->error = "Proxy error: Unable to resolve proxy host name";
sk_addr_free(proxy_addr); sk_addr_free(proxy_addr);
return &ret->sockvt; return &ret->sock;
} }
sfree(proxy_canonical_name); sfree(proxy_canonical_name);
@ -521,15 +521,15 @@ Socket *new_connection(SockAddr *addr, const char *hostname,
ret->sub_socket = sk_new(proxy_addr, ret->sub_socket = sk_new(proxy_addr,
conf_get_int(conf, CONF_proxy_port), conf_get_int(conf, CONF_proxy_port),
privport, oobinline, privport, oobinline,
nodelay, keepalive, &ret->plugvt); nodelay, keepalive, &ret->plugimpl);
if (sk_socket_error(ret->sub_socket) != NULL) if (sk_socket_error(ret->sub_socket) != NULL)
return &ret->sockvt; return &ret->sock;
/* start the proxy negotiation process... */ /* start the proxy negotiation process... */
sk_set_frozen(ret->sub_socket, 0); sk_set_frozen(ret->sub_socket, 0);
ret->negotiate(ret, PROXY_CHANGE_NEW); ret->negotiate(ret, PROXY_CHANGE_NEW);
return &ret->sockvt; return &ret->sock;
} }
/* no proxy, so just return the direct socket */ /* no proxy, so just return the direct socket */

View File

@ -87,8 +87,8 @@ struct ProxySocket {
int chap_current_attribute; int chap_current_attribute;
int chap_current_datalen; int chap_current_datalen;
const SocketVtable *sockvt; Socket sock;
const PlugVtable *plugvt; Plug plugimpl;
}; };
extern void proxy_activate (ProxySocket *); extern void proxy_activate (ProxySocket *);

14
raw.c
View File

@ -20,7 +20,7 @@ struct Raw {
Conf *conf; Conf *conf;
const PlugVtable *plugvt; Plug plug;
Backend backend; Backend backend;
}; };
@ -35,7 +35,7 @@ static void c_write(Raw *raw, const void *buf, int len)
static void raw_log(Plug *plug, int type, SockAddr *addr, int port, static void raw_log(Plug *plug, int type, SockAddr *addr, int port,
const char *error_msg, int error_code) const char *error_msg, int error_code)
{ {
Raw *raw = FROMFIELD(plug, Raw, plugvt); Raw *raw = FROMFIELD(plug, Raw, plug);
backend_socket_log(raw->frontend, type, addr, port, backend_socket_log(raw->frontend, type, addr, port,
error_msg, error_code, raw->conf, raw->session_started); error_msg, error_code, raw->conf, raw->session_started);
} }
@ -58,7 +58,7 @@ static void raw_check_close(Raw *raw)
static void raw_closing(Plug *plug, const char *error_msg, int error_code, static void raw_closing(Plug *plug, const char *error_msg, int error_code,
int calling_back) int calling_back)
{ {
Raw *raw = FROMFIELD(plug, Raw, plugvt); Raw *raw = FROMFIELD(plug, Raw, plug);
if (error_msg) { if (error_msg) {
/* A socket error has occurred. */ /* A socket error has occurred. */
@ -90,7 +90,7 @@ static void raw_closing(Plug *plug, const char *error_msg, int error_code,
static void raw_receive(Plug *plug, int urgent, char *data, int len) static void raw_receive(Plug *plug, int urgent, char *data, int len)
{ {
Raw *raw = FROMFIELD(plug, Raw, plugvt); Raw *raw = FROMFIELD(plug, Raw, plug);
c_write(raw, data, len); c_write(raw, data, len);
/* We count 'session start', for proxy logging purposes, as being /* We count 'session start', for proxy logging purposes, as being
* when data is received from the network and printed. */ * when data is received from the network and printed. */
@ -99,7 +99,7 @@ static void raw_receive(Plug *plug, int urgent, char *data, int len)
static void raw_sent(Plug *plug, int bufsize) static void raw_sent(Plug *plug, int bufsize)
{ {
Raw *raw = FROMFIELD(plug, Raw, plugvt); Raw *raw = FROMFIELD(plug, Raw, plug);
raw->bufsize = bufsize; raw->bufsize = bufsize;
} }
@ -130,7 +130,7 @@ static const char *raw_init(Frontend *frontend, Backend **backend_handle,
char *loghost; char *loghost;
raw = snew(Raw); raw = snew(Raw);
raw->plugvt = &Raw_plugvt; raw->plug.vt = &Raw_plugvt;
raw->backend.vt = &raw_backend; raw->backend.vt = &raw_backend;
raw->s = NULL; raw->s = NULL;
raw->closed_on_socket_error = FALSE; raw->closed_on_socket_error = FALSE;
@ -160,7 +160,7 @@ static const char *raw_init(Frontend *frontend, Backend **backend_handle,
* Open socket. * Open socket.
*/ */
raw->s = new_connection(addr, *realhost, port, 0, 1, nodelay, keepalive, raw->s = new_connection(addr, *realhost, port, 0, 1, nodelay, keepalive,
&raw->plugvt, conf); &raw->plug, conf);
if ((err = sk_socket_error(raw->s)) != NULL) if ((err = sk_socket_error(raw->s)) != NULL)
return err; return err;

View File

@ -26,7 +26,7 @@ struct Rlogin {
/* In case we need to read a username from the terminal before starting */ /* In case we need to read a username from the terminal before starting */
prompts_t *prompt; prompts_t *prompt;
const PlugVtable *plugvt; Plug plug;
Backend backend; Backend backend;
}; };
@ -39,7 +39,7 @@ static void c_write(Rlogin *rlogin, const void *buf, int len)
static void rlogin_log(Plug *plug, int type, SockAddr *addr, int port, static void rlogin_log(Plug *plug, int type, SockAddr *addr, int port,
const char *error_msg, int error_code) const char *error_msg, int error_code)
{ {
Rlogin *rlogin = FROMFIELD(plug, Rlogin, plugvt); Rlogin *rlogin = FROMFIELD(plug, Rlogin, plug);
backend_socket_log(rlogin->frontend, type, addr, port, backend_socket_log(rlogin->frontend, type, addr, port,
error_msg, error_code, error_msg, error_code,
rlogin->conf, !rlogin->firstbyte); rlogin->conf, !rlogin->firstbyte);
@ -48,7 +48,7 @@ static void rlogin_log(Plug *plug, int type, SockAddr *addr, int port,
static void rlogin_closing(Plug *plug, const char *error_msg, int error_code, static void rlogin_closing(Plug *plug, const char *error_msg, int error_code,
int calling_back) int calling_back)
{ {
Rlogin *rlogin = FROMFIELD(plug, Rlogin, plugvt); Rlogin *rlogin = FROMFIELD(plug, Rlogin, plug);
/* /*
* We don't implement independent EOF in each direction for Telnet * We don't implement independent EOF in each direction for Telnet
@ -72,7 +72,7 @@ static void rlogin_closing(Plug *plug, const char *error_msg, int error_code,
static void rlogin_receive(Plug *plug, int urgent, char *data, int len) static void rlogin_receive(Plug *plug, int urgent, char *data, int len)
{ {
Rlogin *rlogin = FROMFIELD(plug, Rlogin, plugvt); Rlogin *rlogin = FROMFIELD(plug, Rlogin, plug);
if (urgent == 2) { if (urgent == 2) {
char c; char c;
@ -109,7 +109,7 @@ static void rlogin_receive(Plug *plug, int urgent, char *data, int len)
static void rlogin_sent(Plug *plug, int bufsize) static void rlogin_sent(Plug *plug, int bufsize)
{ {
Rlogin *rlogin = FROMFIELD(plug, Rlogin, plugvt); Rlogin *rlogin = FROMFIELD(plug, Rlogin, plug);
rlogin->bufsize = bufsize; rlogin->bufsize = bufsize;
} }
@ -162,7 +162,7 @@ static const char *rlogin_init(Frontend *frontend, Backend **backend_handle,
char *loghost; char *loghost;
rlogin = snew(Rlogin); rlogin = snew(Rlogin);
rlogin->plugvt = &Rlogin_plugvt; rlogin->plug.vt = &Rlogin_plugvt;
rlogin->backend.vt = &rlogin_backend; rlogin->backend.vt = &rlogin_backend;
rlogin->s = NULL; rlogin->s = NULL;
rlogin->closed_on_socket_error = FALSE; rlogin->closed_on_socket_error = FALSE;
@ -193,7 +193,7 @@ static const char *rlogin_init(Frontend *frontend, Backend **backend_handle,
* Open socket. * Open socket.
*/ */
rlogin->s = new_connection(addr, *realhost, port, 1, 0, rlogin->s = new_connection(addr, *realhost, port, 1, 0,
nodelay, keepalive, &rlogin->plugvt, conf); nodelay, keepalive, &rlogin->plug, conf);
if ((err = sk_socket_error(rlogin->s)) != NULL) if ((err = sk_socket_error(rlogin->s)) != NULL)
return err; return err;

16
ssh.c
View File

@ -37,7 +37,7 @@ struct Ssh {
struct ssh_version_receiver version_receiver; struct ssh_version_receiver version_receiver;
int remote_bugs; int remote_bugs;
const PlugVtable *plugvt; Plug plug;
Backend backend; Backend backend;
Ldisc *ldisc; Ldisc *ldisc;
@ -489,7 +489,7 @@ void ssh_user_close(Ssh *ssh, const char *fmt, ...)
static void ssh_socket_log(Plug *plug, int type, SockAddr *addr, int port, static void ssh_socket_log(Plug *plug, int type, SockAddr *addr, int port,
const char *error_msg, int error_code) const char *error_msg, int error_code)
{ {
Ssh *ssh = FROMFIELD(plug, Ssh, plugvt); Ssh *ssh = FROMFIELD(plug, Ssh, plug);
/* /*
* While we're attempting connection sharing, don't loudly log * While we're attempting connection sharing, don't loudly log
@ -509,7 +509,7 @@ static void ssh_socket_log(Plug *plug, int type, SockAddr *addr, int port,
static void ssh_closing(Plug *plug, const char *error_msg, int error_code, static void ssh_closing(Plug *plug, const char *error_msg, int error_code,
int calling_back) int calling_back)
{ {
Ssh *ssh = FROMFIELD(plug, Ssh, plugvt); Ssh *ssh = FROMFIELD(plug, Ssh, plug);
if (error_msg) { if (error_msg) {
ssh_remote_error(ssh, "Network error: %s", error_msg); ssh_remote_error(ssh, "Network error: %s", error_msg);
} else if (ssh->bpp) { } else if (ssh->bpp) {
@ -520,7 +520,7 @@ static void ssh_closing(Plug *plug, const char *error_msg, int error_code,
static void ssh_receive(Plug *plug, int urgent, char *data, int len) static void ssh_receive(Plug *plug, int urgent, char *data, int len)
{ {
Ssh *ssh = FROMFIELD(plug, Ssh, plugvt); Ssh *ssh = FROMFIELD(plug, Ssh, plug);
/* Log raw data, if we're in that mode. */ /* Log raw data, if we're in that mode. */
if (ssh->logctx) if (ssh->logctx)
@ -534,7 +534,7 @@ static void ssh_receive(Plug *plug, int urgent, char *data, int len)
static void ssh_sent(Plug *plug, int bufsize) static void ssh_sent(Plug *plug, int bufsize)
{ {
Ssh *ssh = FROMFIELD(plug, Ssh, plugvt); Ssh *ssh = FROMFIELD(plug, Ssh, plug);
/* /*
* If the send backlog on the SSH socket itself clears, we should * If the send backlog on the SSH socket itself clears, we should
* unthrottle the whole world if it was throttled. Also trigger an * unthrottle the whole world if it was throttled. Also trigger an
@ -624,7 +624,7 @@ static const char *connect_to_host(Ssh *ssh, const char *host, int port,
ssh_hostport_setup(host, port, ssh->conf, ssh_hostport_setup(host, port, ssh->conf,
&ssh->savedhost, &ssh->savedport, &loghost); &ssh->savedhost, &ssh->savedport, &loghost);
ssh->plugvt = &Ssh_plugvt; ssh->plug.vt = &Ssh_plugvt;
/* /*
* Try connection-sharing, in case that means we don't open a * Try connection-sharing, in case that means we don't open a
@ -639,7 +639,7 @@ static const char *connect_to_host(Ssh *ssh, const char *host, int port,
ssh->attempting_connshare = TRUE; /* affects socket logging behaviour */ ssh->attempting_connshare = TRUE; /* affects socket logging behaviour */
ssh->s = ssh_connection_sharing_init( ssh->s = ssh_connection_sharing_init(
ssh->savedhost, ssh->savedport, ssh->conf, ssh->frontend, ssh->savedhost, ssh->savedport, ssh->conf, ssh->frontend,
&ssh->plugvt, &ssh->connshare); &ssh->plug, &ssh->connshare);
ssh->attempting_connshare = FALSE; ssh->attempting_connshare = FALSE;
if (ssh->s != NULL) { if (ssh->s != NULL) {
/* /*
@ -677,7 +677,7 @@ static const char *connect_to_host(Ssh *ssh, const char *host, int port,
ssh->s = new_connection(addr, *realhost, port, ssh->s = new_connection(addr, *realhost, port,
0, 1, nodelay, keepalive, 0, 1, nodelay, keepalive,
&ssh->plugvt, ssh->conf); &ssh->plug, ssh->conf);
if ((err = sk_socket_error(ssh->s)) != NULL) { if ((err = sk_socket_error(ssh->s)) != NULL) {
ssh->s = NULL; ssh->s = NULL;
notify_remote_exit(ssh->frontend); notify_remote_exit(ssh->frontend);

View File

@ -147,7 +147,7 @@ struct ssh_sharing_state {
ConnectionLayer *cl; /* instance of the ssh connection layer */ ConnectionLayer *cl; /* instance of the ssh connection layer */
char *server_verstring; /* server version string after "SSH-" */ char *server_verstring; /* server version string after "SSH-" */
const PlugVtable *plugvt; Plug plug;
}; };
struct share_globreq; struct share_globreq;
@ -200,7 +200,7 @@ struct ssh_sharing_connstate {
/* Global requests we've sent on to the server, pending replies. */ /* Global requests we've sent on to the server, pending replies. */
struct share_globreq *globreq_head, *globreq_tail; struct share_globreq *globreq_head, *globreq_tail;
const PlugVtable *plugvt; Plug plug;
}; };
struct share_halfchannel { struct share_halfchannel {
@ -951,7 +951,7 @@ static void share_closing(Plug *plug, const char *error_msg, int error_code,
int calling_back) int calling_back)
{ {
struct ssh_sharing_connstate *cs = FROMFIELD( struct ssh_sharing_connstate *cs = FROMFIELD(
plug, struct ssh_sharing_connstate, plugvt); plug, struct ssh_sharing_connstate, plug);
if (error_msg) { if (error_msg) {
#ifdef BROKEN_PIPE_ERROR_CODE #ifdef BROKEN_PIPE_ERROR_CODE
@ -1767,7 +1767,7 @@ static void share_got_pkt_from_downstream(struct ssh_sharing_connstate *cs,
static void share_receive(Plug *plug, int urgent, char *data, int len) static void share_receive(Plug *plug, int urgent, char *data, int len)
{ {
ssh_sharing_connstate *cs = FROMFIELD( ssh_sharing_connstate *cs = FROMFIELD(
plug, ssh_sharing_connstate, plugvt); plug, ssh_sharing_connstate, plug);
static const char expected_verstring_prefix[] = static const char expected_verstring_prefix[] =
"SSHCONNECTION@putty.projects.tartarus.org-2.0-"; "SSHCONNECTION@putty.projects.tartarus.org-2.0-";
unsigned char c; unsigned char c;
@ -1843,7 +1843,7 @@ static void share_receive(Plug *plug, int urgent, char *data, int len)
static void share_sent(Plug *plug, int bufsize) static void share_sent(Plug *plug, int bufsize)
{ {
/* ssh_sharing_connstate *cs = FROMFIELD( /* ssh_sharing_connstate *cs = FROMFIELD(
plug, ssh_sharing_connstate, plugvt); */ plug, ssh_sharing_connstate, plug); */
/* /*
* We do nothing here, because we expect that there won't be a * We do nothing here, because we expect that there won't be a
@ -1858,7 +1858,7 @@ static void share_sent(Plug *plug, int bufsize)
static void share_listen_closing(Plug *plug, const char *error_msg, static void share_listen_closing(Plug *plug, const char *error_msg,
int error_code, int calling_back) int error_code, int calling_back)
{ {
ssh_sharing_state *sharestate = FROMFIELD(plug, ssh_sharing_state, plugvt); ssh_sharing_state *sharestate = FROMFIELD(plug, ssh_sharing_state, plug);
if (error_msg) if (error_msg)
log_general(sharestate, "listening socket: %s", error_msg); log_general(sharestate, "listening socket: %s", error_msg);
sk_close(sharestate->listensock); sk_close(sharestate->listensock);
@ -1922,7 +1922,7 @@ static int share_listen_accepting(Plug *plug,
accept_fn_t constructor, accept_ctx_t ctx) accept_fn_t constructor, accept_ctx_t ctx)
{ {
struct ssh_sharing_state *sharestate = FROMFIELD( struct ssh_sharing_state *sharestate = FROMFIELD(
plug, struct ssh_sharing_state, plugvt); plug, struct ssh_sharing_state, plug);
struct ssh_sharing_connstate *cs; struct ssh_sharing_connstate *cs;
const char *err; const char *err;
char *peerinfo; char *peerinfo;
@ -1931,7 +1931,7 @@ static int share_listen_accepting(Plug *plug,
* A new downstream has connected to us. * A new downstream has connected to us.
*/ */
cs = snew(struct ssh_sharing_connstate); cs = snew(struct ssh_sharing_connstate);
cs->plugvt = &ssh_sharing_conn_plugvt; cs->plug.vt = &ssh_sharing_conn_plugvt;
cs->parent = sharestate; cs->parent = sharestate;
if ((cs->id = share_find_unused_id(sharestate, sharestate->nextid)) == 0 && if ((cs->id = share_find_unused_id(sharestate, sharestate->nextid)) == 0 &&
@ -1943,7 +1943,7 @@ static int share_listen_accepting(Plug *plug,
if (sharestate->nextid == 0) if (sharestate->nextid == 0)
sharestate->nextid++; /* only happens in VERY long-running upstreams */ sharestate->nextid++; /* only happens in VERY long-running upstreams */
cs->sock = constructor(ctx, &cs->plugvt); cs->sock = constructor(ctx, &cs->plug);
if ((err = sk_socket_error(cs->sock)) != NULL) { if ((err = sk_socket_error(cs->sock)) != NULL) {
sfree(cs); sfree(cs);
return err != NULL; return err != NULL;
@ -2104,7 +2104,7 @@ Socket *ssh_connection_sharing_init(
* to be an upstream. * to be an upstream.
*/ */
sharestate = snew(struct ssh_sharing_state); sharestate = snew(struct ssh_sharing_state);
sharestate->plugvt = &ssh_sharing_listen_plugvt; sharestate->plug.vt = &ssh_sharing_listen_plugvt;
sharestate->listensock = NULL; sharestate->listensock = NULL;
sharestate->cl = NULL; sharestate->cl = NULL;
@ -2118,7 +2118,7 @@ Socket *ssh_connection_sharing_init(
sock = NULL; sock = NULL;
logtext = ds_err = us_err = NULL; logtext = ds_err = us_err = NULL;
result = platform_ssh_share( result = platform_ssh_share(
sockname, conf, sshplug, &sharestate->plugvt, &sock, &logtext, sockname, conf, sshplug, &sharestate->plug, &sock, &logtext,
&ds_err, &us_err, can_upstream, can_downstream); &ds_err, &us_err, can_upstream, can_downstream);
switch (result) { switch (result) {
case SHARE_NONE: case SHARE_NONE:

View File

@ -197,7 +197,7 @@ struct Telnet {
Pinger *pinger; Pinger *pinger;
const PlugVtable *plugvt; Plug plug;
Backend backend; Backend backend;
}; };
@ -645,7 +645,7 @@ static void do_telnet_read(Telnet *telnet, char *buf, int len)
static void telnet_log(Plug *plug, int type, SockAddr *addr, int port, static void telnet_log(Plug *plug, int type, SockAddr *addr, int port,
const char *error_msg, int error_code) const char *error_msg, int error_code)
{ {
Telnet *telnet = FROMFIELD(plug, Telnet, plugvt); Telnet *telnet = FROMFIELD(plug, Telnet, plug);
backend_socket_log(telnet->frontend, type, addr, port, backend_socket_log(telnet->frontend, type, addr, port,
error_msg, error_code, telnet->conf, error_msg, error_code, telnet->conf,
telnet->session_started); telnet->session_started);
@ -654,7 +654,7 @@ static void telnet_log(Plug *plug, int type, SockAddr *addr, int port,
static void telnet_closing(Plug *plug, const char *error_msg, int error_code, static void telnet_closing(Plug *plug, const char *error_msg, int error_code,
int calling_back) int calling_back)
{ {
Telnet *telnet = FROMFIELD(plug, Telnet, plugvt); Telnet *telnet = FROMFIELD(plug, Telnet, plug);
/* /*
* We don't implement independent EOF in each direction for Telnet * We don't implement independent EOF in each direction for Telnet
@ -678,7 +678,7 @@ static void telnet_closing(Plug *plug, const char *error_msg, int error_code,
static void telnet_receive(Plug *plug, int urgent, char *data, int len) static void telnet_receive(Plug *plug, int urgent, char *data, int len)
{ {
Telnet *telnet = FROMFIELD(plug, Telnet, plugvt); Telnet *telnet = FROMFIELD(plug, Telnet, plug);
if (urgent) if (urgent)
telnet->in_synch = TRUE; telnet->in_synch = TRUE;
telnet->session_started = TRUE; telnet->session_started = TRUE;
@ -687,7 +687,7 @@ static void telnet_receive(Plug *plug, int urgent, char *data, int len)
static void telnet_sent(Plug *plug, int bufsize) static void telnet_sent(Plug *plug, int bufsize)
{ {
Telnet *telnet = FROMFIELD(plug, Telnet, plugvt); Telnet *telnet = FROMFIELD(plug, Telnet, plug);
telnet->bufsize = bufsize; telnet->bufsize = bufsize;
} }
@ -717,7 +717,7 @@ static const char *telnet_init(Frontend *frontend, Backend **backend_handle,
int addressfamily; int addressfamily;
telnet = snew(Telnet); telnet = snew(Telnet);
telnet->plugvt = &Telnet_plugvt; telnet->plug.vt = &Telnet_plugvt;
telnet->backend.vt = &telnet_backend; telnet->backend.vt = &telnet_backend;
telnet->conf = conf_copy(conf); telnet->conf = conf_copy(conf);
telnet->s = NULL; telnet->s = NULL;
@ -754,7 +754,7 @@ static const char *telnet_init(Frontend *frontend, Backend **backend_handle,
* Open socket. * Open socket.
*/ */
telnet->s = new_connection(addr, *realhost, port, 0, 1, nodelay, keepalive, telnet->s = new_connection(addr, *realhost, port, 0, 1, nodelay, keepalive,
&telnet->plugvt, telnet->conf); &telnet->plug, telnet->conf);
if ((err = sk_socket_error(telnet->s)) != NULL) if ((err = sk_socket_error(telnet->s)) != NULL)
return err; return err;

View File

@ -89,7 +89,7 @@ struct NetSocket {
*/ */
NetSocket *parent, *child; NetSocket *parent, *child;
const SocketVtable *sockvt; Socket sock;
}; };
struct SockAddr { struct SockAddr {
@ -484,7 +484,7 @@ SockAddr *sk_addr_dup(SockAddr *addr)
static Plug *sk_net_plug(Socket *sock, Plug *p) static Plug *sk_net_plug(Socket *sock, Plug *p)
{ {
NetSocket *s = FROMFIELD(sock, NetSocket, sockvt); NetSocket *s = FROMFIELD(sock, NetSocket, sock);
Plug *ret = s->plug; Plug *ret = s->plug;
if (p) if (p)
s->plug = p; s->plug = p;
@ -528,7 +528,7 @@ static Socket *sk_net_accept(accept_ctx_t ctx, Plug *plug)
* Create NetSocket structure. * Create NetSocket structure.
*/ */
ret = snew(NetSocket); ret = snew(NetSocket);
ret->sockvt = &NetSocket_sockvt; ret->sock.vt = &NetSocket_sockvt;
ret->error = NULL; ret->error = NULL;
ret->plug = plug; ret->plug = plug;
bufchain_init(&ret->output_data); bufchain_init(&ret->output_data);
@ -549,7 +549,7 @@ static Socket *sk_net_accept(accept_ctx_t ctx, Plug *plug)
if (ret->s < 0) { if (ret->s < 0) {
ret->error = strerror(errno); ret->error = strerror(errno);
return &ret->sockvt; return &ret->sock;
} }
ret->oobinline = 0; ret->oobinline = 0;
@ -557,7 +557,7 @@ static Socket *sk_net_accept(accept_ctx_t ctx, Plug *plug)
uxsel_tell(ret); uxsel_tell(ret);
add234(sktree, ret); add234(sktree, ret);
return &ret->sockvt; return &ret->sock;
} }
static int try_connect(NetSocket *sock) static int try_connect(NetSocket *sock)
@ -769,7 +769,7 @@ Socket *sk_new(SockAddr *addr, int port, int privport, int oobinline,
* Create NetSocket structure. * Create NetSocket structure.
*/ */
ret = snew(NetSocket); ret = snew(NetSocket);
ret->sockvt = &NetSocket_sockvt; ret->sock.vt = &NetSocket_sockvt;
ret->error = NULL; ret->error = NULL;
ret->plug = plug; ret->plug = plug;
bufchain_init(&ret->output_data); bufchain_init(&ret->output_data);
@ -801,7 +801,7 @@ Socket *sk_new(SockAddr *addr, int port, int privport, int oobinline,
if (err) if (err)
ret->error = strerror(err); ret->error = strerror(err);
return &ret->sockvt; return &ret->sock;
} }
Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug, Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
@ -824,7 +824,7 @@ Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
* Create NetSocket structure. * Create NetSocket structure.
*/ */
ret = snew(NetSocket); ret = snew(NetSocket);
ret->sockvt = &NetSocket_sockvt; ret->sock.vt = &NetSocket_sockvt;
ret->error = NULL; ret->error = NULL;
ret->plug = plug; ret->plug = plug;
bufchain_init(&ret->output_data); bufchain_init(&ret->output_data);
@ -875,7 +875,7 @@ Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
if (s < 0) { if (s < 0) {
ret->error = strerror(errno); ret->error = strerror(errno);
return &ret->sockvt; return &ret->sock;
} }
cloexec(s); cloexec(s);
@ -886,7 +886,7 @@ Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
(const char *)&on, sizeof(on)) < 0) { (const char *)&on, sizeof(on)) < 0) {
ret->error = strerror(errno); ret->error = strerror(errno);
close(s); close(s);
return &ret->sockvt; return &ret->sock;
} }
retcode = -1; retcode = -1;
@ -964,13 +964,13 @@ Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
if (retcode < 0) { if (retcode < 0) {
close(s); close(s);
ret->error = strerror(errno); ret->error = strerror(errno);
return &ret->sockvt; return &ret->sock;
} }
if (listen(s, SOMAXCONN) < 0) { if (listen(s, SOMAXCONN) < 0) {
close(s); close(s);
ret->error = strerror(errno); ret->error = strerror(errno);
return &ret->sockvt; return &ret->sock;
} }
#ifndef NO_IPV6 #ifndef NO_IPV6
@ -984,7 +984,7 @@ Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
other = FROMFIELD( other = FROMFIELD(
sk_newlistener(srcaddr, port, plug, sk_newlistener(srcaddr, port, plug,
local_host_only, ADDRTYPE_IPV4), local_host_only, ADDRTYPE_IPV4),
NetSocket, sockvt); NetSocket, sock);
if (other) { if (other) {
if (!other->error) { if (!other->error) {
@ -995,7 +995,7 @@ Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
* as IPv6, we must return an error overall. */ * as IPv6, we must return an error overall. */
close(s); close(s);
sfree(ret); sfree(ret);
return &other->sockvt; return &other->sock;
} }
} }
} }
@ -1006,15 +1006,15 @@ Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
uxsel_tell(ret); uxsel_tell(ret);
add234(sktree, ret); add234(sktree, ret);
return &ret->sockvt; return &ret->sock;
} }
static void sk_net_close(Socket *sock) static void sk_net_close(Socket *sock)
{ {
NetSocket *s = FROMFIELD(sock, NetSocket, sockvt); NetSocket *s = FROMFIELD(sock, NetSocket, sock);
if (s->child) if (s->child)
sk_net_close(&s->child->sockvt); sk_net_close(&s->child->sock);
del234(sktree, s); del234(sktree, s);
if (s->s >= 0) { if (s->s >= 0) {
@ -1038,9 +1038,9 @@ void *sk_getxdmdata(Socket *sock, int *lenp)
* We must check that this socket really _is_ a NetSocket before * We must check that this socket really _is_ a NetSocket before
* downcasting it. * downcasting it.
*/ */
if (*sock != &NetSocket_sockvt) if (sock->vt != &NetSocket_sockvt)
return NULL; /* failure */ return NULL; /* failure */
s = FROMFIELD(sock, NetSocket, sockvt); s = FROMFIELD(sock, NetSocket, sock);
addrlen = sizeof(u); addrlen = sizeof(u);
if (getsockname(s->s, &u.sa, &addrlen) < 0) if (getsockname(s->s, &u.sa, &addrlen) < 0)
@ -1186,7 +1186,7 @@ void try_send(NetSocket *s)
static int sk_net_write(Socket *sock, const void *buf, int len) static int sk_net_write(Socket *sock, const void *buf, int len)
{ {
NetSocket *s = FROMFIELD(sock, NetSocket, sockvt); NetSocket *s = FROMFIELD(sock, NetSocket, sock);
assert(s->outgoingeof == EOF_NO); assert(s->outgoingeof == EOF_NO);
@ -1212,7 +1212,7 @@ static int sk_net_write(Socket *sock, const void *buf, int len)
static int sk_net_write_oob(Socket *sock, const void *buf, int len) static int sk_net_write_oob(Socket *sock, const void *buf, int len)
{ {
NetSocket *s = FROMFIELD(sock, NetSocket, sockvt); NetSocket *s = FROMFIELD(sock, NetSocket, sock);
assert(s->outgoingeof == EOF_NO); assert(s->outgoingeof == EOF_NO);
@ -1241,7 +1241,7 @@ static int sk_net_write_oob(Socket *sock, const void *buf, int len)
static void sk_net_write_eof(Socket *sock) static void sk_net_write_eof(Socket *sock)
{ {
NetSocket *s = FROMFIELD(sock, NetSocket, sockvt); NetSocket *s = FROMFIELD(sock, NetSocket, sock);
assert(s->outgoingeof == EOF_NO); assert(s->outgoingeof == EOF_NO);
@ -1468,13 +1468,13 @@ const char *sk_addr_error(SockAddr *addr)
} }
static const char *sk_net_socket_error(Socket *sock) static const char *sk_net_socket_error(Socket *sock)
{ {
NetSocket *s = FROMFIELD(sock, NetSocket, sockvt); NetSocket *s = FROMFIELD(sock, NetSocket, sock);
return s->error; return s->error;
} }
static void sk_net_set_frozen(Socket *sock, int is_frozen) static void sk_net_set_frozen(Socket *sock, int is_frozen)
{ {
NetSocket *s = FROMFIELD(sock, NetSocket, sockvt); NetSocket *s = FROMFIELD(sock, NetSocket, sock);
if (s->frozen == is_frozen) if (s->frozen == is_frozen)
return; return;
s->frozen = is_frozen; s->frozen = is_frozen;
@ -1483,7 +1483,7 @@ static void sk_net_set_frozen(Socket *sock, int is_frozen)
static char *sk_net_peer_info(Socket *sock) static char *sk_net_peer_info(Socket *sock)
{ {
NetSocket *s = FROMFIELD(sock, NetSocket, sockvt); NetSocket *s = FROMFIELD(sock, NetSocket, sock);
union sockaddr_union addr; union sockaddr_union addr;
socklen_t addrlen = sizeof(addr); socklen_t addrlen = sizeof(addr);
#ifndef NO_IPV6 #ifndef NO_IPV6
@ -1644,7 +1644,7 @@ Socket *new_unix_listener(SockAddr *listenaddr, Plug *plug)
* Create NetSocket structure. * Create NetSocket structure.
*/ */
ret = snew(NetSocket); ret = snew(NetSocket);
ret->sockvt = &NetSocket_sockvt; ret->sock.vt = &NetSocket_sockvt;
ret->error = NULL; ret->error = NULL;
ret->plug = plug; ret->plug = plug;
bufchain_init(&ret->output_data); bufchain_init(&ret->output_data);
@ -1669,7 +1669,7 @@ Socket *new_unix_listener(SockAddr *listenaddr, Plug *plug)
s = socket(AF_UNIX, SOCK_STREAM, 0); s = socket(AF_UNIX, SOCK_STREAM, 0);
if (s < 0) { if (s < 0) {
ret->error = strerror(errno); ret->error = strerror(errno);
return &ret->sockvt; return &ret->sock;
} }
cloexec(s); cloexec(s);
@ -1692,20 +1692,20 @@ Socket *new_unix_listener(SockAddr *listenaddr, Plug *plug)
if (unlink(u.su.sun_path) < 0 && errno != ENOENT) { if (unlink(u.su.sun_path) < 0 && errno != ENOENT) {
close(s); close(s);
ret->error = strerror(errno); ret->error = strerror(errno);
return &ret->sockvt; return &ret->sock;
} }
retcode = bind(s, &addr->sa, addrlen); retcode = bind(s, &addr->sa, addrlen);
if (retcode < 0) { if (retcode < 0) {
close(s); close(s);
ret->error = strerror(errno); ret->error = strerror(errno);
return &ret->sockvt; return &ret->sock;
} }
if (listen(s, SOMAXCONN) < 0) { if (listen(s, SOMAXCONN) < 0) {
close(s); close(s);
ret->error = strerror(errno); ret->error = strerror(errno);
return &ret->sockvt; return &ret->sock;
} }
ret->s = s; ret->s = s;
@ -1713,5 +1713,5 @@ Socket *new_unix_listener(SockAddr *listenaddr, Plug *plug)
uxsel_tell(ret); uxsel_tell(ret);
add234(sktree, ret); add234(sktree, ret);
return &ret->sockvt; return &ret->sock;
} }

View File

@ -176,7 +176,7 @@ static void x11_closing(Plug *plug, const char *error_msg, int error_code,
time_to_die = TRUE; time_to_die = TRUE;
} }
struct X11Connection { struct X11Connection {
const PlugVtable *plugvt; Plug plug;
}; };
char *socketname; char *socketname;
@ -809,10 +809,10 @@ void run_agent(void)
disp = x11_setup_display(display, conf); disp = x11_setup_display(display, conf);
conn = snew(struct X11Connection); conn = snew(struct X11Connection);
conn->plugvt = &X11Connection_plugvt; conn->plug.vt = &X11Connection_plugvt;
s = new_connection(sk_addr_dup(disp->addr), s = new_connection(sk_addr_dup(disp->addr),
disp->realhost, disp->port, disp->realhost, disp->port,
0, 1, 0, 0, &conn->plugvt, conf); 0, 1, 0, 0, &conn->plug, conf);
if ((err = sk_socket_error(s)) != NULL) { if ((err = sk_socket_error(s)) != NULL) {
fprintf(stderr, "pageant: unable to connect to X server: %s", err); fprintf(stderr, "pageant: unable to connect to X server: %s", err);
exit(1); exit(1);

View File

@ -29,7 +29,7 @@ typedef struct LocalProxySocket {
int pending_error; int pending_error;
const SocketVtable *sockvt; Socket sock;
} LocalProxySocket; } LocalProxySocket;
static void localproxy_select_result(int fd, int event); static void localproxy_select_result(int fd, int event);
@ -105,7 +105,7 @@ static int localproxy_errfd_find(void *av, void *bv)
static Plug *sk_localproxy_plug (Socket *s, Plug *p) static Plug *sk_localproxy_plug (Socket *s, Plug *p)
{ {
LocalProxySocket *ps = FROMFIELD(s, LocalProxySocket, sockvt); LocalProxySocket *ps = FROMFIELD(s, LocalProxySocket, sock);
Plug *ret = ps->plug; Plug *ret = ps->plug;
if (p) if (p)
ps->plug = p; ps->plug = p;
@ -114,7 +114,7 @@ static Plug *sk_localproxy_plug (Socket *s, Plug *p)
static void sk_localproxy_close (Socket *s) static void sk_localproxy_close (Socket *s)
{ {
LocalProxySocket *ps = FROMFIELD(s, LocalProxySocket, sockvt); LocalProxySocket *ps = FROMFIELD(s, LocalProxySocket, sock);
if (ps->to_cmd >= 0) { if (ps->to_cmd >= 0) {
del234(localproxy_by_tofd, ps); del234(localproxy_by_tofd, ps);
@ -202,7 +202,7 @@ static int localproxy_try_send(LocalProxySocket *ps)
static int sk_localproxy_write (Socket *s, const void *data, int len) static int sk_localproxy_write (Socket *s, const void *data, int len)
{ {
LocalProxySocket *ps = FROMFIELD(s, LocalProxySocket, sockvt); LocalProxySocket *ps = FROMFIELD(s, LocalProxySocket, sock);
assert(ps->outgoingeof == EOF_NO); assert(ps->outgoingeof == EOF_NO);
@ -224,7 +224,7 @@ static int sk_localproxy_write_oob (Socket *s, const void *data, int len)
static void sk_localproxy_write_eof (Socket *s) static void sk_localproxy_write_eof (Socket *s)
{ {
LocalProxySocket *ps = FROMFIELD(s, LocalProxySocket, sockvt); LocalProxySocket *ps = FROMFIELD(s, LocalProxySocket, sock);
assert(ps->outgoingeof == EOF_NO); assert(ps->outgoingeof == EOF_NO);
ps->outgoingeof = EOF_PENDING; ps->outgoingeof = EOF_PENDING;
@ -234,13 +234,13 @@ static void sk_localproxy_write_eof (Socket *s)
static void sk_localproxy_flush (Socket *s) static void sk_localproxy_flush (Socket *s)
{ {
/* LocalProxySocket *ps = FROMFIELD(s, LocalProxySocket, sockvt); */ /* LocalProxySocket *ps = FROMFIELD(s, LocalProxySocket, sock); */
/* do nothing */ /* do nothing */
} }
static void sk_localproxy_set_frozen (Socket *s, int is_frozen) static void sk_localproxy_set_frozen (Socket *s, int is_frozen)
{ {
LocalProxySocket *ps = FROMFIELD(s, LocalProxySocket, sockvt); LocalProxySocket *ps = FROMFIELD(s, LocalProxySocket, sock);
if (ps->from_cmd < 0) if (ps->from_cmd < 0)
return; return;
@ -253,7 +253,7 @@ static void sk_localproxy_set_frozen (Socket *s, int is_frozen)
static const char * sk_localproxy_socket_error (Socket *s) static const char * sk_localproxy_socket_error (Socket *s)
{ {
LocalProxySocket *ps = FROMFIELD(s, LocalProxySocket, sockvt); LocalProxySocket *ps = FROMFIELD(s, LocalProxySocket, sock);
return ps->error; return ps->error;
} }
@ -330,7 +330,7 @@ Socket *platform_new_connection(SockAddr *addr, const char *hostname,
return NULL; return NULL;
ret = snew(LocalProxySocket); ret = snew(LocalProxySocket);
ret->sockvt = &LocalProxySocket_sockvt; ret->sock.vt = &LocalProxySocket_sockvt;
ret->plug = plug; ret->plug = plug;
ret->error = NULL; ret->error = NULL;
ret->outgoingeof = EOF_NO; ret->outgoingeof = EOF_NO;
@ -358,7 +358,7 @@ Socket *platform_new_connection(SockAddr *addr, const char *hostname,
pipe(cmd_err_pipe) < 0) { pipe(cmd_err_pipe) < 0) {
ret->error = dupprintf("pipe: %s", strerror(errno)); ret->error = dupprintf("pipe: %s", strerror(errno));
sfree(cmd); sfree(cmd);
return &ret->sockvt; return &ret->sock;
} }
cloexec(to_cmd_pipe[1]); cloexec(to_cmd_pipe[1]);
cloexec(from_cmd_pipe[0]); cloexec(from_cmd_pipe[0]);
@ -369,7 +369,7 @@ Socket *platform_new_connection(SockAddr *addr, const char *hostname,
if (pid < 0) { if (pid < 0) {
ret->error = dupprintf("fork: %s", strerror(errno)); ret->error = dupprintf("fork: %s", strerror(errno));
sfree(cmd); sfree(cmd);
return &ret->sockvt; return &ret->sock;
} else if (pid == 0) { } else if (pid == 0) {
close(0); close(0);
close(1); close(1);
@ -399,13 +399,13 @@ Socket *platform_new_connection(SockAddr *addr, const char *hostname,
if (ret->to_cmd == -1) { if (ret->to_cmd == -1) {
ret->error = dupprintf("/dev/null: %s", strerror(errno)); ret->error = dupprintf("/dev/null: %s", strerror(errno));
sfree(cmd); sfree(cmd);
return &ret->sockvt; return &ret->sock;
} }
ret->from_cmd = open(cmd, O_RDONLY); ret->from_cmd = open(cmd, O_RDONLY);
if (ret->from_cmd == -1) { if (ret->from_cmd == -1) {
ret->error = dupprintf("%s: %s", cmd, strerror(errno)); ret->error = dupprintf("%s: %s", cmd, strerror(errno));
sfree(cmd); sfree(cmd);
return &ret->sockvt; return &ret->sock;
} }
sfree(cmd); sfree(cmd);
ret->cmd_err = -1; ret->cmd_err = -1;
@ -430,5 +430,5 @@ Socket *platform_new_connection(SockAddr *addr, const char *hostname,
/* We are responsible for this and don't need it any more */ /* We are responsible for this and don't need it any more */
sk_addr_free(addr); sk_addr_free(addr);
return &ret->sockvt; return &ret->sock;
} }

View File

@ -43,7 +43,7 @@ typedef struct HandleSocket {
Plug *plug; Plug *plug;
const SocketVtable *sockvt; Socket sock;
} HandleSocket; } HandleSocket;
static int handle_gotdata(struct handle *h, void *data, int len) static int handle_gotdata(struct handle *h, void *data, int len)
@ -107,7 +107,7 @@ static void handle_sentdata(struct handle *h, int new_backlog)
static Plug *sk_handle_plug(Socket *s, Plug *p) static Plug *sk_handle_plug(Socket *s, Plug *p)
{ {
HandleSocket *hs = FROMFIELD(s, HandleSocket, sockvt); HandleSocket *hs = FROMFIELD(s, HandleSocket, sock);
Plug *ret = hs->plug; Plug *ret = hs->plug;
if (p) if (p)
hs->plug = p; hs->plug = p;
@ -116,7 +116,7 @@ static Plug *sk_handle_plug(Socket *s, Plug *p)
static void sk_handle_close(Socket *s) static void sk_handle_close(Socket *s)
{ {
HandleSocket *hs = FROMFIELD(s, HandleSocket, sockvt); HandleSocket *hs = FROMFIELD(s, HandleSocket, sock);
if (hs->defer_close) { if (hs->defer_close) {
hs->deferred_close = TRUE; hs->deferred_close = TRUE;
@ -136,7 +136,7 @@ static void sk_handle_close(Socket *s)
static int sk_handle_write(Socket *s, const void *data, int len) static int sk_handle_write(Socket *s, const void *data, int len)
{ {
HandleSocket *hs = FROMFIELD(s, HandleSocket, sockvt); HandleSocket *hs = FROMFIELD(s, HandleSocket, sock);
return handle_write(hs->send_h, data, len); return handle_write(hs->send_h, data, len);
} }
@ -152,14 +152,14 @@ static int sk_handle_write_oob(Socket *s, const void *data, int len)
static void sk_handle_write_eof(Socket *s) static void sk_handle_write_eof(Socket *s)
{ {
HandleSocket *hs = FROMFIELD(s, HandleSocket, sockvt); HandleSocket *hs = FROMFIELD(s, HandleSocket, sock);
handle_write_eof(hs->send_h); handle_write_eof(hs->send_h);
} }
static void sk_handle_flush(Socket *s) static void sk_handle_flush(Socket *s)
{ {
/* HandleSocket *hs = FROMFIELD(s, HandleSocket, sockvt); */ /* HandleSocket *hs = FROMFIELD(s, HandleSocket, sock); */
/* do nothing */ /* do nothing */
} }
@ -191,7 +191,7 @@ static void handle_socket_unfreeze(void *hsv)
bufchain_consume(&hs->inputdata, len); bufchain_consume(&hs->inputdata, len);
hs->defer_close = FALSE; hs->defer_close = FALSE;
if (hs->deferred_close) { if (hs->deferred_close) {
sk_handle_close(&hs->sockvt); sk_handle_close(&hs->sock);
return; return;
} }
@ -212,7 +212,7 @@ static void handle_socket_unfreeze(void *hsv)
static void sk_handle_set_frozen(Socket *s, int is_frozen) static void sk_handle_set_frozen(Socket *s, int is_frozen)
{ {
HandleSocket *hs = FROMFIELD(s, HandleSocket, sockvt); HandleSocket *hs = FROMFIELD(s, HandleSocket, sock);
if (is_frozen) { if (is_frozen) {
switch (hs->frozen) { switch (hs->frozen) {
@ -267,13 +267,13 @@ static void sk_handle_set_frozen(Socket *s, int is_frozen)
static const char *sk_handle_socket_error(Socket *s) static const char *sk_handle_socket_error(Socket *s)
{ {
HandleSocket *hs = FROMFIELD(s, HandleSocket, sockvt); HandleSocket *hs = FROMFIELD(s, HandleSocket, sock);
return hs->error; return hs->error;
} }
static char *sk_handle_peer_info(Socket *s) static char *sk_handle_peer_info(Socket *s)
{ {
HandleSocket *hs = FROMFIELD(s, HandleSocket, sockvt); HandleSocket *hs = FROMFIELD(s, HandleSocket, sock);
ULONG pid; ULONG pid;
static HMODULE kernel32_module; static HMODULE kernel32_module;
DECL_WINDOWS_FUNCTION(static, BOOL, GetNamedPipeClientProcessId, DECL_WINDOWS_FUNCTION(static, BOOL, GetNamedPipeClientProcessId,
@ -325,7 +325,7 @@ Socket *make_handle_socket(HANDLE send_H, HANDLE recv_H, HANDLE stderr_H,
int flags = (overlapped ? HANDLE_FLAG_OVERLAPPED : 0); int flags = (overlapped ? HANDLE_FLAG_OVERLAPPED : 0);
hs = snew(HandleSocket); hs = snew(HandleSocket);
hs->sockvt = &HandleSocket_sockvt; hs->sock.vt = &HandleSocket_sockvt;
hs->plug = plug; hs->plug = plug;
hs->error = NULL; hs->error = NULL;
hs->frozen = UNFROZEN; hs->frozen = UNFROZEN;
@ -343,5 +343,5 @@ Socket *make_handle_socket(HANDLE send_H, HANDLE recv_H, HANDLE stderr_H,
hs->defer_close = hs->deferred_close = FALSE; hs->defer_close = hs->deferred_close = FALSE;
return &hs->sockvt; return &hs->sock;
} }

View File

@ -76,7 +76,7 @@ struct NetSocket {
*/ */
NetSocket *parent, *child; NetSocket *parent, *child;
const SocketVtable *sockvt; Socket sock;
}; };
struct SockAddr { struct SockAddr {
@ -910,7 +910,7 @@ SockAddr *sk_addr_dup(SockAddr *addr)
static Plug *sk_net_plug(Socket *sock, Plug *p) static Plug *sk_net_plug(Socket *sock, Plug *p)
{ {
NetSocket *s = FROMFIELD(sock, NetSocket, sockvt); NetSocket *s = FROMFIELD(sock, NetSocket, sock);
Plug *ret = s->plug; Plug *ret = s->plug;
if (p) if (p)
s->plug = p; s->plug = p;
@ -957,7 +957,7 @@ static Socket *sk_net_accept(accept_ctx_t ctx, Plug *plug)
* Create NetSocket structure. * Create NetSocket structure.
*/ */
ret = snew(NetSocket); ret = snew(NetSocket);
ret->sockvt = &NetSocket_sockvt; ret->sock.vt = &NetSocket_sockvt;
ret->error = NULL; ret->error = NULL;
ret->plug = plug; ret->plug = plug;
bufchain_init(&ret->output_data); bufchain_init(&ret->output_data);
@ -976,7 +976,7 @@ static Socket *sk_net_accept(accept_ctx_t ctx, Plug *plug)
if (ret->s == INVALID_SOCKET) { if (ret->s == INVALID_SOCKET) {
err = p_WSAGetLastError(); err = p_WSAGetLastError();
ret->error = winsock_error_string(err); ret->error = winsock_error_string(err);
return &ret->sockvt; return &ret->sock;
} }
ret->oobinline = 0; ret->oobinline = 0;
@ -986,12 +986,12 @@ static Socket *sk_net_accept(accept_ctx_t ctx, Plug *plug)
errstr = do_select(ret->s, 1); errstr = do_select(ret->s, 1);
if (errstr) { if (errstr) {
ret->error = errstr; ret->error = errstr;
return &ret->sockvt; return &ret->sock;
} }
add234(sktree, ret); add234(sktree, ret);
return &ret->sockvt; return &ret->sock;
} }
static DWORD try_connect(NetSocket *sock) static DWORD try_connect(NetSocket *sock)
@ -1202,7 +1202,7 @@ Socket *sk_new(SockAddr *addr, int port, int privport, int oobinline,
* Create NetSocket structure. * Create NetSocket structure.
*/ */
ret = snew(NetSocket); ret = snew(NetSocket);
ret->sockvt = &NetSocket_sockvt; ret->sock.vt = &NetSocket_sockvt;
ret->error = NULL; ret->error = NULL;
ret->plug = plug; ret->plug = plug;
bufchain_init(&ret->output_data); bufchain_init(&ret->output_data);
@ -1229,7 +1229,7 @@ Socket *sk_new(SockAddr *addr, int port, int privport, int oobinline,
err = try_connect(ret); err = try_connect(ret);
} while (err && sk_nextaddr(ret->addr, &ret->step)); } while (err && sk_nextaddr(ret->addr, &ret->step));
return &ret->sockvt; return &ret->sock;
} }
Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug, Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
@ -1253,7 +1253,7 @@ Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
* Create NetSocket structure. * Create NetSocket structure.
*/ */
ret = snew(NetSocket); ret = snew(NetSocket);
ret->sockvt = &NetSocket_sockvt; ret->sock.vt = &NetSocket_sockvt;
ret->error = NULL; ret->error = NULL;
ret->plug = plug; ret->plug = plug;
bufchain_init(&ret->output_data); bufchain_init(&ret->output_data);
@ -1295,7 +1295,7 @@ Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
if (s == INVALID_SOCKET) { if (s == INVALID_SOCKET) {
err = p_WSAGetLastError(); err = p_WSAGetLastError();
ret->error = winsock_error_string(err); ret->error = winsock_error_string(err);
return &ret->sockvt; return &ret->sock;
} }
SetHandleInformation((HANDLE)s, HANDLE_FLAG_INHERIT, 0); SetHandleInformation((HANDLE)s, HANDLE_FLAG_INHERIT, 0);
@ -1381,14 +1381,14 @@ Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
if (err) { if (err) {
p_closesocket(s); p_closesocket(s);
ret->error = winsock_error_string(err); ret->error = winsock_error_string(err);
return &ret->sockvt; return &ret->sock;
} }
if (p_listen(s, SOMAXCONN) == SOCKET_ERROR) { if (p_listen(s, SOMAXCONN) == SOCKET_ERROR) {
p_closesocket(s); p_closesocket(s);
ret->error = winsock_error_string(p_WSAGetLastError()); ret->error = winsock_error_string(p_WSAGetLastError());
return &ret->sockvt; return &ret->sock;
} }
/* Set up a select mechanism. This could be an AsyncSelect on a /* Set up a select mechanism. This could be an AsyncSelect on a
@ -1397,7 +1397,7 @@ Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
if (errstr) { if (errstr) {
p_closesocket(s); p_closesocket(s);
ret->error = errstr; ret->error = errstr;
return &ret->sockvt; return &ret->sock;
} }
add234(sktree, ret); add234(sktree, ret);
@ -1412,7 +1412,7 @@ Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
local_host_only, ADDRTYPE_IPV6); local_host_only, ADDRTYPE_IPV6);
if (other) { if (other) {
NetSocket *ns = FROMFIELD(other, NetSocket, sockvt); NetSocket *ns = FROMFIELD(other, NetSocket, sock);
if (!ns->error) { if (!ns->error) {
ns->parent = ret; ns->parent = ret;
ret->child = ns; ret->child = ns;
@ -1423,16 +1423,16 @@ Socket *sk_newlistener(const char *srcaddr, int port, Plug *plug,
} }
#endif #endif
return &ret->sockvt; return &ret->sock;
} }
static void sk_net_close(Socket *sock) static void sk_net_close(Socket *sock)
{ {
extern char *do_select(SOCKET skt, int startup); extern char *do_select(SOCKET skt, int startup);
NetSocket *s = FROMFIELD(sock, NetSocket, sockvt); NetSocket *s = FROMFIELD(sock, NetSocket, sock);
if (s->child) if (s->child)
sk_net_close(&s->child->sockvt); sk_net_close(&s->child->sock);
del234(sktree, s); del234(sktree, s);
do_select(s->s, 0); do_select(s->s, 0);
@ -1540,7 +1540,7 @@ void try_send(NetSocket *s)
static int sk_net_write(Socket *sock, const void *buf, int len) static int sk_net_write(Socket *sock, const void *buf, int len)
{ {
NetSocket *s = FROMFIELD(sock, NetSocket, sockvt); NetSocket *s = FROMFIELD(sock, NetSocket, sock);
assert(s->outgoingeof == EOF_NO); assert(s->outgoingeof == EOF_NO);
@ -1560,7 +1560,7 @@ static int sk_net_write(Socket *sock, const void *buf, int len)
static int sk_net_write_oob(Socket *sock, const void *buf, int len) static int sk_net_write_oob(Socket *sock, const void *buf, int len)
{ {
NetSocket *s = FROMFIELD(sock, NetSocket, sockvt); NetSocket *s = FROMFIELD(sock, NetSocket, sock);
assert(s->outgoingeof == EOF_NO); assert(s->outgoingeof == EOF_NO);
@ -1583,7 +1583,7 @@ static int sk_net_write_oob(Socket *sock, const void *buf, int len)
static void sk_net_write_eof(Socket *sock) static void sk_net_write_eof(Socket *sock)
{ {
NetSocket *s = FROMFIELD(sock, NetSocket, sockvt); NetSocket *s = FROMFIELD(sock, NetSocket, sock);
assert(s->outgoingeof == EOF_NO); assert(s->outgoingeof == EOF_NO);
@ -1786,13 +1786,13 @@ const char *sk_addr_error(SockAddr *addr)
} }
static const char *sk_net_socket_error(Socket *sock) static const char *sk_net_socket_error(Socket *sock)
{ {
NetSocket *s = FROMFIELD(sock, NetSocket, sockvt); NetSocket *s = FROMFIELD(sock, NetSocket, sock);
return s->error; return s->error;
} }
static char *sk_net_peer_info(Socket *sock) static char *sk_net_peer_info(Socket *sock)
{ {
NetSocket *s = FROMFIELD(sock, NetSocket, sockvt); NetSocket *s = FROMFIELD(sock, NetSocket, sock);
#ifdef NO_IPV6 #ifdef NO_IPV6
struct sockaddr_in addr; struct sockaddr_in addr;
#else #else
@ -1824,7 +1824,7 @@ static char *sk_net_peer_info(Socket *sock)
static void sk_net_set_frozen(Socket *sock, int is_frozen) static void sk_net_set_frozen(Socket *sock, int is_frozen)
{ {
NetSocket *s = FROMFIELD(sock, NetSocket, sockvt); NetSocket *s = FROMFIELD(sock, NetSocket, sock);
if (s->frozen == is_frozen) if (s->frozen == is_frozen)
return; return;
s->frozen = is_frozen; s->frozen = is_frozen;

View File

@ -34,12 +34,12 @@ typedef struct NamedPipeServerSocket {
Plug *plug; Plug *plug;
char *error; char *error;
const SocketVtable *sockvt; Socket sock;
} NamedPipeServerSocket; } NamedPipeServerSocket;
static Plug *sk_namedpipeserver_plug(Socket *s, Plug *p) static Plug *sk_namedpipeserver_plug(Socket *s, Plug *p)
{ {
NamedPipeServerSocket *ps = FROMFIELD(s, NamedPipeServerSocket, sockvt); NamedPipeServerSocket *ps = FROMFIELD(s, NamedPipeServerSocket, sock);
Plug *ret = ps->plug; Plug *ret = ps->plug;
if (p) if (p)
ps->plug = p; ps->plug = p;
@ -48,7 +48,7 @@ static Plug *sk_namedpipeserver_plug(Socket *s, Plug *p)
static void sk_namedpipeserver_close(Socket *s) static void sk_namedpipeserver_close(Socket *s)
{ {
NamedPipeServerSocket *ps = FROMFIELD(s, NamedPipeServerSocket, sockvt); NamedPipeServerSocket *ps = FROMFIELD(s, NamedPipeServerSocket, sock);
if (ps->callback_handle) if (ps->callback_handle)
handle_free(ps->callback_handle); handle_free(ps->callback_handle);
@ -65,7 +65,7 @@ static void sk_namedpipeserver_close(Socket *s)
static const char *sk_namedpipeserver_socket_error(Socket *s) static const char *sk_namedpipeserver_socket_error(Socket *s)
{ {
NamedPipeServerSocket *ps = FROMFIELD(s, NamedPipeServerSocket, sockvt); NamedPipeServerSocket *ps = FROMFIELD(s, NamedPipeServerSocket, sock);
return ps->error; return ps->error;
} }
@ -219,7 +219,7 @@ static const SocketVtable NamedPipeServerSocket_sockvt = {
Socket *new_named_pipe_listener(const char *pipename, Plug *plug) Socket *new_named_pipe_listener(const char *pipename, Plug *plug)
{ {
NamedPipeServerSocket *ret = snew(NamedPipeServerSocket); NamedPipeServerSocket *ret = snew(NamedPipeServerSocket);
ret->sockvt = &NamedPipeServerSocket_sockvt; ret->sock.vt = &NamedPipeServerSocket_sockvt;
ret->plug = plug; ret->plug = plug;
ret->error = NULL; ret->error = NULL;
ret->psd = NULL; ret->psd = NULL;
@ -249,7 +249,7 @@ Socket *new_named_pipe_listener(const char *pipename, Plug *plug)
named_pipe_accept_loop(ret, FALSE); named_pipe_accept_loop(ret, FALSE);
cleanup: cleanup:
return &ret->sockvt; return &ret->sock;
} }
#endif /* !defined NO_SECURITY */ #endif /* !defined NO_SECURITY */

View File

@ -42,7 +42,7 @@ typedef struct X11Connection {
SshChannel *c; /* channel structure held by SSH backend */ SshChannel *c; /* channel structure held by SSH backend */
Socket *s; Socket *s;
const PlugVtable *plugvt; Plug plug;
Channel chan; Channel chan;
} X11Connection; } X11Connection;
@ -635,7 +635,7 @@ static void x11_closing(Plug *plug, const char *error_msg, int error_code,
int calling_back) int calling_back)
{ {
struct X11Connection *xconn = FROMFIELD( struct X11Connection *xconn = FROMFIELD(
plug, struct X11Connection, plugvt); plug, struct X11Connection, plug);
if (error_msg) { if (error_msg) {
/* /*
@ -667,7 +667,7 @@ static void x11_closing(Plug *plug, const char *error_msg, int error_code,
static void x11_receive(Plug *plug, int urgent, char *data, int len) static void x11_receive(Plug *plug, int urgent, char *data, int len)
{ {
struct X11Connection *xconn = FROMFIELD( struct X11Connection *xconn = FROMFIELD(
plug, struct X11Connection, plugvt); plug, struct X11Connection, plug);
xconn->no_data_sent_to_x_client = FALSE; xconn->no_data_sent_to_x_client = FALSE;
sshfwd_write(xconn->c, data, len); sshfwd_write(xconn->c, data, len);
@ -676,7 +676,7 @@ static void x11_receive(Plug *plug, int urgent, char *data, int len)
static void x11_sent(Plug *plug, int bufsize) static void x11_sent(Plug *plug, int bufsize)
{ {
struct X11Connection *xconn = FROMFIELD( struct X11Connection *xconn = FROMFIELD(
plug, struct X11Connection, plugvt); plug, struct X11Connection, plug);
sshfwd_unthrottle(xconn->c, bufsize); sshfwd_unthrottle(xconn->c, bufsize);
} }
@ -738,7 +738,7 @@ Channel *x11_new_channel(tree234 *authtree, SshChannel *c,
* Open socket. * Open socket.
*/ */
xconn = snew(struct X11Connection); xconn = snew(struct X11Connection);
xconn->plugvt = &X11Connection_plugvt; xconn->plug.vt = &X11Connection_plugvt;
xconn->chan.vt = &X11Connection_channelvt; xconn->chan.vt = &X11Connection_channelvt;
xconn->chan.initial_fixed_window_size = xconn->chan.initial_fixed_window_size =
(connection_sharing_possible ? 128 : 0); (connection_sharing_possible ? 128 : 0);
@ -945,7 +945,7 @@ static int x11_send(Channel *chan, int is_stderr, const void *vdata, int len)
xconn->disp = auth_matched->disp; xconn->disp = auth_matched->disp;
xconn->s = new_connection(sk_addr_dup(xconn->disp->addr), xconn->s = new_connection(sk_addr_dup(xconn->disp->addr),
xconn->disp->realhost, xconn->disp->port, xconn->disp->realhost, xconn->disp->port,
0, 1, 0, 0, &xconn->plugvt, 0, 1, 0, 0, &xconn->plug,
sshfwd_get_conf(xconn->c)); sshfwd_get_conf(xconn->c));
if ((err = sk_socket_error(xconn->s)) != NULL) { if ((err = sk_socket_error(xconn->s)) != NULL) {
char *err_message = dupprintf("unable to connect to" char *err_message = dupprintf("unable to connect to"