X-Git-Url: https://git.ozlabs.org/?a=blobdiff_plain;f=ccan%2Fio%2Ftest%2Frun-12-bidir.c;fp=ccan%2Fio%2Ftest%2Frun-12-bidir.c;h=6dc94c8a4a57a1baee29d281b7e04355a7cd7752;hb=57d9d1be33905691ec756b14b066181ca6850ced;hp=3534bc3138f92df5aa6bb57e51849aac26ac6f3b;hpb=737705f0c2ec60ea5b51ca55299488d86db37b5d;p=ccan diff --git a/ccan/io/test/run-12-bidir.c b/ccan/io/test/run-12-bidir.c index 3534bc31..6dc94c8a 100644 --- a/ccan/io/test/run-12-bidir.c +++ b/ccan/io/test/run-12-bidir.c @@ -18,28 +18,27 @@ static void finish_ok(struct io_conn *conn, struct data *d) d->state++; } -static struct io_plan write_out(struct io_conn *conn, struct data *d) +static struct io_plan write_done(struct io_conn *conn, struct data *d) { d->state++; - return io_write(d->wbuf, sizeof(d->wbuf), io_close, d); + return io_close(conn, NULL); } -static struct io_plan start_ok(struct io_conn *conn, struct data *d) +static void init_conn(int fd, struct data *d) { + struct io_conn *conn; + ok1(d->state == 0); d->state++; io_close_listener(d->l); memset(d->wbuf, 7, sizeof(d->wbuf)); - ok1(io_duplex(conn, write_out, finish_ok, d)); - return io_read(d->buf, sizeof(d->buf), io_close, d); -} -static void init_conn(int fd, struct data *d) -{ - if (!io_new_conn(fd, start_ok, finish_ok, d)) - abort(); + conn = io_new_conn(fd, io_read(d->buf, sizeof(d->buf), io_close, d), + finish_ok, d); + ok1(io_duplex(conn, io_write(d->wbuf, sizeof(d->wbuf), write_done, d), + finish_ok, d)); } static int make_listen_fd(const char *port, struct addrinfo **info)