void lua_ondisconnect(int hooknum, void *arg);
void lua_onmode(int hooknum, void *arg);
void lua_onop(int hooknum, void *arg);
+void lua_onvoice(int hooknum, void *arg);
+void lua_onprequit(int hooknum, void *arg);
void lua_onquit(int hooknum, void *arg);
void lua_onrename(int hooknum, void *arg);
void lua_onconnect(int hooknum, void *arg);
registerhook(HOOK_CHANNEL_KICK, &lua_onkick);
registerhook(HOOK_CHANNEL_OPPED, &lua_onop);
registerhook(HOOK_CHANNEL_DEOPPED, &lua_onop);
+ registerhook(HOOK_CHANNEL_VOICED, &lua_onvoice);
+ registerhook(HOOK_CHANNEL_DEVOICED, &lua_onvoice);
+ registerhook(HOOK_NICK_PRE_LOSTNICK, &lua_onprequit);
registerhook(HOOK_NICK_LOSTNICK, &lua_onquit);
registerhook(HOOK_NICK_RENAME, &lua_onrename);
registerhook(HOOK_IRC_CONNECTED, &lua_onconnect);
deregisterhook(HOOK_IRC_CONNECTED, &lua_onconnect);
deregisterhook(HOOK_NICK_RENAME, &lua_onrename);
deregisterhook(HOOK_NICK_LOSTNICK, &lua_onquit);
+ deregisterhook(HOOK_NICK_PRE_LOSTNICK, &lua_onprequit);
deregisterhook(HOOK_CHANNEL_DEOPPED, &lua_onop);
deregisterhook(HOOK_CHANNEL_OPPED, &lua_onop);
+ deregisterhook(HOOK_CHANNEL_DEVOICED, &lua_onvoice);
+ deregisterhook(HOOK_CHANNEL_VOICED, &lua_onvoice);
deregisterhook(HOOK_CHANNEL_KICK, &lua_onkick);
deregisterhook(HOOK_CHANNEL_TOPIC, &lua_ontopic);
deregisterhook(HOOK_NICK_ACCOUNT, &lua_onauth);
p[le - 1] = '\000';
lua_avpcall("irc_onctcp", "ls", np->numeric, p + 1);
-
+ } else {
+ lua_avpcall("irc_onnotice", "ls", np->numeric, p);
}
break;
nick *kicked = arglist[1];
nick *kicker = arglist[2];
char *message = (char *)arglist[3];
- int mode = 1;
-
- if(!kicker || IsOper(kicker) || IsService(kicker) || IsXOper(kicker)) /* bloody Cruicky */
- mode = 0;
- if(mode) {
+ if(kicker)
lua_avpcall("irc_onkick", "Slls", ci->name, kicked->numeric, kicker->numeric, message);
- } else if(kicker) {
- lua_avpcall("irc_onkickall", "Slls", ci->name, kicked->numeric, kicker->numeric, message);
- } else {
- lua_avpcall("irc_onkickall", "Sl0s", ci->name, kicked->numeric, message);
- }
+ else
+ lua_avpcall("irc_onkick", "Sl0s", ci->name, kicked->numeric, message);
}
void lua_ontopic(int hooknum, void *arg) {
channel *cp=(channel*)arglist[0];
nick *np = (nick *)arglist[1];
- if(!np || IsOper(np) || IsService(np) || IsXOper(np))
- return;
- if(!cp || !cp->topic)
+ if(!cp || !cp->topic)
return;
- lua_avpcall("irc_ontopic", "SlS", cp->index->name, np->numeric, cp->topic);
+ if(np)
+ lua_avpcall("irc_ontopic", "SlS", cp->index->name, np->numeric, cp->topic);
+ else
+ lua_avpcall("irc_ontopic", "S0S", cp->index->name, cp->topic);
}
void lua_onop(int hooknum, void *arg) {
}
}
+void lua_onvoice(int hooknum, void *arg) {
+ void **arglist = (void **)arg;
+ chanindex *ci = ((channel *)arglist[0])->index;
+ nick *np = arglist[1];
+ nick *target = arglist[2];
+
+ if(!target)
+ return;
+
+ if(np) {
+ lua_avpcall(hooknum == HOOK_CHANNEL_VOICED?"irc_onvoice":"irc_ondevoice", "Sll", ci->name, np->numeric, target->numeric);
+ } else {
+ lua_avpcall(hooknum == HOOK_CHANNEL_VOICED?"irc_onvoice":"irc_ondevoice", "S0l", ci->name, target->numeric);
+ }
+}
+
void lua_onjoin(int hooknum, void *arg) {
void **arglist = (void **)arg;
chanindex *ci = ((channel *)arglist[0])->index;
void **arglist = (void **)arg;
chanindex *ci = ((channel *)arglist[0])->index;
nick *np = arglist[1];
+ char *reason = arglist[2];
if(!ci || !np)
return;
- lua_avpcall("irc_onpart", "Sl", ci->name, np->numeric);
+ lua_avpcall("irc_onpart", "Sls", ci->name, np->numeric, reason);
}
void lua_onrename(int hooknum, void *arg) {
lua_avpcall("irc_onquit", "l", np->numeric);
}
+void lua_onprequit(int hooknum, void *arg) {
+ nick *np = (nick *)arg;
+
+ if(!np)
+ return;
+
+ lua_avpcall("irc_onprequit", "l", np->numeric);
+}
+
void lua_onauth(int hooknum, void *arg) {
nick *np = (nick *)arg;
return buf;
}
+static char *printlimitedmodes(channel *cp, flag_t before) {
+ static char buf[1024];
+
+ snprintf(buf, sizeof(buf), "%s", printflags(cp->flags, cmodeflags));
+
+ return buf;
+}
+
void lua_onmode(int hooknum, void *arg) {
void **arglist = (void **)arg;
channel *cp = (channel *)arglist[0];
chanindex *ci = cp->index;
nick *np = arglist[1];
+ flag_t beforeflags = (flag_t)(long)arglist[3];
if(np) {
- lua_avpcall("irc_onmode", "Sls", ci->name, np->numeric, printallmodes(cp));
+ lua_avpcall("irc_onmode", "Slss", ci->name, np->numeric, printallmodes(cp), printlimitedmodes(cp, beforeflags));
} else {
- lua_avpcall("irc_onmode", "S0s", ci->name, printallmodes(cp));
+ lua_avpcall("irc_onmode", "S0ss", ci->name, printallmodes(cp), printlimitedmodes(cp, beforeflags));
}
}
-
-