summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2008-04-20 18:58:59 +0000
committerbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2008-04-20 18:58:59 +0000
commite5131f92b3b88ae7646da9a9972b1bbb5855f874 (patch)
tree1ce2c5c79b7cd2a3369e89ec1a64dbc4059c3dab
parenta36d5a1395d913ae72519aa48db3ca7f3ed138b6 (diff)
Fix RemoveCommands to remove all commands (this function had some really odd removal logic?)
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@9554 e03df62e-2008-0410-955e-edbf42e46eb7
-rw-r--r--include/command_parse.h3
-rw-r--r--src/command_parse.cpp15
2 files changed, 4 insertions, 14 deletions
diff --git a/include/command_parse.h b/include/command_parse.h
index fea8bd869..858c1c8e6 100644
--- a/include/command_parse.h
+++ b/include/command_parse.h
@@ -180,9 +180,8 @@ class CoreExport CommandParser : public classbase
/** Remove all commands relating to module 'source'.
* @param source A module name which has introduced new commands
- * @return True This function returns true if commands were removed
*/
- bool RemoveCommands(const char* source);
+ void RemoveCommands(const char* source);
/** Add a new command to the commands hash
* @param f The new Command to add to the list
diff --git a/src/command_parse.cpp b/src/command_parse.cpp
index dab770312..9e54a63d9 100644
--- a/src/command_parse.cpp
+++ b/src/command_parse.cpp
@@ -367,24 +367,15 @@ bool CommandParser::ProcessCommand(User *user, std::string &cmd)
}
}
-bool CommandParser::RemoveCommands(const char* source)
+void CommandParser::RemoveCommands(const char* source)
{
Commandable::iterator i,safei;
- for (i = cmdlist.begin(); i != cmdlist.end(); i++)
+ for (i = cmdlist.begin(); i != cmdlist.end();)
{
safei = i;
- safei++;
- if (safei != cmdlist.end())
- {
- RemoveCommand(safei, source);
- }
- }
- safei = cmdlist.begin();
- if (safei != cmdlist.end())
- {
+ i++;
RemoveCommand(safei, source);
}
- return true;
}
void CommandParser::RemoveCommand(Commandable::iterator safei, const char* source)