diff options
author | rodri <rgl@antares-labs.eu> | 2021-07-23 03:38:18 +0000 |
---|---|---|
committer | rodri <rgl@antares-labs.eu> | 2021-07-23 03:38:18 +0000 |
commit | 615575f7dca0e43ecb23c4ab1ea7fd2e93c4e3b4 (patch) | |
tree | f7c7052cbbac5b7af14f88adee1072352284d565 /muswd.c | |
parent | dfb8bd8c95a5ff8633214f483f358d24071a7d8a (diff) | |
download | musw-615575f7dca0e43ecb23c4ab1ea7fd2e93c4e3b4.tar.gz musw-615575f7dca0e43ecb23c4ab1ea7fd2e93c4e3b4.tar.bz2 musw-615575f7dca0e43ecb23c4ab1ea7fd2e93c4e3b4.zip |
implemented a lobby for users waiting to join a party.
brought the pack/unpack procedures from ssh(1).
Diffstat (limited to 'muswd.c')
-rw-r--r-- | muswd.c | 30 |
1 files changed, 13 insertions, 17 deletions
@@ -9,7 +9,8 @@ int debug; GameState state; double t, Δt; -Conn conns; +Lobby *lobby; + static long _iolisten(va_list *arg) @@ -54,15 +55,11 @@ threadlisten(void *arg) continue; } - if(conns.off >= conns.cap){ - conns.cap += 8; - conns.fds = erealloc(conns.fds, conns.cap*sizeof(*conns.fds)); - } - conns.fds[conns.off++] = dfd; + lobby->takeseat(lobby, dfd); if(debug) - fprint(2, "added conn %d for %lud conns at %lud max\n", - dfd, conns.off, conns.cap); + fprint(2, "added conn for %lud conns at %lud max\n", + lobby->seats.len, lobby->seats.cap); } } @@ -95,16 +92,16 @@ threadsim(void *) then = now; timeacc += frametime/1e9; - for(i = 0; i < conns.off; i++) - if(fprint(conns.fds[i], "state: x=%g v=%g\n", state.x, state.v) < 0){ - fprint(2, "client #%d hanged up\n", i+1); - if(conns.off < conns.cap-1) - memmove(&conns.fds[conns.off], &conns.fds[conns.off+1], conns.cap-conns.off - 1); - conns.off--; + for(i = 0; i < lobby->seats.len; i++) + if(fprint(lobby->seats.fds[i], "state: x=%g v=%g\n", state.x, state.v) < 0){ + if(debug) + fprint(2, "client #%d hanged up\n", i+1); + + lobby->leaveseat(lobby, i); if(debug) fprint(2, "removed conn %d for %lud conns at %lud max\n", - i, conns.off, conns.cap); + i, lobby->seats.len, lobby->seats.cap); i--; } @@ -146,8 +143,7 @@ threadmain(int argc, char *argv[]) if(acfd < 0) sysfatal("announce: %r"); - conns.fds = emalloc(2*sizeof(*conns.fds)); - conns.cap = 2; + lobby = newlobby(); threadcreate(threadlisten, adir, 4096); threadcreate(threadsim, nil, 4096); |