commit 1edd94af86c032d4a83e5e2778526e567c1c4715
parent a3abf3b3ef581c415e4a29845453e49258faaada
Author: Anselm R. Garbe <arg@suckless.org>
Date: Fri, 9 Feb 2007 14:40:11 +0100
some changes
Diffstat:
M | sic.c | | | 50 | ++++++++++++++++++++++++-------------------------- |
1 file changed, 24 insertions(+), 26 deletions(-)
diff --git a/sic.c b/sic.c
@@ -102,45 +102,43 @@ parsesrv(char *msg) {
if(!msg || !(*msg))
return;
pout("debug", msg);
- if(msg[0] == ':') { /* check prefix */
- if(!(p = strchr(msg, ' ')))
- return;
+ if(msg[0] != ':')
+ return; /* don't handle prefix-less server commands */
+ if(!(p = strchr(msg, ' ')))
+ return;
+ usr = &msg[1];
+ *p = 0;
+ cmd = ++p;
+ if((p = strchr(usr, '!')))
*p = 0;
- usr = &msg[1];
- cmd = ++p;
- if((p = strchr(usr, '!')))
- *p = 0;
- } else
- cmd = msg;
/* remove CRLFs */
- for(p = cmd; *p; p++)
+ if(!(p = strchr(cmd, ':')))
+ return;
+ *p = 0;
+ txt = ++p;
+ for(p = txt; *p; p++)
if(*p == '\r' || *p == '\n')
*p = 0;
if(!strncmp("PONG", cmd, 4))
return;
- if(!strncmp("PRIVMSG", cmd, 7) || !strncmp("PING", cmd, 4)) {
+ if(!strncmp("PRIVMSG", cmd, 7)) {
if(!(p = strchr(cmd, ' ')))
return;
*p = 0;
chan = ++p;
for(; *p && *p != ' '; p++);
*p = 0;
- if(!(p = strchr(++p, ':')))
- return;
- *p = 0;
- txt = ++p;
- if(!strncmp("PRIVMSG", cmd, 8) && chan && txt) {
- snprintf(bufout, sizeof bufout, "<%s> %s", usr, txt);
- pout(chan, bufout);
- }
- else if(!strncmp("PING", cmd, 5) && txt) {
- snprintf(bufout, sizeof bufout, "PONG %s\r\n", txt);
- write(srv, bufout, strlen(bufout));
- }
- return;
+ snprintf(bufout, sizeof bufout, "<%s> %s", usr, txt);
+ pout(chan, bufout);
+ }
+ else if(!strncmp("PING", cmd, 4) && txt) {
+ snprintf(bufout, sizeof bufout, "PONG %s\r\n", txt);
+ write(srv, bufout, strlen(bufout));
+ }
+ else {
+ snprintf(bufout, sizeof bufout, "-!- %s", cmd);
+ pout(usr, bufout);
}
- snprintf(bufout, sizeof bufout, "-!- %s", cmd);
- pout(host, bufout);
}
int