diff options
author | George Hazan <ghazan@miranda.im> | 2018-07-09 22:28:27 +0300 |
---|---|---|
committer | George Hazan <ghazan@miranda.im> | 2018-07-09 22:28:27 +0300 |
commit | 6279b5f012a3b3d5734c9cc67c7a307cb0fd8eef (patch) | |
tree | 7b1e2ce0fd75fe4559b914aa52c2b3a40d54f60f /protocols/IcqOscarJ | |
parent | e9b6fb67ea86cf2e817cc846988dc736b3a6e216 (diff) |
fixes #920 (Crash when receiving file via ICQ)
Diffstat (limited to 'protocols/IcqOscarJ')
-rw-r--r-- | protocols/IcqOscarJ/src/icq_proto.h | 2 | ||||
-rw-r--r-- | protocols/IcqOscarJ/src/oscar_filetransfer.cpp | 34 |
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);
|