#include "numeric.h"
#include "s_conf.h"
#include "send.h"
+#include "supported.h"
-static int m_monitor(struct Client *, struct Client *, int, const char **);
+static int monitor_init(void);
+static void monitor_deinit(void);
+static int m_monitor(struct MsgBuf *, struct Client *, struct Client *, int, const char **);
struct Message monitor_msgtab = {
- "MONITOR", 0, 0, 0, MFLG_SLOW,
+ "MONITOR", 0, 0, 0, 0,
{mg_unreg, {m_monitor, 2}, mg_ignore, mg_ignore, mg_ignore, {m_monitor, 2}}
};
mapi_clist_av1 monitor_clist[] = { &monitor_msgtab, NULL };
-DECLARE_MODULE_AV1(monitor, NULL, NULL, monitor_clist, NULL, NULL, "$Revision: 312 $");
+DECLARE_MODULE_AV1(monitor, monitor_init, monitor_deinit, monitor_clist, NULL, NULL, "$Revision: 312 $");
+
+static int monitor_init(void)
+{
+ add_isupport("MONITOR", isupport_intptr, &ConfigFileEntry.max_monitor);
+ return 0;
+}
+
+static void monitor_deinit(void)
+{
+ delete_isupport("MONITOR");
+}
static void
add_monitor(struct Client *client_p, const char *nicks)
continue;
if(rb_dlink_list_length(&client_p->localClient->monitor_list) >=
- ConfigFileEntry.max_monitor)
+ (unsigned long)ConfigFileEntry.max_monitor)
{
char buf[100];
sendto_one(client_p, "%s", offbuf);
if(p)
- rb_snprintf(buf, sizeof(buf), "%s,%s", name, p);
+ snprintf(buf, sizeof(buf), "%s,%s", name, p);
else
- rb_snprintf(buf, sizeof(buf), "%s", name);
+ snprintf(buf, sizeof(buf), "%s", name);
sendto_one(client_p, form_str(ERR_MONLISTFULL),
me.name, client_p->name,
return;
}
+ if (!clean_nick(name, 0))
+ continue;
+
monptr = find_monitor(name, 1);
/* already monitoring this nick */
rb_dlinkFindDestroy(client_p, &monptr->users);
rb_dlinkFindDestroy(monptr, &client_p->localClient->monitor_list);
+
+ free_monitor(monptr);
}
}
}
static int
-m_monitor(struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
+m_monitor(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
{
switch(parv[1][0])
{
return 0;
}
-