* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
* USA
- *
- * $Id: m_mode.c 1006 2006-03-09 15:32:14Z nenolod $
*/
#include "stdinc.h"
#include "packet.h"
#include "s_newconf.h"
-static int m_mode(struct Client *, struct Client *, int, const char **);
-static int ms_mode(struct Client *, struct Client *, int, const char **);
-static int ms_tmode(struct Client *, struct Client *, int, const char **);
-static int ms_mlock(struct Client *, struct Client *, int, const char **);
-static int ms_bmask(struct Client *, struct Client *, int, const char **);
+static const char mode_desc[] =
+ "Provides the MODE and MLOCK client and server commands, and TS6 server-to-server TMODE and BMASK commands";
+
+static void m_mode(struct MsgBuf *, struct Client *, struct Client *, int, const char **);
+static void ms_mode(struct MsgBuf *, struct Client *, struct Client *, int, const char **);
+static void ms_tmode(struct MsgBuf *, struct Client *, struct Client *, int, const char **);
+static void ms_mlock(struct MsgBuf *, struct Client *, struct Client *, int, const char **);
+static void ms_bmask(struct MsgBuf *, struct Client *, struct Client *, int, const char **);
struct Message mode_msgtab = {
- "MODE", 0, 0, 0, MFLG_SLOW,
+ "MODE", 0, 0, 0, 0,
{mg_unreg, {m_mode, 2}, {m_mode, 3}, {ms_mode, 3}, mg_ignore, {m_mode, 2}}
};
struct Message tmode_msgtab = {
- "TMODE", 0, 0, 0, MFLG_SLOW,
+ "TMODE", 0, 0, 0, 0,
{mg_ignore, mg_ignore, {ms_tmode, 4}, {ms_tmode, 4}, mg_ignore, mg_ignore}
};
struct Message mlock_msgtab = {
- "MLOCK", 0, 0, 0, MFLG_SLOW,
+ "MLOCK", 0, 0, 0, 0,
{mg_ignore, mg_ignore, {ms_mlock, 3}, {ms_mlock, 3}, mg_ignore, mg_ignore}
};
struct Message bmask_msgtab = {
- "BMASK", 0, 0, 0, MFLG_SLOW,
+ "BMASK", 0, 0, 0, 0,
{mg_ignore, mg_ignore, mg_ignore, {ms_bmask, 5}, mg_ignore, mg_ignore}
};
mapi_clist_av1 mode_clist[] = { &mode_msgtab, &tmode_msgtab, &mlock_msgtab, &bmask_msgtab, NULL };
-DECLARE_MODULE_AV1(mode, NULL, NULL, mode_clist, NULL, NULL, "$Revision: 1006 $");
+DECLARE_MODULE_AV2(mode, NULL, NULL, mode_clist, NULL, NULL, NULL, NULL, mode_desc);
/*
* m_mode - MODE command handler
* parv[1] - channel
*/
-static int
-m_mode(struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
+static void
+m_mode(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
{
struct Channel *chptr = NULL;
struct membership *msptr;
{
sendto_one(source_p, form_str(ERR_NEEDMOREPARAMS),
me.name, source_p->name, "MODE");
- return 0;
+ return;
}
}
{
/* if here, it has to be a non-channel name */
user_mode(client_p, source_p, parc, parv);
- return 0;
+ return;
}
if(!check_channel_name(dest))
{
sendto_one_numeric(source_p, ERR_BADCHANNAME, form_str(ERR_BADCHANNAME), parv[1]);
- return 0;
+ return;
}
chptr = find_channel(dest);
{
sendto_one_numeric(source_p, ERR_NOSUCHCHANNEL,
form_str(ERR_NOSUCHCHANNEL), parv[1]);
- return 0;
+ return;
}
/* Now know the channel exists */
/* Finish the flood grace period... */
if(MyClient(source_p) && !IsFloodDone(source_p))
{
- if(!((parc == 3) && (parv[2][0] == 'b') && (parv[2][1] == '\0')))
+ if(!((parc == 3) && (parv[2][0] == 'b' || parv[2][0] == 'q') && (parv[2][1] == '\0')))
flood_endgrace(source_p);
}
set_channel_mode(client_p, source_p, chptr, msptr, parc - n, parv + n);
}
-
- return 0;
}
-static int
-ms_mode(struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
+static void
+ms_mode(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
{
struct Channel *chptr;
{
sendto_one_numeric(source_p, ERR_NOSUCHCHANNEL,
form_str(ERR_NOSUCHCHANNEL), parv[1]);
- return 0;
+ return;
}
set_channel_mode(client_p, source_p, chptr, NULL, parc - 2, parv + 2);
-
- return 0;
}
-static int
-ms_tmode(struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
+static void
+ms_tmode(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
{
struct Channel *chptr = NULL;
struct membership *msptr;
if(!IsChanPrefix(parv[2][0]) || !check_channel_name(parv[2]))
{
sendto_one_numeric(source_p, ERR_BADCHANNAME, form_str(ERR_BADCHANNAME), parv[2]);
- return 0;
+ return;
}
chptr = find_channel(parv[2]);
{
sendto_one_numeric(source_p, ERR_NOSUCHCHANNEL,
form_str(ERR_NOSUCHCHANNEL), parv[2]);
- return 0;
+ return;
}
/* TS is higher, drop it. */
if(atol(parv[1]) > chptr->channelts)
- return 0;
+ return;
if(IsServer(source_p))
{
set_channel_mode(client_p, source_p, chptr, msptr, parc - 3, parv + 3);
}
-
- return 0;
}
-static int
-ms_mlock(struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
+static void
+ms_mlock(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
{
struct Channel *chptr = NULL;
if(!IsChanPrefix(parv[2][0]) || !check_channel_name(parv[2]))
{
sendto_one_numeric(source_p, ERR_BADCHANNAME, form_str(ERR_BADCHANNAME), parv[2]);
- return 0;
+ return;
}
chptr = find_channel(parv[2]);
{
sendto_one_numeric(source_p, ERR_NOSUCHCHANNEL,
form_str(ERR_NOSUCHCHANNEL), parv[2]);
- return 0;
+ return;
}
/* TS is higher, drop it. */
if(atol(parv[1]) > chptr->channelts)
- return 0;
+ return;
if(IsServer(source_p))
- set_channel_mlock(client_p, source_p, chptr, parv[3], TRUE);
-
- return 0;
+ set_channel_mlock(client_p, source_p, chptr, parv[3], true);
}
static void
}
}
-static int
-ms_bmask(struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
+static void
+ms_bmask(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
{
static char modebuf[BUFSIZE];
static char parabuf[BUFSIZE];
struct Client *fakesource_p;
if(!IsChanPrefix(parv[2][0]) || !check_channel_name(parv[2]))
- return 0;
+ return;
if((chptr = find_channel(parv[2])) == NULL)
- return 0;
+ return;
/* TS is higher, drop it. */
if(atol(parv[1]) > chptr->channelts)
- return 0;
+ return;
switch (parv[3][0])
{
/* maybe we should just blindly propagate this? */
default:
- return 0;
+ return;
}
parabuf[0] = '\0';
fakesource_p = &me;
else
fakesource_p = source_p;
- mlen = rb_sprintf(modebuf, ":%s MODE %s +", fakesource_p->name, chptr->chname);
+ mlen = sprintf(modebuf, ":%s MODE %s +", fakesource_p->name, chptr->chname);
mbuf = modebuf + mlen;
pbuf = parabuf;
forward[-1] = '$';
*mbuf++ = parv[3][0];
- arglen = rb_sprintf(pbuf, "%s ", s);
+ arglen = sprintf(pbuf, "%s ", s);
pbuf += arglen;
plen += arglen;
modecount++;
sendto_server(client_p, chptr, CAP_TS6 | needcap, NOCAPS, ":%s BMASK %ld %s %s :%s",
source_p->id, (long) chptr->channelts, chptr->chname, parv[3], parv[4]);
- return 0;
}
-