From 0f888d07d981965f9a9aff45988210996c71b12c 2011-07-20 11:23:24 From: Jan Kaluza Date: 2011-07-20 11:23:24 Subject: [PATCH] Disconnect removeTimeout once it's fired --- diff --git a/src/usermanager.cpp b/src/usermanager.cpp index 528f3739a49e47bdada9f1933838c7d3d4edeed8..2eae166f0b2dfa28b92b5b974b2e23a9f4e61447 100644 --- a/src/usermanager.cpp +++ b/src/usermanager.cpp @@ -188,7 +188,7 @@ void UserManager::handlePresence(Swift::Presence::ref presence) { Swift::Presence::ref highest = m_component->getPresenceOracle()->getHighestPriorityPresence(presence->getFrom().toBare()); // There's no presence for this user, so disconnect if (!highest || (highest && highest->getType() == Swift::Presence::Unavailable)) { - m_removeTimer->onTick.connect(boost::bind(&UserManager::handleRemoveTimeout, this, user->getJID().toBare().toString())); + m_removeTimer->onTick.connect(boost::bind(&UserManager::handleRemoveTimeout, this, user->getJID().toBare().toString())); m_removeTimer->start(); } } @@ -200,6 +200,7 @@ void UserManager::handlePresence(Swift::Presence::ref presence) { } void UserManager::handleRemoveTimeout(const std::string jid) { + m_removeTimer->onTick.disconnect(boost::bind(&UserManager::handleRemoveTimeout, this, jid)); User *user = getUser(jid); if (user) { removeUser(user);