diff options
author | Attila Molnar <attilamolnar@hush.com> | 2014-07-09 15:14:30 +0200 |
---|---|---|
committer | Attila Molnar <attilamolnar@hush.com> | 2014-07-09 15:14:30 +0200 |
commit | eef472fb62c299d4900baf0339e0eaf08648dcf1 (patch) | |
tree | 0518ec5511f6fadbe50098e62560bb585819d2e2 /src | |
parent | 18d9adff0fd2ea811dbbf17814a4ba5e36ed2da4 (diff) |
core_whowas Change the FIFO to be an intrusive list
Diffstat (limited to 'src')
-rw-r--r-- | src/coremods/core_whowas.cpp | 23 |
1 files changed, 8 insertions, 15 deletions
diff --git a/src/coremods/core_whowas.cpp b/src/coremods/core_whowas.cpp index 53b25eb7c..a27eb4341 100644 --- a/src/coremods/core_whowas.cpp +++ b/src/coremods/core_whowas.cpp @@ -109,19 +109,15 @@ void CommandWhowas::AddToWhoWas(User* user) ret.first->second = nick; // Add this nick to the fifo too - whowas_fifo.push_back(std::make_pair(ServerInstance->Time(), ret.first->first)); + whowas_fifo.push_back(nick); if (whowas.size() > this->MaxGroups) { // Too many nicks, remove the nick which was inserted the longest time ago from both the map and the fifo - whowas_users::iterator it = whowas.find(whowas_fifo.front().second); - if (it != whowas.end()) - { - WhoWas::Nick* set = it->second; - delete set; - whowas.erase(it); - } + nick = whowas_fifo.front(); whowas_fifo.pop_front(); + whowas.erase(nick->nick); + delete nick; } } else @@ -147,22 +143,19 @@ void CommandWhowas::Prune() /* first cut the list to new size (maxgroups) and also prune entries that are timed out. */ while (!whowas_fifo.empty()) { - if ((whowas_fifo.size() > this->MaxGroups) || (whowas_fifo.front().first < min)) + WhoWas::Nick* nick = whowas_fifo.front(); + if ((whowas_fifo.size() > this->MaxGroups) || (nick->addtime < min)) { - whowas_users::iterator iter = whowas.find(whowas_fifo.front().second); - /* hopefully redundant integrity check, but added while debugging r6216 */ - if (iter == whowas.end()) + if (!whowas.erase(nick->nick)) { /* this should never happen, if it does maps are corrupt */ ServerInstance->Logs->Log("WHOWAS", LOG_DEFAULT, "BUG: Whowas maps got corrupted! (1)"); return; } - WhoWas::Nick* nick = iter->second; - delete nick; - whowas.erase(iter); whowas_fifo.pop_front(); + delete nick; } else break; |