about summary refs log tree commit diff homepage
path: root/client.c
diff options
context:
space:
mode:
authorJune McEnroe <programble@gmail.com>2017-07-31 21:30:22 -0400
committerJune McEnroe <programble@gmail.com>2017-07-31 21:30:22 -0400
commite2e97511e8b3ff819274b8ea802e20a41e50858f (patch)
treef9e2c129e18da878366385965ae5c8d9df6e1cd9 /client.c
parentPerform enter as two moves rather than a loop (diff)
downloadtorus-e2e97511e8b3ff819274b8ea802e20a41e50858f.tar.gz
torus-e2e97511e8b3ff819274b8ea802e20a41e50858f.zip
Show other clients' cursors
Also unfuck removing on send failure.
Diffstat (limited to 'client.c')
-rwxr-xr-xclient.c20
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);
     }