current->plan = plan;
backend_plan_changed(current);
+ /* If it closed, close duplex. */
+ if (!current->plan.next && current->duplex) {
+ current->duplex->plan = io_close_();
+ backend_plan_changed(current->duplex);
+ }
+
/* Call back into the loop immediately. */
io_loop_return = do_io_loop(&ready);
backend_plan_changed(conn);
}
set_current(NULL);
+
+ /* If it closed, close duplex. */
+ if (!conn->plan.next && conn->duplex) {
+ set_current(conn->duplex);
+ conn->duplex->plan = io_close();
+ backend_plan_changed(conn->duplex);
+ set_current(NULL);
+ }
}
/* Close the connection, we're done. */
return plan;
}
+int io_conn_fd(const struct io_conn *conn)
+{
+ return conn->fd.fd;
+}
+
void io_set_alloc(void *(*allocfn)(size_t size),
void *(*reallocfn)(void *ptr, size_t size),
void (*freefn)(void *ptr))