diff options
author | w00t <w00t@e03df62e-2008-0410-955e-edbf42e46eb7> | 2008-09-07 17:02:06 +0000 |
---|---|---|
committer | w00t <w00t@e03df62e-2008-0410-955e-edbf42e46eb7> | 2008-09-07 17:02:06 +0000 |
commit | be812e3a415655f8c60bd084d132173bfd07d7c6 (patch) | |
tree | 7917b92385b40531d11d88bf87dbecea16511fc1 | |
parent | c7cdfe744d7a94276ee4bb2bf9c07de9d9af0d99 (diff) |
Fix aliases returning multiple messages, thanks Ankit.
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@10444 e03df62e-2008-0410-955e-edbf42e46eb7
-rw-r--r-- | src/modules/m_alias.cpp | 29 |
1 files changed, 19 insertions, 10 deletions
diff --git a/src/modules/m_alias.cpp b/src/modules/m_alias.cpp index 62e091bb6..14339030f 100644 --- a/src/modules/m_alias.cpp +++ b/src/modules/m_alias.cpp @@ -167,7 +167,12 @@ class ModuleAlias : public Module while (i != Aliases.end()) { if (i->second.UserCommand) - DoAlias(user, NULL, &(i->second), compare, safe); + { + if (DoAlias(user, NULL, &(i->second), compare, safe)) + { + return 1; + } + } i++; } @@ -240,7 +245,10 @@ class ModuleAlias : public Module while (i != Aliases.end()) { if (i->second.ChannelCommand) - DoAlias(user, c, &(i->second), compare, safe); + { + if (DoAlias(user, c, &(i->second), compare, safe)) + return 0; + } i++; } @@ -249,26 +257,27 @@ class ModuleAlias : public Module } - void DoAlias(User *user, Channel *c, Alias *a, const std::string compare, const std::string safe) + int DoAlias(User *user, Channel *c, Alias *a, const std::string compare, const std::string safe) { User *u = NULL; + /* Does it match the pattern? */ if (!a->format.empty()) { if (a->CaseSensitive) { if (InspIRCd::Match(compare, a->format, case_sensitive_map)) - return; + return 0; } else { if (InspIRCd::Match(compare, a->format)) - return; + return 0; } } if ((a->OperOnly) && (!IS_OPER(user))) - return; + return 0; if (!a->RequiredNick.empty()) { @@ -276,7 +285,7 @@ class ModuleAlias : public Module if (!u) { user->WriteNumeric(401, ""+std::string(user->nick)+" "+a->RequiredNick+" :is currently unavailable. Please try again later."); - return; + return 1; } } if ((u != NULL) && (!a->RequiredNick.empty()) && (a->ULineOnly)) @@ -285,7 +294,7 @@ class ModuleAlias : public Module { ServerInstance->SNO->WriteToSnoMask('A', "NOTICE -- Service "+a->RequiredNick+" required by alias "+std::string(a->AliasedCommand.c_str())+" is not on a u-lined server, possibly underhanded antics detected!"); user->WriteNumeric(401, ""+std::string(user->nick)+" "+a->RequiredNick+" :is an imposter! Please inform an IRC operator as soon as possible."); - return; + return 1; } } @@ -296,7 +305,7 @@ class ModuleAlias : public Module if (crlf == std::string::npos) { DoCommand(a->ReplaceFormat, user, c, safe); - return; + return 0; } else { @@ -306,7 +315,7 @@ class ModuleAlias : public Module { DoCommand(scommand, user, c, safe); } - return; + return 0; } } |