summaryrefslogtreecommitdiff
path: root/handle.c
diff options
context:
space:
mode:
authorC. McEnroe2020-02-08 00:58:17 -0500
committerC. McEnroe2020-02-08 00:58:17 -0500
commitb5707af4b842f521104c5fba07e5685612ff91f2 (patch)
treeaa599074d2fa08fc12cdf005e867a1c030b13526 /handle.c
parentf14175ebede46eb9e1fbf239a5c3b349951d34fc (diff)
Handle KICK
See I knew the color cache in complete would be useful in at least one place!
Diffstat (limited to 'handle.c')
-rw-r--r--handle.c20
1 files changed, 20 insertions, 0 deletions
diff --git a/handle.c b/handle.c
index de9e73a..8ebc3b1 100644
--- a/handle.c
+++ b/handle.c
@@ -226,6 +226,25 @@ static void handlePart(struct Message *msg) {
);
}
+static void handleKick(struct Message *msg) {
+ require(msg, true, 2);
+ size_t id = idFor(msg->params[0]);
+ bool kicked = self.nick && !strcmp(msg->params[1], self.nick);
+ completeTouch(id, msg->nick, hash(msg->user));
+ uiFormat(
+ id, (kicked ? Hot : Cold), tagTime(msg),
+ "%s\3%02d%s\17\tkicks \3%02d%s\3 out of \3%02d%s\3%s%s",
+ (kicked ? "\26" : ""),
+ hash(msg->user), msg->nick,
+ completeColor(id, msg->params[1]), msg->params[1],
+ hash(msg->params[0]), msg->params[0],
+ (msg->params[2] ? ": " : ""),
+ (msg->params[2] ? msg->params[2] : "")
+ );
+ completeRemove(id, msg->params[1]);
+ if (kicked) completeClear(id);
+}
+
static void handleNick(struct Message *msg) {
require(msg, true, 1);
if (self.nick && !strcmp(msg->nick, self.nick)) {
@@ -413,6 +432,7 @@ static const struct Handler {
{ "CAP", handleCap },
{ "ERROR", handleError },
{ "JOIN", handleJoin },
+ { "KICK", handleKick },
{ "NICK", handleNick },
{ "NOTICE", handlePrivmsg },
{ "PART", handlePart },