summaryrefslogtreecommitdiff
path: root/protocols/IcqOscarJ
diff options
context:
space:
mode:
authorGeorge Hazan <ghazan@miranda.im>2018-07-09 22:28:27 +0300
committerGeorge Hazan <ghazan@miranda.im>2018-07-09 22:28:27 +0300
commit6279b5f012a3b3d5734c9cc67c7a307cb0fd8eef (patch)
tree7b1e2ce0fd75fe4559b914aa52c2b3a40d54f60f /protocols/IcqOscarJ
parente9b6fb67ea86cf2e817cc846988dc736b3a6e216 (diff)
fixes #920 (Crash when receiving file via ICQ)
Diffstat (limited to 'protocols/IcqOscarJ')
-rw-r--r--protocols/IcqOscarJ/src/icq_proto.h2
-rw-r--r--protocols/IcqOscarJ/src/oscar_filetransfer.cpp34
2 files changed, 20 insertions, 16 deletions
diff --git a/protocols/IcqOscarJ/src/icq_proto.h b/protocols/IcqOscarJ/src/icq_proto.h
index 03606edf51..ca775a081b 100644
--- a/protocols/IcqOscarJ/src/icq_proto.h
+++ b/protocols/IcqOscarJ/src/icq_proto.h
@@ -825,7 +825,7 @@ struct CIcqProto : public PROTO<CIcqProto>
void proxy_sendJoinTunnel(oscar_connection *oc, WORD wPort);
//----| stdpackets.cpp |--------------------------------------------------------------
- void __cdecl oft_connectionThread(struct oscarthreadstartinfo *otsi);
+ void __cdecl oft_connectionThread(void *otsi);
int oft_handlePackets(oscar_connection *oc, BYTE *buf, size_t len);
int oft_handleFileData(oscar_connection *oc, BYTE *buf, size_t len);
diff --git a/protocols/IcqOscarJ/src/oscar_filetransfer.cpp b/protocols/IcqOscarJ/src/oscar_filetransfer.cpp
index 4c1d7cc317..ced8b22347 100644
--- a/protocols/IcqOscarJ/src/oscar_filetransfer.cpp
+++ b/protocols/IcqOscarJ/src/oscar_filetransfer.cpp
@@ -664,7 +664,7 @@ static void oft_newConnectionReceived(HNETLIBCONN hNewConnection, DWORD dwRemote
otsi->listener = listener;
// Start a new thread for the incomming connection
- listener->ppro->ForkThread((CIcqProto::MyThreadFunc)&CIcqProto::oft_connectionThread, otsi);
+ listener->ppro->ForkThread(&CIcqProto::oft_connectionThread, otsi);
}
static char* oftGetFileContainer(oscar_filetransfer* oft, const char** files, int iFile)
@@ -1073,23 +1073,30 @@ int CIcqProto::CreateOscarProxyConnection(oscar_connection *oc)
return 1; // Success
}
-void __cdecl CIcqProto::oft_connectionThread(oscarthreadstartinfo *otsi)
+void __cdecl CIcqProto::oft_connectionThread(void *param)
{
- oscar_connection oc = { 0 };
- oscar_listener *source;
-
Thread_SetName("ICQ: oft_connectionThread");
- oc.hContact = otsi->hContact;
- oc.hConnection = otsi->hConnection;
- oc.type = otsi->type;
- oc.incoming = otsi->incoming;
- oc.ft = otsi->ft;
- source = otsi->listener;
+ DWORD dwRemoteIP;
+ oscar_connection oc = {};
+ oscar_listener *source;
+ {
+ oscarthreadstartinfo *otsi = (oscarthreadstartinfo*)param;
+ source = otsi->listener;
+ dwRemoteIP = otsi->dwRemoteIP;
+
+ oc.hContact = otsi->hContact;
+ oc.hConnection = otsi->hConnection;
+ oc.type = otsi->type;
+ oc.incoming = otsi->incoming;
+ oc.ft = otsi->ft;
+ SAFE_FREE((void**)&otsi);
+ }
+
if (oc.incoming) {
if (IsValidOscarTransfer(source->ft)) {
oc.ft = source->ft;
- oc.ft->dwRemoteExternalIP = otsi->dwRemoteIP;
+ oc.ft->dwRemoteExternalIP = dwRemoteIP;
oc.hContact = oc.ft->hContact;
oc.ft->connection = &oc;
oc.status = OCS_CONNECTED;
@@ -1099,12 +1106,9 @@ void __cdecl CIcqProto::oft_connectionThread(oscarthreadstartinfo *otsi)
CloseOscarConnection(&oc);
ReleaseOscarListener(&source);
-
- SAFE_FREE((void**)&otsi);
return;
}
}
- SAFE_FREE((void**)&otsi);
if (oc.hContact) // Load contact information
getContactUid(oc.hContact, &oc.dwUin, &oc.szUid);