diff options
author | George Hazan <george.hazan@gmail.com> | 2015-03-07 19:39:33 +0000 |
---|---|---|
committer | George Hazan <george.hazan@gmail.com> | 2015-03-07 19:39:33 +0000 |
commit | 8e91cc3b73d6c77c79781115fc1acbbb7fddfe32 (patch) | |
tree | d0afc2226cca8c60656eb0f89a3bf0788525d2aa /protocols/IcqOscarJ/src/icq_server.cpp | |
parent | 7ad29f87c6d2be2b8fd48c25c94a21b7a5db7b0d (diff) |
- old ugly borkred mutexes removed from ICQ, cause all threads work as expected for a long time;
- even older ugly linked list of avatars replaced with LIST<>;
- version bump
git-svn-id: http://svn.miranda-ng.org/main/trunk@12369 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
Diffstat (limited to 'protocols/IcqOscarJ/src/icq_server.cpp')
-rw-r--r-- | protocols/IcqOscarJ/src/icq_server.cpp | 40 |
1 files changed, 19 insertions, 21 deletions
diff --git a/protocols/IcqOscarJ/src/icq_server.cpp b/protocols/IcqOscarJ/src/icq_server.cpp index 5ea930f0b7..3bc7e459a3 100644 --- a/protocols/IcqOscarJ/src/icq_server.cpp +++ b/protocols/IcqOscarJ/src/icq_server.cpp @@ -96,7 +96,7 @@ void __cdecl CIcqProto::ServerThread(serverthread_start_info *infoParam) // Initialize rate limiting queues
{
- icq_lock l(m_ratesMutex);
+ mir_cslock l(m_ratesMutex);
m_ratesQueue_Request = new rates_queue(this, "request", RML_IDLE_30, RML_IDLE_50, 1);
m_ratesQueue_Response = new rates_queue(this, "response", RML_IDLE_10, RML_IDLE_30, -1);
}
@@ -196,7 +196,7 @@ void __cdecl CIcqProto::ServerThread(serverthread_start_info *infoParam) // release rates queues
{
- icq_lock l(m_ratesMutex);
+ mir_cslock l(m_ratesMutex);
delete m_ratesQueue_Request; m_ratesQueue_Request = NULL;
delete m_ratesQueue_Response; m_ratesQueue_Response = NULL;
delete m_rates; m_rates = NULL;
@@ -292,25 +292,26 @@ int CIcqProto::handleServerPackets(BYTE *buf, int len, serverthread_info *info) void CIcqProto::sendServPacket(icq_packet *pPacket)
{
// make sure to have the connection handle
- connectionHandleMutex->Enter();
+ mir_cslockfull l(connectionHandleMutex);
if (hServerConn) {
// This critsec makes sure that the sequence order doesn't get screwed up
- localSeqMutex->Enter();
+ int nSendResult;
+ {
+ mir_cslock slck(localSeqMutex);
- // :IMPORTANT:
- // The FLAP sequence must be a WORD. When it reaches 0xFFFF it should wrap to
- // 0x0000, otherwise we'll get kicked by server.
- wLocalSequence++;
+ // :IMPORTANT:
+ // The FLAP sequence must be a WORD. When it reaches 0xFFFF it should wrap to
+ // 0x0000, otherwise we'll get kicked by server.
+ wLocalSequence++;
- // Pack sequence number
- pPacket->pData[2] = ((wLocalSequence & 0xff00) >> 8);
- pPacket->pData[3] = (wLocalSequence & 0x00ff);
+ // Pack sequence number
+ pPacket->pData[2] = ((wLocalSequence & 0xff00) >> 8);
+ pPacket->pData[3] = (wLocalSequence & 0x00ff);
- int nSendResult = Netlib_Send(hServerConn, (const char *)pPacket->pData, pPacket->wLen, 0);
-
- localSeqMutex->Leave();
- connectionHandleMutex->Leave();
+ nSendResult = Netlib_Send(hServerConn, (const char *)pPacket->pData, pPacket->wLen, 0);
+ }
+ l.unlock();
// Send error
if (nSendResult == SOCKET_ERROR) {
@@ -320,14 +321,11 @@ void CIcqProto::sendServPacket(icq_packet *pPacket) icq_serverDisconnect();
}
else { // Rates management
- icq_lock l(m_ratesMutex);
+ mir_cslock l(m_ratesMutex);
m_rates->packetSent(pPacket);
}
}
- else {
- connectionHandleMutex->Leave();
- debugLogA("Error: Failed to send packet (no connection)");
- }
+ else debugLogA("Error: Failed to send packet (no connection)");
SAFE_FREE((void**)&pPacket->pData);
}
@@ -353,7 +351,7 @@ void CIcqProto::sendServPacketAsync(icq_packet *packet) int CIcqProto::IsServerOverRate(WORD wFamily, WORD wCommand, int nLevel)
{
- icq_lock l(m_ratesMutex);
+ mir_cslock l(m_ratesMutex);
if (m_rates) {
WORD wGroup = m_rates->getGroupFromSNAC(wFamily, wCommand);
|