From a9ee61418f223d2135dbf10cdbd2066215cdfc8d Mon Sep 17 00:00:00 2001 From: Drew DeVault Date: Sun, 27 Sep 2020 12:11:11 -0400 Subject: [PATCH] Break after processing polled client Otherwise we might not grok it, ya jive --- src/server.c | 3 +++ 1 file changed, 3 insertions(+) diff --git a/src/server.c b/src/server.c index 488f2eb..f14a121 100644 --- a/src/server.c +++ b/src/server.c @@ -443,10 +443,13 @@ server_run(struct gmnisrv_server *server) for (size_t i = 0; i < server->nclients; ++i) { if ((server->fds[server->nlisten + i].revents & (POLLHUP | POLLERR))) { disconnect_client(server, &server->clients[i]); + break; } else if ((server->fds[server->nlisten + i].revents & POLLIN)) { client_readable(server, &server->clients[i]); + break; } else if ((server->fds[server->nlisten + i].revents & POLLOUT)) { client_writable(server, &server->clients[i]); + break; } } } while (server->run);