diff options
Diffstat (limited to 'Swiften/Roster')
-rw-r--r-- | Swiften/Roster/XMPPRoster.cpp | 22 | ||||
-rw-r--r-- | Swiften/Roster/XMPPRoster.h | 14 |
2 files changed, 27 insertions, 9 deletions
diff --git a/Swiften/Roster/XMPPRoster.cpp b/Swiften/Roster/XMPPRoster.cpp index a5cccaf..62edc45 100644 --- a/Swiften/Roster/XMPPRoster.cpp +++ b/Swiften/Roster/XMPPRoster.cpp @@ -2,17 +2,21 @@ namespace Swift { -void XMPPRoster::addContact(const JID& jid, const String& name, const std::vector<String>& groups) { +void XMPPRoster::addContact(const JID& jid, const String& name, const std::vector<String>& groups, RosterItemPayload::Subscription subscription) { JID bareJID(jid.toBare()); bool exists = containsJID(bareJID); + String oldName = getNameForJID(bareJID); + std::vector<String> oldGroups = entries_[bareJID].groups; if (exists) { entries_.erase(bareJID); } - String oldName = getNameForJID(bareJID); - std::vector<String> oldGroups = entries_[bareJID].second; - entries_[bareJID] = std::pair<String, std::vector<String> >(name, groups); + XMPPRosterItem item; + item.groups = groups; + item.name = name; + item.jid = jid; + item.subscription = subscription; + entries_[bareJID] = item; if (exists) { - onJIDUpdated(bareJID, oldName, oldGroups); } else { onJIDAdded(bareJID); @@ -29,11 +33,15 @@ bool XMPPRoster::containsJID(const JID& jid) { } const String& XMPPRoster::getNameForJID(const JID& jid) { - return entries_[JID(jid.toBare())].first; + return entries_[JID(jid.toBare())].name; } const std::vector<String>& XMPPRoster::getGroupsForJID(const JID& jid) { - return entries_[JID(jid.toBare())].second; + return entries_[JID(jid.toBare())].groups; +} + +RosterItemPayload::Subscription XMPPRoster::getSubscriptionStateForJID(const JID& jid) { + return entries_[JID(jid.toBare())].subscription; } } diff --git a/Swiften/Roster/XMPPRoster.h b/Swiften/Roster/XMPPRoster.h index 7a72e00..47326c3 100644 --- a/Swiften/Roster/XMPPRoster.h +++ b/Swiften/Roster/XMPPRoster.h @@ -3,6 +3,7 @@ #include "Swiften/Base/String.h" #include "Swiften/JID/JID.h" +#include "Swiften/Elements/RosterItemPayload.h" #include <map> #include <vector> @@ -10,14 +11,22 @@ namespace Swift { +struct XMPPRosterItem { + JID jid; + String name; + std::vector<String> groups; + RosterItemPayload::Subscription subscription; +}; + class XMPPRoster { public: XMPPRoster() {}; ~XMPPRoster() {}; - void addContact(const JID& jid, const String& name, const std::vector<String>& groups); + void addContact(const JID& jid, const String& name, const std::vector<String>& groups, const RosterItemPayload::Subscription subscription); bool containsJID(const JID& jid); void removeContact(const JID& jid); + RosterItemPayload::Subscription getSubscriptionStateForJID(const JID& jid); const String& getNameForJID(const JID& jid); const std::vector<String>& getGroupsForJID(const JID& jid); @@ -26,7 +35,8 @@ class XMPPRoster { boost::signal<void (const JID&, const String&, const std::vector<String>&)> onJIDUpdated; private: - std::map<JID, std::pair<String, std::vector<String> > > entries_; + //std::map<JID, std::pair<String, std::vector<String> > > entries_; + std::map<JID, XMPPRosterItem> entries_; }; } |