summaryrefslogtreecommitdiff
path: root/src/cmd_join.cpp
diff options
context:
space:
mode:
authorbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2006-07-16 15:08:59 +0000
committerbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2006-07-16 15:08:59 +0000
commit085cd4278f0f495c6d008a3d157026b33a23b787 (patch)
treeb1c5df846e0c74891546f24ebd5f41040dc86dea /src/cmd_join.cpp
parent863d8a3d08f7c4089683822f3d1e5544b6419ec6 (diff)
Created new class irc::commasepstream.
Will read comma seperated lists and works identically to irc::tokenstream It's re-entrant so we can run two of them together for JOIN git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@4412 e03df62e-2008-0410-955e-edbf42e46eb7
Diffstat (limited to 'src/cmd_join.cpp')
-rw-r--r--src/cmd_join.cpp25
1 files changed, 19 insertions, 6 deletions
diff --git a/src/cmd_join.cpp b/src/cmd_join.cpp
index fc63283e5..728038c2e 100644
--- a/src/cmd_join.cpp
+++ b/src/cmd_join.cpp
@@ -24,15 +24,28 @@ extern InspIRCd* ServerInstance;
void cmd_join::Handle (const char** parameters, int pcnt, userrec *user)
{
- if (ServerInstance->Parser->LoopCall(this, parameters, pcnt, user, 0, 0, 1))
- return;
-
- if (IsValidChannelName(parameters[0]))
+ if (pcnt > 1)
{
- add_channel(user, parameters[0], parameters[1], false);
+ if (ServerInstance->Parser->LoopCall(user, this, parameters, pcnt, 0, 1))
+ return;
+
+ if (IsValidChannelName(parameters[0]))
+ {
+ add_channel(user, parameters[0], parameters[1], false);
+ return;
+ }
}
else
{
- WriteServ(user->fd,"403 %s %s :Invalid channel name",user->nick, parameters[0]);
+ if (ServerInstance->Parser->LoopCall(user, this, parameters, pcnt, 0))
+ return;
+
+ if (IsValidChannelName(parameters[0]))
+ {
+ add_channel(user, parameters[0], "", false);
+ return;
+ }
}
+
+ WriteServ(user->fd,"403 %s %s :Invalid channel name",user->nick, parameters[0]);
}