+static HCConn *
+server_conn_new (char *server, char *port)
+{
+ int fd;
+ HCConn *conn;
+ HCConn *ssl_conn;
+ conn = hc_conn_new (NULL, NULL);
+ ssl_conn = hc_conn_new (NULL, NULL);
+ fd = hc_tcp_connect (server, port);
+ hc_conn_set_driver_channel (conn, fd);
+ hc_conn_set_driver_ssl (ssl_conn, conn);
+ return ssl_conn;
+}
+
+static void
+push_other (HCConn *conn, HCEvent event, gpointer data)
+{
+ char buffer[4096];
+ int r;
+ switch (event)
+ {
+ case HC_EVENT_READ:
+ while ((r = hc_conn_read (conn, buffer, sizeof (buffer))) > 0)
+ hc_conn_write (data, buffer, r);
+ break;
+ case HC_EVENT_CLOSE:
+ hc_conn_close (conn);
+ hc_conn_close (data);
+ break;
+ }
+}
+