summary refs log tree commit diff
diff options
context:
space:
mode:
authorJune McEnroe <june@causal.agency>2019-10-25 18:23:30 -0400
committerJune McEnroe <june@causal.agency>2019-10-25 18:23:30 -0400
commita4a76a4d7a7281fff4a8b4ad8b1a3e5e39d51c49 (patch)
tree23d42e68fd6e8bf326a4f1b792495992d0f1eaf6
parentClean up client (diff)
downloadpounce-a4a76a4d7a7281fff4a8b4ad8b1a3e5e39d51c49.tar.gz
pounce-a4a76a4d7a7281fff4a8b4ad8b1a3e5e39d51c49.zip
Clean up event loop
Diffstat (limited to '')
-rw-r--r--bounce.c24
1 files changed, 15 insertions, 9 deletions
diff --git a/bounce.c b/bounce.c
index ad346a0..a167cea 100644
--- a/bounce.c
+++ b/bounce.c
@@ -14,6 +14,7 @@
  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
  */
 
+#include <assert.h>
 #include <err.h>
 #include <limits.h>
 #include <poll.h>
@@ -120,10 +121,7 @@ int main(int argc, char *argv[]) {
 
 	int server = serverConnect(host, port);
 	serverLogin(pass, auth, nick, user, real);
-
-	while (!stateReady()) {
-		serverRecv();
-	}
+	while (!stateReady()) serverRecv();
 	if (join) serverFormat("JOIN :%s\r\n", join);
 
 	for (size_t i = 0; i < binds; ++i) {
@@ -135,22 +133,30 @@ int main(int argc, char *argv[]) {
 
 	while (0 < poll(event.fds, event.len, -1)) {
 		for (size_t i = 0; i < event.len; ++i) {
-			if (!event.fds[i].revents) continue;
+			short revents = event.fds[i].revents;
+			if (!revents) continue;
+
 			if (i < binds) {
 				int fd;
 				struct tls *tls = listenAccept(&fd, event.fds[i].fd);
 				eventAdd(fd, clientAlloc(tls));
 				continue;
 			}
+
 			if (!event.clients[i]) {
-				serverRecv();
+				if (revents & POLLIN) {
+					serverRecv();
+				} else {
+					errx(EX_UNAVAILABLE, "server hung up");
+				}
 				continue;
 			}
-			short revents = event.fds[i].revents;
+
 			struct Client *client = event.clients[i];
 			if (revents & POLLIN) clientRecv(client);
 			if (revents & POLLOUT) clientConsume(client);
 			if (clientError(client) || revents & (POLLHUP | POLLERR)) {
+				// TODO: Set AWAY if no more clients remain.
 				clientFree(client);
 				close(event.fds[i].fd);
 				eventRemove(i);
@@ -158,8 +164,8 @@ int main(int argc, char *argv[]) {
 			}
 		}
 
-		for (size_t i = 0; i < event.len; ++i) {
-			if (!event.clients[i]) continue;
+		for (size_t i = binds + 1; i < event.len; ++i) {
+			assert(event.clients[i]);
 			if (clientDiff(event.clients[i])) {
 				event.fds[i].events |= POLLOUT;
 			} else {
tr class='logheader'>2021-01-13Update Terminal.app coloursJune McEnroe God what is this garbage I only changed one colour. 2021-01-13Increase dark white brightness slightlyJune McEnroe 2021-01-13Add hilex example to htagml manualJune McEnroe 2021-01-12Style causal.agency like bin HTMLJune McEnroe 2021-01-12Avoid matching tag text inside HTML elementsJune McEnroe 2021-01-12Use hilex for up -hJune McEnroe 2021-01-12Use hilex for bin HTMLJune McEnroe 2021-01-12Don't output a pre in hilex by defaultJune McEnroe 2021-01-12Move hilex out of hilex directoryJune McEnroe 2021-01-12Consolidate hilex formatters into hilex.cJune McEnroe 2021-01-12Remove hacky tagging from hilexJune McEnroe God that makes the lexers so much simpler. 2021-01-12Add htagml -iJune McEnroe 2021-01-12Render tag index in HTMLJune McEnroe 2021-01-12Add htagml -xJune McEnroe 2021-01-12Prevent matching the same tag twiceJune McEnroe 2021-01-12Process htagml file line by lineJune McEnroe This simplifies some things, adds support for line number tag definitions, and should enable combining htagml with other preprocessors in the future. 2021-01-12Split fields by tab onlyJune McEnroe Also don't fail hard on non-forward-search definitions. 2021-01-12List both Makefile and html.sh under README.7June McEnroe 2021-01-12Add htagml exampleJune McEnroe 2021-01-12Use mandoc and htagml for bin htmlJune McEnroe 2021-01-12Add htagmlJune McEnroe 2021-01-12Replace causal.agency with a simple mdoc pageJune McEnroe 2021-01-11Publish "Using vi"June McEnroe 2021-01-11Enable diff.colorMovedJune McEnroe 2021-01-10Set less search case-insensitiveJune McEnroe 2021-01-10Set EXINITJune McEnroe neovim is laggy as hell in my OpenBSD VM, so I switched to vi so I could type without getting frustrated. 2021-01-09Add c -t flag to print expression typeJune McEnroe Also add missing float case. 2021-01-05Update taglineJune McEnroe