summaryrefslogtreecommitdiff
path: root/src/usermanager.cpp
diff options
context:
space:
mode:
authorAttila Molnar <attilamolnar@hush.com>2015-11-03 13:13:00 +0100
committerAttila Molnar <attilamolnar@hush.com>2015-11-03 13:13:00 +0100
commitc89cc290fbc6d53040fc8abc6fc0b0cb637beee9 (patch)
tree97060938b9341f81ad2fb47a9afecd720d182569 /src/usermanager.cpp
parent3ef3047681f0813d8f1d06939eaa2ef378d99505 (diff)
Move already sent id rollover handling and static LocalUser::already_sent_id into UserManager
Diffstat (limited to 'src/usermanager.cpp')
-rw-r--r--src/usermanager.cpp16
1 files changed, 13 insertions, 3 deletions
diff --git a/src/usermanager.cpp b/src/usermanager.cpp
index c593e149f..d81b83d20 100644
--- a/src/usermanager.cpp
+++ b/src/usermanager.cpp
@@ -49,7 +49,8 @@ namespace
}
UserManager::UserManager()
- : unregistered_count(0)
+ : already_sent_id(0)
+ , unregistered_count(0)
{
}
@@ -281,7 +282,6 @@ void UserManager::ServerNoticeAll(const char* text, ...)
void UserManager::GarbageCollect()
{
// Reset the already_sent IDs so we don't wrap it around and drop a message
- LocalUser::already_sent_id = 0;
for (LocalList::const_iterator i = local_users.begin(); i != local_users.end(); ++i)
(**i).already_sent = 0;
}
@@ -371,5 +371,15 @@ void UserManager::DoBackgroundUserStuff()
already_sent_t UserManager::NextAlreadySentId()
{
- return ++LocalUser::already_sent_id;
+ if (++already_sent_id == 0)
+ {
+ // Wrapped around, reset the already_sent ids of all users
+ already_sent_id = 1;
+ for (LocalList::iterator i = local_users.begin(); i != local_users.end(); ++i)
+ {
+ LocalUser* user = *i;
+ user->already_sent = 0;
+ }
+ }
+ return already_sent_id;
}