/***********************************************************************
X3 ChangeLog
+2009-11-24 Henrik Stuart <evilnet@hstuart.dk>
+
+ * src/hash.c src/hash.h: add extra parameter to reg_kick_func and
+ kick_func_t.
+
+ * src/chanserv.c src/mod-snoop.c src/mod-track.c: collateral evolution
+ fixes due to kick_func change.
+
2009-11-24 Henrik Stuart <evilnet@hstuart.dk>
* src/hash.c src/hash.h: add extra parameter to reg_part_func,
}
static void
-handle_kick(struct userNode *kicker, struct userNode *victim, struct chanNode *channel)
+handle_kick(struct userNode *kicker, struct userNode *victim, struct chanNode *channel, UNUSED_ARG(void *extra))
{
struct userData *uData;
}
static kick_func_t *kf_list;
+static void **kf_list_extra;
static unsigned int kf_size = 0, kf_used = 0;
void
/* This may break things, but lets see.. -Rubin */
for (n=0; n<kf_used; n++)
- kf_list[n](kicker, target, channel);
+ kf_list[n](kicker, target, channel, kf_list_extra[n]);
/* don't remove them from the channel, since the server will send a PART */
irc_kick(kicker, target, channel, why);
}
void
-reg_kick_func(kick_func_t handler)
+reg_kick_func(kick_func_t handler, void *extra)
{
if (kf_used == kf_size) {
if (kf_size) {
kf_size <<= 1;
kf_list = realloc(kf_list, kf_size*sizeof(kick_func_t));
+ kf_list_extra = realloc(kf_list_extra, kf_size*sizeof(void*));
} else {
kf_size = 8;
kf_list = malloc(kf_size*sizeof(kick_func_t));
+ kf_list_extra = malloc(kf_size*sizeof(void*));
}
}
- kf_list[kf_used++] = handler;
+ kf_list[kf_used] = handler;
+ kf_list_extra[kf_used++] = extra;
}
void
mn->idle_since = now;
for (n=0; n<kf_used; n++)
- kf_list[n](kicker, victim, channel);
+ kf_list[n](kicker, victim, channel, kf_list_extra[n]);
DelChannelUser(victim, channel, 0, 0);
free(pf_list);
free(pf_list_extra);
free(kf_list);
+ free(kf_list_extra);
free(tf_list);
free(tf_list_extra);
}
void DelChannelUser(struct userNode* user, struct chanNode* channel, const char *reason, int deleting);
void KickChannelUser(struct userNode* target, struct chanNode* channel, struct userNode *kicker, const char *why);
-typedef void (*kick_func_t) (struct userNode *kicker, struct userNode *user, struct chanNode *chan);
-void reg_kick_func(kick_func_t handler);
+typedef void (*kick_func_t) (struct userNode *kicker, struct userNode *user, struct chanNode *chan, void *extra);
+void reg_kick_func(kick_func_t handler, void *extra);
void ChannelUserKicked(struct userNode* kicker, struct userNode* victim, struct chanNode* channel);
int ChannelBanExists(struct chanNode *channel, const char *ban);
}
static void
-snoop_kick(struct userNode *kicker, struct userNode *victim, struct chanNode *chan) {
+snoop_kick(struct userNode *kicker, struct userNode *victim, struct chanNode *chan, UNUSED_ARG(void *extra)) {
if (!snoop_cfg.enabled) return;
UPDATE_TIMESTAMP();
SNOOP("$bKICK$b %s from %s by %s", victim->nick, chan->name, (kicker ? kicker->nick : "some server"));
}
static void
-track_kick(struct userNode *kicker, struct userNode *victim, struct chanNode *chan) {
+track_kick(struct userNode *kicker, struct userNode *victim, struct chanNode *chan, UNUSED_ARG(void *extra)) {
if (!track_cfg.enabled) return;
if (check_track_kick(track_cfg) && ((check_track_user(kicker->nick) || check_track_user(victim->nick))))
{