projects
/
cascardo
/
rnetproxy.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Allow set_driver to fail and handle this case.
[cascardo/rnetproxy.git]
/
hcconn_ssl.c
diff --git
a/hcconn_ssl.c
b/hcconn_ssl.c
index
0a4f885
..
264be27
100644
(file)
--- a/
hcconn_ssl.c
+++ b/
hcconn_ssl.c
@@
-185,11
+185,13
@@
hc_conn_ssl_watch (HCConn *conn, HCEvent event, gpointer data)
}
}
}
}
-static
void
+static
int
hc_conn_set_driver_ssl (HCConn *conn, HCConn *lowconn, int server)
{
struct ssl_data *ssl;
ssl = ssl_data_new (server);
hc_conn_set_driver_ssl (HCConn *conn, HCConn *lowconn, int server)
{
struct ssl_data *ssl;
ssl = ssl_data_new (server);
+ if (ssl == NULL)
+ return -1;
ssl->lowconn = lowconn;
conn->layer = ssl;
conn->read = hc_conn_ssl_read;
ssl->lowconn = lowconn;
conn->layer = ssl;
conn->read = hc_conn_ssl_read;
@@
-197,9
+199,11
@@
hc_conn_set_driver_ssl (HCConn *conn, HCConn *lowconn, int server)
conn->close = hc_conn_ssl_close;
hc_conn_set_callback (lowconn, hc_conn_ssl_watch, conn);
ssl_server_connect (conn);
conn->close = hc_conn_ssl_close;
hc_conn_set_callback (lowconn, hc_conn_ssl_watch, conn);
ssl_server_connect (conn);
+ return 0;
}
}
-void hc_conn_set_driver_ssl_client (HCConn *conn, HCConn *lowconn)
+int
+hc_conn_set_driver_ssl_client (HCConn *conn, HCConn *lowconn)
{
{
- hc_conn_set_driver_ssl (conn, lowconn, 0);
+
return
hc_conn_set_driver_ssl (conn, lowconn, 0);
}
}