Parse time tag
parent
c799310d67
commit
8ef0af34ef
25
handle.c
25
handle.c
|
@ -65,8 +65,6 @@ static void set(char **field, const char *value) {
|
||||||
if (!*field) err(EX_OSERR, "strdup");
|
if (!*field) err(EX_OSERR, "strdup");
|
||||||
}
|
}
|
||||||
|
|
||||||
typedef void Handler(struct Message *msg);
|
|
||||||
|
|
||||||
static void require(const struct Message *msg, bool origin, size_t len) {
|
static void require(const struct Message *msg, bool origin, size_t len) {
|
||||||
if (origin && !msg->nick) {
|
if (origin && !msg->nick) {
|
||||||
errx(EX_PROTOCOL, "%s missing origin", msg->cmd);
|
errx(EX_PROTOCOL, "%s missing origin", msg->cmd);
|
||||||
|
@ -77,6 +75,16 @@ static void require(const struct Message *msg, bool origin, size_t len) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const struct tm *tagTime(const struct Message *msg) {
|
||||||
|
if (!msg->tags[TagTime]) return NULL;
|
||||||
|
static struct tm time;
|
||||||
|
char *rest = strptime(msg->tags[TagTime], "%FT%T", &time);
|
||||||
|
time.tm_gmtoff = 0;
|
||||||
|
return (rest ? &time : NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
typedef void Handler(struct Message *msg);
|
||||||
|
|
||||||
static void handleCap(struct Message *msg) {
|
static void handleCap(struct Message *msg) {
|
||||||
require(msg, false, 3);
|
require(msg, false, 3);
|
||||||
enum Cap caps = capParse(msg->params[2]);
|
enum Cap caps = capParse(msg->params[2]);
|
||||||
|
@ -143,7 +151,10 @@ static void handleReplyISupport(struct Message *msg) {
|
||||||
char *key = strsep(&msg->params[i], "=");
|
char *key = strsep(&msg->params[i], "=");
|
||||||
if (!msg->params[i]) continue;
|
if (!msg->params[i]) continue;
|
||||||
if (!strcmp(key, "NETWORK")) {
|
if (!strcmp(key, "NETWORK")) {
|
||||||
uiFormat(Network, Cold, NULL, "You arrive in %s", msg->params[i]);
|
uiFormat(
|
||||||
|
Network, Cold, tagTime(msg),
|
||||||
|
"You arrive in %s", msg->params[i]
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -152,7 +163,12 @@ static void handleReplyMOTD(struct Message *msg) {
|
||||||
require(msg, false, 2);
|
require(msg, false, 2);
|
||||||
char *line = msg->params[1];
|
char *line = msg->params[1];
|
||||||
if (!strncmp(line, "- ", 2)) line += 2;
|
if (!strncmp(line, "- ", 2)) line += 2;
|
||||||
uiFormat(Network, Cold, NULL, "%s", line);
|
uiFormat(Network, Cold, tagTime(msg), "%s", line);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void handlePing(struct Message *msg) {
|
||||||
|
require(msg, false, 1);
|
||||||
|
ircFormat("PONG :%s\r\n", msg->params[0]);
|
||||||
}
|
}
|
||||||
|
|
||||||
static const struct Handler {
|
static const struct Handler {
|
||||||
|
@ -168,6 +184,7 @@ static const struct Handler {
|
||||||
{ "906", handleErrorSASLFail },
|
{ "906", handleErrorSASLFail },
|
||||||
{ "AUTHENTICATE", handleAuthenticate },
|
{ "AUTHENTICATE", handleAuthenticate },
|
||||||
{ "CAP", handleCap },
|
{ "CAP", handleCap },
|
||||||
|
{ "PING", handlePing },
|
||||||
};
|
};
|
||||||
|
|
||||||
static int compar(const void *cmd, const void *_handler) {
|
static int compar(const void *cmd, const void *_handler) {
|
||||||
|
|
Loading…
Reference in New Issue