X-Git-Url: http://git.ozlabs.org/?p=ccan;a=blobdiff_plain;f=ccan%2Fio%2Ftest%2Frun-02-read.c;h=439beb1f8a9ad6aaedab7ec1f8f4d72af2f527cc;hp=e5a6142c9677b411e96cc149180b250477bc95a8;hb=cdf62dce7077a9f9a818edbb67d31d033cbb73c6;hpb=733b09fa8b6083949ff62795e54851aa282d510c diff --git a/ccan/io/test/run-02-read.c b/ccan/io/test/run-02-read.c index e5a6142c..439beb1f 100644 --- a/ccan/io/test/run-02-read.c +++ b/ccan/io/test/run-02-read.c @@ -6,23 +6,30 @@ #include #include +#ifndef PORT +#define PORT "65002" +#endif + struct data { int state; char buf[4]; }; -static struct io_plan start_ok(struct io_conn *conn, struct data *d) +static void finish_ok(struct io_conn *conn, struct data *d) { - ok1(d->state == 0); + ok1(d->state == 1); d->state++; - return io_read(d->buf, sizeof(d->buf), io_close, d); + io_break(d, io_never()); } -static void finish_ok(struct io_conn *conn, struct data *d) +static void init_conn(int fd, struct data *d) { - ok1(d->state == 1); + ok1(d->state == 0); d->state++; - io_break(d, NULL, NULL); + + io_set_finish(io_new_conn(fd, + io_read(d->buf, sizeof(d->buf), io_close_cb, d)), + finish_ok, d); } static int make_listen_fd(const char *port, struct addrinfo **info) @@ -67,9 +74,9 @@ int main(void) /* This is how many tests you plan to run */ plan_tests(10); d->state = 0; - fd = make_listen_fd("65002", &addrinfo); + fd = make_listen_fd(PORT, &addrinfo); ok1(fd >= 0); - l = io_new_listener(fd, start_ok, finish_ok, d); + l = io_new_listener(fd, init_conn, d); ok1(l); fflush(stdout); if (!fork()) {