summaryrefslogtreecommitdiff
path: root/src/modules
diff options
context:
space:
mode:
authorbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2006-11-26 02:33:42 +0000
committerbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2006-11-26 02:33:42 +0000
commit9ae7cd7bf378ded4c09814ca13b36dd5302f9d06 (patch)
treeba32dd0cffdef272cf525165ea069c5a4890bc22 /src/modules
parent307a31f79486d56f463becd093dea873ce0dc0f0 (diff)
Make silence list removals and additions a ton faster by making the silence list a map. Note that this probably wont port to peavey's improved silence, i wouldnt bother trying :p
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@5798 e03df62e-2008-0410-955e-edbf42e46eb7
Diffstat (limited to 'src/modules')
-rw-r--r--src/modules/m_silence.cpp37
1 files changed, 14 insertions, 23 deletions
diff --git a/src/modules/m_silence.cpp b/src/modules/m_silence.cpp
index 6d51c718c..595c3505e 100644
--- a/src/modules/m_silence.cpp
+++ b/src/modules/m_silence.cpp
@@ -28,11 +28,10 @@ using namespace std;
/* $ModDesc: Provides support for the /SILENCE command */
-
// This typedef holds a silence list. Each user may or may not have a
// silencelist, if a silence list is empty for a user, he/she does not
// have one of these structures associated with their user record.
-typedef std::vector<std::string> silencelist;
+typedef std::map<irc::string, time_t> silencelist;
class cmd_silence : public command_t
{
@@ -54,9 +53,9 @@ class cmd_silence : public command_t
// if the user has a silence list associated with their user record, show it
if (sl)
{
- for (silencelist::const_iterator c = sl->begin(); c < sl->end(); c++)
+ for (silencelist::const_iterator c = sl->begin(); c != sl->end(); c++)
{
- user->WriteServ("271 %s %s %s",user->nick, user->nick,c->c_str());
+ user->WriteServ("271 %s %s %s :%lu",user->nick, user->nick, c->first.c_str(), (unsigned long)c->second);
}
}
user->WriteServ("272 %s :End of Silence List",user->nick);
@@ -87,16 +86,11 @@ class cmd_silence : public command_t
{
if (sl->size())
{
- for (silencelist::iterator i = sl->begin(); i != sl->end(); i++)
- {
- // search through for the item
- irc::string listitem = i->c_str();
- if (listitem == mask)
- {
- sl->erase(i);
- user->WriteServ("950 %s %s :Removed %s from silence list",user->nick, user->nick, mask.c_str());
- break;
- }
+ silencelist::iterator i = sl->find(mask.c_str());
+ if (i != sl->end())
+ {
+ sl->erase(i);
+ user->WriteServ("950 %s %s :Removed %s from silence list",user->nick, user->nick, mask.c_str());
}
}
else
@@ -119,16 +113,13 @@ class cmd_silence : public command_t
sl = new silencelist;
user->Extend("silence_list", sl);
}
- for (silencelist::iterator n = sl->begin(); n != sl->end(); n++)
+ silencelist::iterator n = sl->find(mask.c_str());
+ if (n != sl->end())
{
- irc::string listitem = n->c_str();
- if (listitem == mask)
- {
- user->WriteServ("952 %s %s :%s is already on your silence list",user->nick, user->nick, mask.c_str());
- return CMD_SUCCESS;
- }
+ user->WriteServ("952 %s %s :%s is already on your silence list",user->nick, user->nick, mask.c_str());
+ return CMD_FAILURE;
}
- sl->push_back(mask);
+ sl->insert(std::make_pair<irc::string, time_t>(mask.c_str(), ServerInstance->Time()));
user->WriteServ("951 %s %s :Added %s to silence list",user->nick, user->nick, mask.c_str());
return CMD_SUCCESS;
}
@@ -190,7 +181,7 @@ class ModuleSilence : public Module
{
for (silencelist::const_iterator c = sl->begin(); c != sl->end(); c++)
{
- if (match(user->GetFullHost(), c->c_str()))
+ if (match(user->GetFullHost(), c->first.c_str()))
{
return 1;
}