X-Git-Url: http://git.ozlabs.org/?a=blobdiff_plain;f=ccan%2Foserver%2Foserver.c;fp=ccan%2Foserver%2Foserver.c;h=50b49bd5f94746c8259fb3c609c285c5d68684c9;hb=ce689e269acaabd77dcb82166340441a4a00f9a1;hp=b65fe6b1f3069fd90dae4cda0895210bda37a649;hpb=33b799969447a818cd99749aa937a59c88e4f83f;p=ccan-lca-2011.git diff --git a/ccan/oserver/oserver.c b/ccan/oserver/oserver.c index b65fe6b..50b49bd 100644 --- a/ccan/oserver/oserver.c +++ b/ccan/oserver/oserver.c @@ -326,7 +326,7 @@ static bool load_file(struct oserver *oserver, const char *file) return true; } -static void complete_server(struct tevent_context *ev, +static bool complete_server(struct tevent_context *ev, struct oserver *oserver, const char *dumpfile) { /* Re-set this even if restored from file, in case it changed. */ @@ -341,16 +341,39 @@ static void complete_server(struct tevent_context *ev, /* Show talloc tree on SIGUSR1. */ tevent_add_signal(ev, oserver, SIGUSR1, SA_RESTART, talloc_dump, oserver); + + oserver->fde = tevent_add_fd(ev, oserver, oserver->fd, + TEVENT_FD_READ, add_client, oserver); + if (!oserver->fde) + return false; + return true; } struct oserver *oserver_restore(struct tevent_context *ev, const char *dumpfile) { + unsigned int i; struct oserver *oserver = talloc(ev, struct oserver); if (!load_file(oserver, dumpfile)) { talloc_free(oserver); return NULL; } - complete_server(ev, oserver, dumpfile); + + /* Restore ignored fields in clients (fde and oserver). */ + for (i = 0; i < ARRAY_SIZE(oserver->clients); i++) { + struct client *client = oserver->clients[i]; + if (!client) + continue; + client->oserver = oserver; + client->fde = tevent_add_fd(ev, client, client->fd, + state_flag_map[client->state], + service_client, client); + tevent_fd_set_auto_close(client->fde); + } + + if (!complete_server(ev, oserver, dumpfile)) { + talloc_free(oserver); + return NULL; + } return oserver; } @@ -391,13 +414,10 @@ struct oserver *oserver_setup(struct tevent_context *ev, unsigned short port, return NULL; } - oserver->fde = tevent_add_fd(ev, oserver, oserver->fd, - TEVENT_FD_READ, add_client, oserver); - if (!oserver->fde) { + if (!complete_server(ev, oserver, dumpfile)) { talloc_free(oserver); return NULL; } - complete_server(ev, oserver, dumpfile); return oserver; }