void *io_loop_return;
struct io_listener *io_new_listener_(int fd,
- struct io_plan (*start)(struct io_conn *,
- void *arg),
- void (*finish)(struct io_conn *, void *),
+ void (*init)(int fd, void *arg),
void *arg)
{
struct io_listener *l = malloc(sizeof(*l));
l->fd.listener = true;
l->fd.fd = fd;
- l->next = start;
- l->finish = finish;
- l->conn_arg = arg;
+ l->init = init;
+ l->arg = arg;
if (!add_listener(l)) {
free(l);
return NULL;
}
struct io_conn *io_new_conn_(int fd,
- struct io_plan (*start)(struct io_conn *, void *),
+ struct io_plan plan,
void (*finish)(struct io_conn *, void *),
void *arg)
{
conn->fd.listener = false;
conn->fd.fd = fd;
- conn->plan.next = start;
+ conn->plan = plan;
conn->finish = finish;
- conn->finish_arg = conn->plan.next_arg = arg;
- conn->plan.pollflag = 0;
- conn->plan.state = IO_NEXT;
+ conn->finish_arg = arg;
conn->duplex = NULL;
conn->timeout = NULL;
if (!add_conn(conn)) {
}
struct io_conn *io_duplex_(struct io_conn *old,
- struct io_plan (*start)(struct io_conn *, void *),
- void (*finish)(struct io_conn *, void *),
- void *arg)
+ struct io_plan plan,
+ void (*finish)(struct io_conn *, void *),
+ void *arg)
{
struct io_conn *conn;
conn->fd.listener = false;
conn->fd.fd = old->fd.fd;
- conn->plan.next = start;
- conn->finish = finish;
- conn->finish_arg = conn->plan.next_arg = arg;
- conn->plan.pollflag = 0;
- conn->plan.state = IO_NEXT;
+ conn->plan = plan;
conn->duplex = old;
+ conn->finish = finish;
+ conn->finish_arg = arg;
conn->timeout = NULL;
if (!add_duplex(conn)) {
free(conn);
}
/* Queue some data to be written. */
-struct io_plan io_write_(struct io_conn *conn, const void *data, size_t len,
+struct io_plan io_write_(const void *data, size_t len,
struct io_plan (*cb)(struct io_conn *, void *),
void *arg)
{
}
/* Queue a request to read into a buffer. */
-struct io_plan io_read_(struct io_conn *conn, void *data, size_t len,
+struct io_plan io_read_(void *data, size_t len,
struct io_plan (*cb)(struct io_conn *, void *),
void *arg)
{
}
/* Queue a partial request to read into a buffer. */
-struct io_plan io_read_partial_(struct io_conn *conn, void *data, size_t *len,
+struct io_plan io_read_partial_(void *data, size_t *len,
struct io_plan (*cb)(struct io_conn *, void *),
void *arg)
{
}
/* Queue a partial write request. */
-struct io_plan io_write_partial_(struct io_conn *conn,
- const void *data, size_t *len,
+struct io_plan io_write_partial_(const void *data, size_t *len,
struct io_plan (*cb)(struct io_conn*, void *),
void *arg)
{
return plan;
}
-struct io_plan io_idle(struct io_conn *conn)
+struct io_plan io_idle(void)
{
struct io_plan plan;
plan.pollflag = 0;
- plan.state = IO_IDLE;
+ plan.state = IO_IO;
+ plan.io = NULL;
return plan;
}
-void io_wake_(struct io_conn *conn,
- struct io_plan (*fn)(struct io_conn *, void *), void *arg)
+void io_wake(struct io_conn *conn, struct io_plan plan)
{
/* It might have finished, but we haven't called its finish() yet. */
if (conn->plan.state == IO_FINISHED)
return;
- assert(conn->plan.state == IO_IDLE);
- conn->plan.next = fn;
- conn->plan.next_arg = arg;
- conn->plan.pollflag = 0;
- conn->plan.state = IO_NEXT;
+ assert(!conn->plan.io);
+ conn->plan = plan;
backend_wakeup(conn);
}
}
/* Exit the loop, returning this (non-NULL) arg. */
-struct io_plan io_break_(struct io_conn *conn, void *ret,
- struct io_plan (*fn)(struct io_conn *, void *),
- void *arg)
+struct io_plan io_break(void *ret, struct io_plan plan)
{
- struct io_plan plan;
-
io_loop_return = ret;
- plan.state = IO_NEXT;
- plan.pollflag = 0;
- plan.next = fn;
- plan.next_arg = arg;
-
return plan;
}