summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKevin Smith <git@kismith.co.uk>2010-11-08 22:39:28 (GMT)
committerKevin Smith <git@kismith.co.uk>2010-11-08 22:39:28 (GMT)
commit8774d67aabd02086ec0663bb4567cef14bd513c6 (patch)
treebfb723ecc9b1fd528b1da3135a5cfd401c44a268 /Swiften/Presence
parenta594eb3fef7e047d1eca7959d7734d4d10fd1eb7 (diff)
downloadswift-8774d67aabd02086ec0663bb4567cef14bd513c6.zip
swift-8774d67aabd02086ec0663bb4567cef14bd513c6.tar.bz2
Brute force application of presence to roster items on add/modify.
Resolves: #655 Resolves: #672 Release-Notes: The roster should no longer sometimes show online users as offline.
Diffstat (limited to 'Swiften/Presence')
-rw-r--r--Swiften/Presence/PresenceOracle.cpp15
-rw-r--r--Swiften/Presence/PresenceOracle.h1
2 files changed, 16 insertions, 0 deletions
diff --git a/Swiften/Presence/PresenceOracle.cpp b/Swiften/Presence/PresenceOracle.cpp
index 387ad42..90e403c 100644
--- a/Swiften/Presence/PresenceOracle.cpp
+++ b/Swiften/Presence/PresenceOracle.cpp
@@ -76,6 +76,21 @@ Presence::ref PresenceOracle::getLastPresence(const JID& jid) const {
}
}
+std::vector<Presence::ref> PresenceOracle::getAllPresence(const JID& bareJID) const {
+ std::vector<Presence::ref> results;
+ PresencesMap::const_iterator i = entries_.find(bareJID);
+ if (i == entries_.end()) {
+ return results;
+ }
+ PresenceMap presenceMap = i->second;
+ PresenceMap::const_iterator j = presenceMap.begin();
+ for (; j != presenceMap.end(); j++) {
+ Presence::ref current = j->second;
+ results.push_back(current);
+ }
+ return results;
+}
+
Presence::ref PresenceOracle::getHighestPriorityPresence(const JID& bareJID) const {
PresencesMap::const_iterator i = entries_.find(bareJID);
if (i == entries_.end()) {
diff --git a/Swiften/Presence/PresenceOracle.h b/Swiften/Presence/PresenceOracle.h
index e846984..4e16e41 100644
--- a/Swiften/Presence/PresenceOracle.h
+++ b/Swiften/Presence/PresenceOracle.h
@@ -22,6 +22,7 @@ class StanzaChannel;
Presence::ref getLastPresence(const JID&) const;
Presence::ref getHighestPriorityPresence(const JID& bareJID) const;
+ std::vector<Presence::ref> getAllPresence(const JID& bareJID) const;
public:
boost::signal<void (Presence::ref)> onPresenceChange;