summaryrefslogtreecommitdiff
path: root/protocols/IcqOscarJ/src/utilities.cpp
diff options
context:
space:
mode:
authorGeorge Hazan <george.hazan@gmail.com>2016-05-13 20:27:01 +0000
committerGeorge Hazan <george.hazan@gmail.com>2016-05-13 20:27:01 +0000
commit690f3c5828685ffc3c2a11d8d68e4c0b1cf5f0ba (patch)
tree6fe6df105c8ffcefb5e3c0bfe59b14bfa2d1acbe /protocols/IcqOscarJ/src/utilities.cpp
parent37c98eaad76b7f1bf86c75fe2c32cf6aa11f7c6f (diff)
major memory leak in ICQ cookie module
git-svn-id: http://svn.miranda-ng.org/main/trunk@16829 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
Diffstat (limited to 'protocols/IcqOscarJ/src/utilities.cpp')
-rw-r--r--protocols/IcqOscarJ/src/utilities.cpp42
1 files changed, 15 insertions, 27 deletions
diff --git a/protocols/IcqOscarJ/src/utilities.cpp b/protocols/IcqOscarJ/src/utilities.cpp
index 6ad5193126..26ffc7ed66 100644
--- a/protocols/IcqOscarJ/src/utilities.cpp
+++ b/protocols/IcqOscarJ/src/utilities.cpp
@@ -370,18 +370,17 @@ void CIcqProto::InitContactsCache()
void CIcqProto::UninitContactsCache(void)
{
- { mir_cslock l(contactsCacheMutex);
-
- // cleanup the cache
- for (int i = 0; i < contactsCache.getCount(); i++) {
- icq_contacts_cache *cache_item = contactsCache[i];
+ mir_cslock l(contactsCacheMutex);
- SAFE_FREE((void**)&cache_item->szUid);
- SAFE_FREE((void**)&cache_item);
- }
+ // cleanup the cache
+ for (int i = 0; i < contactsCache.getCount(); i++) {
+ icq_contacts_cache *cache_item = contactsCache[i];
- contactsCache.destroy();
+ SAFE_FREE((void**)&cache_item->szUid);
+ SAFE_FREE((void**)&cache_item);
}
+
+ contactsCache.destroy();
}
@@ -419,7 +418,8 @@ MCONTACT CIcqProto::HandleFromCacheByUid(DWORD dwUin, const char *szUid)
MCONTACT CIcqProto::HContactFromUIN(DWORD dwUin, int *Added)
{
- if (Added) *Added = 0;
+ if (Added)
+ *Added = 0;
MCONTACT hContact = HandleFromCacheByUid(dwUin, NULL);
if (hContact)
@@ -438,7 +438,7 @@ MCONTACT CIcqProto::HContactFromUIN(DWORD dwUin, int *Added)
hContact = db_find_next(hContact, m_szModuleName);
}
- //not present: add
+ // not present: add
if (Added) {
debugLogA("Attempt to create ICQ contact %u", dwUin);
@@ -486,13 +486,15 @@ MCONTACT CIcqProto::HContactFromUID(DWORD dwUin, const char *szUid, int *Added)
if (dwUin)
return HContactFromUIN(dwUin, Added);
- if (Added) *Added = 0;
+ if (Added)
+ *Added = 0;
if (!m_bAimEnabled)
return INVALID_CONTACT_ID;
MCONTACT hContact = HandleFromCacheByUid(dwUin, szUid);
- if (hContact) return hContact;
+ if (hContact)
+ return hContact;
hContact = db_find_first(m_szModuleName);
while (hContact) {
@@ -529,7 +531,6 @@ MCONTACT CIcqProto::HContactFromUID(DWORD dwUin, const char *szUid, int *Added)
}
AddToContactsCache(hContact, 0, szUid);
*Added = 1;
-
return hContact;
}
@@ -1317,16 +1318,6 @@ bool CIcqProto::validateStatusMessageRequest(MCONTACT hContact, WORD byMessageTy
return true;
}
-
-void __fastcall SAFE_DELETE(MZeroedObject **p)
-{
- if (*p) {
- delete *p;
- *p = NULL;
- }
-}
-
-
void __fastcall SAFE_FREE(void** p)
{
if (*p) {
@@ -1335,7 +1326,6 @@ void __fastcall SAFE_FREE(void** p)
}
}
-
void* __fastcall SAFE_MALLOC(size_t size)
{
void* p = NULL;
@@ -1348,7 +1338,6 @@ void* __fastcall SAFE_MALLOC(size_t size)
return p;
}
-
void* __fastcall SAFE_REALLOC(void* p, size_t size)
{
if (p)
@@ -1357,7 +1346,6 @@ void* __fastcall SAFE_REALLOC(void* p, size_t size)
return SAFE_MALLOC(size);
}
-
DWORD ICQWaitForSingleObject(HANDLE hObject, DWORD dwMilliseconds, int bWaitAlways)
{
DWORD dwResult;