about summary refs log tree commit diff
path: root/handle.c
diff options
context:
space:
mode:
authorJune McEnroe <june@causal.agency>2020-02-06 01:16:35 -0500
committerJune McEnroe <june@causal.agency>2020-02-06 01:16:35 -0500
commit5fb492f8cda7598cbf1a977b0b3c66f9dc1b24f0 (patch)
treea63c31326644c6599a6608dcf71d43106f30a77f /handle.c
parentAdd /join command (diff)
downloadcatgirl-5fb492f8cda7598cbf1a977b0b3c66f9dc1b24f0.tar.gz
catgirl-5fb492f8cda7598cbf1a977b0b3c66f9dc1b24f0.zip
Handle PART
Diffstat (limited to 'handle.c')
-rw-r--r--handle.c13
1 files changed, 13 insertions, 0 deletions
diff --git a/handle.c b/handle.c
index a111b16..8a68c95 100644
--- a/handle.c
+++ b/handle.c
@@ -201,6 +201,18 @@ static void handleJoin(struct Message *msg) {
 	);
 }
 
+static void handlePart(struct Message *msg) {
+	require(msg, true, 1);
+	size_t id = idFor(msg->params[0]);
+	uiFormat(
+		id, Cold, tagTime(msg),
+		"\3%02d%s\3\tleaves \3%02d%s\3%s%s",
+		hash(msg->user), msg->nick, idColors[id], idNames[id],
+		(msg->params[1] ? ": " : ""),
+		(msg->params[1] ? msg->params[1] : "")
+	);
+}
+
 static bool isAction(struct Message *msg) {
 	if (strncmp(msg->params[1], "\1ACTION ", 8)) return false;
 	msg->params[1] += 8;
@@ -256,6 +268,7 @@ static const struct Handler {
 	{ "ERROR", handleError },
 	{ "JOIN", handleJoin },
 	{ "NOTICE", handlePrivmsg },
+	{ "PART", handlePart },
 	{ "PING", handlePing },
 	{ "PRIVMSG", handlePrivmsg },
 };