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);
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);
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);
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;
lua_avpcall("irc_onmode", "S0ss", ci->name, printallmodes(cp), printlimitedmodes(cp, beforeflags));
}
}
-
-