aboutsummaryrefslogtreecommitdiff
path: root/muswd.c
diff options
context:
space:
mode:
authorrodri <rgl@antares-labs.eu>2021-07-23 03:38:18 +0000
committerrodri <rgl@antares-labs.eu>2021-07-23 03:38:18 +0000
commit615575f7dca0e43ecb23c4ab1ea7fd2e93c4e3b4 (patch)
treef7c7052cbbac5b7af14f88adee1072352284d565 /muswd.c
parentdfb8bd8c95a5ff8633214f483f358d24071a7d8a (diff)
downloadmusw-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.c30
1 files changed, 13 insertions, 17 deletions
diff --git a/muswd.c b/muswd.c
index c652b39..249e516 100644
--- a/muswd.c
+++ b/muswd.c
@@ -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);