]> git.ozlabs.org Git - ccan/blobdiff - ccan/io/test/run-08-read-after-hangup.c
io: fix maybe-uninitialized warning in test (-O2)
[ccan] / ccan / io / test / run-08-read-after-hangup.c
index 56d9a164accddbbd40ba290016a2486a008fd45d..14af5ae6373a5afaac958b5b8376fab0c443f7fa 100644 (file)
@@ -9,10 +9,25 @@
 
 static char inbuf[8];
 
-static struct io_plan wake_it(struct io_conn *conn, struct io_conn *reader)
+static struct io_plan *wake_it(struct io_conn *conn, struct io_conn *reader)
 {
-       io_wake(reader, io_read(inbuf, 8, io_close, NULL));
-       return io_close(conn, NULL);
+       io_wake(inbuf);
+       return io_close(conn);
+}
+
+static struct io_plan *read_buf(struct io_conn *conn, void *unused)
+{
+       return io_read(conn, inbuf, 8, io_close_cb, NULL);
+}
+
+static struct io_plan *init_writer(struct io_conn *conn, struct io_conn *wakeme)
+{
+       return io_write(conn, "EASYTEST", 8, wake_it, wakeme);
+}
+
+static struct io_plan *init_waiter(struct io_conn *conn, void *unused)
+{
+       return io_wait(conn, inbuf, read_buf, NULL);
 }
 
 int main(void)
@@ -23,10 +38,10 @@ int main(void)
        plan_tests(3);
 
        ok1(pipe(fds) == 0);
-       conn = io_new_conn(fds[0], io_idle());
-       io_new_conn(fds[1], io_write("EASYTEST", 8, wake_it, conn));
+       conn = io_new_conn(NULL, fds[0], init_waiter, NULL);
+       io_new_conn(conn, fds[1], init_writer, conn);
 
-       ok1(io_loop() == NULL);
+       ok1(io_loop(NULL, NULL) == NULL);
        ok1(memcmp(inbuf, "EASYTEST", sizeof(inbuf)) == 0);
 
        /* This exits depending on whether all tests passed */