summaryrefslogtreecommitdiff
path: root/src/core/cs_modes.c
diff options
context:
space:
mode:
authoradam- <adam-@5417fbe8-f217-4b02-8779-1006273d7864>2009-06-23 16:56:38 +0000
committeradam- <adam-@5417fbe8-f217-4b02-8779-1006273d7864>2009-06-23 16:56:38 +0000
commitdc8f7923f4c9cd685a338072bcc2bb351bf575d9 (patch)
treecb55529a96b40d43b2646640a06cc248efa76efb /src/core/cs_modes.c
parent59c1a509b4264648a6ef61e96b85f06f735d6dd6 (diff)
Adds check for using commands on non-registered channels before the
commands are called git-svn-id: http://anope.svn.sourceforge.net/svnroot/anope/trunk@2336 5417fbe8-f217-4b02-8779-1006273d7864
Diffstat (limited to 'src/core/cs_modes.c')
-rw-r--r--src/core/cs_modes.c9
1 files changed, 5 insertions, 4 deletions
diff --git a/src/core/cs_modes.c b/src/core/cs_modes.c
index 3b081e3b1..239b31305 100644
--- a/src/core/cs_modes.c
+++ b/src/core/cs_modes.c
@@ -20,7 +20,7 @@
static CommandReturn do_util(User *u, CSModeUtil *util, const char *chan, const char *nick)
{
const char *av[2];
- Channel *c;
+ Channel *c = findchan(chan);
ChannelInfo *ci;
User *u2;
@@ -32,10 +32,11 @@ static CommandReturn do_util(User *u, CSModeUtil *util, const char *chan, const
is_same = (nick == u->nick) ? 1 : (stricmp(nick, u->nick) == 0);
- if (!(c = findchan(chan))) {
+ if (c)
+ ci = c->ci;
+
+ if (!c) {
notice_lang(s_ChanServ, u, CHAN_X_NOT_IN_USE, chan);
- } else if (!(ci = c->ci)) {
- notice_lang(s_ChanServ, u, CHAN_X_NOT_REGISTERED, c->name);
} else if (is_same ? !(u2 = u) : !(u2 = finduser(nick))) {
notice_lang(s_ChanServ, u, NICK_X_NOT_IN_USE, nick);
} else if (!is_on_chan(c, u2)) {