diff options
Diffstat (limited to 'protocols/SkypeWeb/src/skype_contacts.cpp')
-rw-r--r-- | protocols/SkypeWeb/src/skype_contacts.cpp | 26 |
1 files changed, 4 insertions, 22 deletions
diff --git a/protocols/SkypeWeb/src/skype_contacts.cpp b/protocols/SkypeWeb/src/skype_contacts.cpp index e4a46cd0e3..c33e1c5dca 100644 --- a/protocols/SkypeWeb/src/skype_contacts.cpp +++ b/protocols/SkypeWeb/src/skype_contacts.cpp @@ -43,23 +43,11 @@ MCONTACT CSkypeProto::GetContactFromAuthEvent(MEVENT hEvent) MCONTACT CSkypeProto::GetContact(const char *skypename)
{
- std::map<std::string, MCONTACT>::iterator it = contactMap.find(skypename);
- if (it != contactMap.end())
- return it->second;
-
MCONTACT hContact = NULL;
- if (contactMap.empty())
- MCONTACT hContact = db_find_first(m_szModuleName);
- else
- {
- hContact = db_find_next(lastMapContact, m_szModuleName);
- }
- for (; hContact; hContact = db_find_next(hContact, m_szModuleName))
+ for (hContact = db_find_first(m_szModuleName); hContact; hContact = db_find_next(hContact, m_szModuleName))
{
- std::string cSkypename = ptrA(getStringA(hContact, SKYPE_SETTINGS_ID));
- if (!contactMap.count(cSkypename))
- contactMap[cSkypename] = lastMapContact = hContact;
- if (mir_strcmpi(skypename, cSkypename.c_str()) == 0)
+ ptrA cSkypename(getStringA(hContact, SKYPE_SETTINGS_ID));
+ if (mir_strcmpi(skypename, cSkypename) == 0)
break;
}
return hContact;
@@ -68,13 +56,11 @@ MCONTACT CSkypeProto::GetContact(const char *skypename) MCONTACT CSkypeProto::AddContact(const char *skypename, bool isTemporary)
{
MCONTACT hContact = GetContact(skypename);
- if (hContact == NULL)
+ if (!hContact)
{
hContact = (MCONTACT)CallService(MS_DB_CONTACT_ADD, 0, 0);
CallService(MS_PROTO_ADDTOCONTACT, hContact, (LPARAM)m_szModuleName);
- contactMap[skypename] = lastMapContact = hContact;
-
setString(hContact, SKYPE_SETTINGS_ID, skypename);
DBVARIANT dbv;
@@ -261,9 +247,5 @@ INT_PTR CSkypeProto::OnGrantAuth(WPARAM hContact, LPARAM) int CSkypeProto::OnContactDeleted(MCONTACT hContact, LPARAM)
{
- /*ptrA skypename(getStringA(hContact, SKYPE_SETTINGS_ID));
- std::map<std::string, MCONTACT>::iterator it = contactMap.find((char*)skypename);
- if (it != contactMap.end())
- contactMap.erase(it);*/
return 0;
}
\ No newline at end of file |