diff options
author | June McEnroe <programble@gmail.com> | 2017-07-31 21:30:22 -0400 |
---|---|---|
committer | June McEnroe <programble@gmail.com> | 2017-07-31 21:30:22 -0400 |
commit | e2e97511e8b3ff819274b8ea802e20a41e50858f (patch) | |
tree | f9e2c129e18da878366385965ae5c8d9df6e1cd9 /client.c | |
parent | Perform enter as two moves rather than a loop (diff) | |
download | torus-e2e97511e8b3ff819274b8ea802e20a41e50858f.tar.gz torus-e2e97511e8b3ff819274b8ea802e20a41e50858f.zip |
Show other clients' cursors
Also unfuck removing on send failure.
Diffstat (limited to '')
-rwxr-xr-x | client.c | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/client.c b/client.c index 4eb726b..d77aeb7 100755 --- a/client.c +++ b/client.c @@ -245,6 +245,17 @@ static void serverTile(void) { } } +static void serverCursor(uint8_t oldX, uint8_t oldY, uint8_t newX, uint8_t newY) { + if (oldX != CURSOR_NONE) { + move(oldY, oldX); + addch(inch() & ~A_REVERSE); + } + if (newX != CURSOR_NONE) { + move(newY, newX); + addch(inch() | A_REVERSE); + } +} + static void readMessage(void) { struct ServerMessage msg; ssize_t len = recv(client, &msg, sizeof(msg), 0); @@ -273,6 +284,15 @@ static void readMessage(void) { ); break; + case SERVER_CURSOR: + serverCursor( + msg.data.c.oldCellX, + msg.data.c.oldCellY, + msg.data.c.newCellX, + msg.data.c.newCellY + ); + break; + default: errx(EX_PROTOCOL, "I don't know what %d means!", msg.type); } |