diff options
-rw-r--r-- | plugins/ProxySwitch/src/ip.cpp | 68 | ||||
-rw-r--r-- | plugins/ProxySwitch/src/main.cpp | 7 | ||||
-rw-r--r-- | plugins/ProxySwitch/src/proxy.cpp | 7 | ||||
-rw-r--r-- | plugins/ProxySwitch/src/stdafx.h | 21 |
4 files changed, 39 insertions, 64 deletions
diff --git a/plugins/ProxySwitch/src/ip.cpp b/plugins/ProxySwitch/src/ip.cpp index 8ed30c7664..3841ceb37f 100644 --- a/plugins/ProxySwitch/src/ip.cpp +++ b/plugins/ProxySwitch/src/ip.cpp @@ -11,7 +11,7 @@ wchar_t tempstr[MAX_SECONDLINE]; /* ################################################################################ */ -void IP_WatchDog(void *arg) +void IP_WatchDog(void*) { OVERLAPPED overlap; DWORD ret; @@ -158,12 +158,10 @@ int Create_NIF_List(NETWORK_INTERFACE_LIST *list) PIP_ADAPTER_INFO pAdapterInfo, pAdapt; PIP_ADDR_STRING pAddrStr; PIP_ADAPTER_ADDRESSES pAddresses, pAddr; - PNETWORK_INTERFACE nif; ULONG outBufLen; wchar_t *tmp_opt, *intf, *rest, *name; BOOL skip; DWORD out; - UCHAR idx; // prepare and load IP_ADAPTER_ADDRESSES outBufLen = 0; @@ -212,7 +210,7 @@ int Create_NIF_List(NETWORK_INTERFACE_LIST *list) // add a new interface into the list list->count++; list->item = (PNETWORK_INTERFACE)mir_realloc(list->item, list->count * sizeof(NETWORK_INTERFACE)); - nif = &(list->item[list->count - 1]); + PNETWORK_INTERFACE nif = &(list->item[list->count - 1]); ZeroMemory(nif, sizeof(NETWORK_INTERFACE)); // copy AdapterName @@ -272,7 +270,7 @@ int Create_NIF_List(NETWORK_INTERFACE_LIST *list) while (pAddrStr) { if (mir_strcmp("0.0.0.0", pAddrStr->IpAddress.String)) { nif->IPcount++; // count IP addresses - outBufLen += strlen(pAddrStr->IpAddress.String); // count length of IPstr + outBufLen += (ULONG)strlen(pAddrStr->IpAddress.String); // count length of IPstr } pAddrStr = pAddrStr->Next; if (pAddrStr) outBufLen += 2; // count length of IPstr (add ", ") @@ -304,11 +302,10 @@ int Create_NIF_List(NETWORK_INTERFACE_LIST *list) mir_free(pAddresses); mir_cslock lck(csConnection_List); - for (idx = 0; idx < Connection_List.count; idx++) { - nif = Find_NIF_IP(*list, Connection_List.item[idx].IP); - if (nif) { + for (auto &it : g_arConnections) { + PNETWORK_INTERFACE nif = Find_NIF_IP(*list, it->IP); + if (nif) nif->Bound = 1; - } } return 0; @@ -701,65 +698,44 @@ void Free_Range_List(IP_RANGE_LIST *list) } -int ManageConnections(WPARAM wParam, LPARAM lParam) +int ManageConnections(WPARAM wParam, LPARAM) { NETLIBCONNECTIONEVENTINFO *info = (NETLIBCONNECTIONEVENTINFO *)wParam; - int found; - UCHAR i; + ACTIVE_CONNECTION *pFound = nullptr; mir_cslock lck(csConnection_List); - found = -1; - for (i = 0; i < Connection_List.count; i++) { - if (Connection_List.item[i].IP == info->local.sin_addr.s_addr && Connection_List.item[i].Port == info->local.sin_port) { - found = i; + for (auto &it : g_arConnections) + if (it->IP == info->local.sin_addr.s_addr && it->Port == info->local.sin_port) { + pFound = it; break; } - } - if ((found >= 0 && info->connected) || (found == -1 && !info->connected)) { + + if ((pFound && info->connected) || (!pFound && !info->connected)) return 0; - } - if (found >= 0) { - Connection_List.count--; - for (i = found; i < Connection_List.count; i++) - memcpy(&(Connection_List.item[i]), &(Connection_List.item[i + 1]), sizeof(ACTIVE_CONNECTION)); - } - else { - if (Connection_List.count >= Connection_List._alloc) { - Connection_List._alloc += 10; - Connection_List.item = (PACTIVE_CONNECTION)mir_realloc(Connection_List.item, Connection_List._alloc * sizeof(ACTIVE_CONNECTION)); - } - Connection_List.item[Connection_List.count].IP = info->local.sin_addr.s_addr; - Connection_List.item[Connection_List.count].Port = info->local.sin_port; - Connection_List.count++; - } - SetEvent(hEventRebound); + if (!pFound) + g_arConnections.insert(new ACTIVE_CONNECTION(info->local.sin_addr.s_addr, info->local.sin_port)); + else + g_arConnections.remove(g_arConnections.indexOf(&pFound)); + SetEvent(hEventRebound); return 0; } void UnboundConnections(LONG *OldIP, LONG *NewIP) { - UCHAR i, j; LONG *IP; while (OldIP != NULL && *OldIP != 0) { IP = NewIP; while (IP != NULL && *IP != 0 && *IP != *OldIP) IP++; + if (IP == NULL || *IP != *OldIP) { mir_cslock lck(csConnection_List); - i = 0; - while (i < Connection_List.count) { - if (Connection_List.item[i].IP == (ULONG)*OldIP) { - Connection_List.count--; - for (j = i; j < Connection_List.count; j++) - memcpy(&(Connection_List.item[j]), &(Connection_List.item[j + 1]), sizeof(ACTIVE_CONNECTION)); - } - else { - i++; - } - } + for (auto &it : g_arConnections.rev_iter()) + if (it->IP == (ULONG)*OldIP) + g_arConnections.remove(g_arConnections.indexOf(&it)); } OldIP++; } diff --git a/plugins/ProxySwitch/src/main.cpp b/plugins/ProxySwitch/src/main.cpp index b83d2588a6..5721bfc1b2 100644 --- a/plugins/ProxySwitch/src/main.cpp +++ b/plugins/ProxySwitch/src/main.cpp @@ -29,10 +29,12 @@ CMPlugin::CMPlugin() : HGENMENU hEnableDisablePopupMenu = 0; +OBJLIST<ACTIVE_CONNECTION> g_arConnections(10, PtrKeySortT); +mir_cs csConnection_List; + NETWORK_INTERFACE_LIST NIF_List; mir_cs csNIF_List; -ACTIVE_CONNECTION_LIST Connection_List; -mir_cs csConnection_List; + HANDLE hEventRebound = NULL; wchar_t opt_useProxy[MAX_IPLIST_LENGTH]; @@ -251,7 +253,6 @@ int CMPlugin::Load() LoadSettings(); - ZeroMemory(&Connection_List, sizeof(Connection_List)); Create_NIF_List_Ex(&NIF_List); if (opt_ie || opt_miranda || opt_firefox) { diff --git a/plugins/ProxySwitch/src/proxy.cpp b/plugins/ProxySwitch/src/proxy.cpp index 5ab1c50dfb..bed73e9fb6 100644 --- a/plugins/ProxySwitch/src/proxy.cpp +++ b/plugins/ProxySwitch/src/proxy.cpp @@ -28,7 +28,7 @@ int Enum_Settings(const char *szSetting, LPARAM lParam) return 0; } -int Enum_Modules(const char *szModuleName, DWORD ofsModuleName, LPARAM lParam) +int Enum_Modules(const char *szModuleName, DWORD, LPARAM lParam) { //DBCONTACTENUMSETTINGS e; MCONTACT hContact = NULL; @@ -286,9 +286,8 @@ char Firefox_Installed(void) if (SHGetSpecialFolderPath(NULL, path, CSIDL_APPDATA, 0)) { mir_wstrcat(path, L"\\Mozilla\\Firefox\\Profiles"); - if (_wstat(path, &info) == 0 && info.st_mode & _S_IFDIR == _S_IFDIR) { + if (_wstat(path, &info) == 0 && (info.st_mode & _S_IFDIR) == _S_IFDIR) return 1; - } } return 0; } @@ -297,7 +296,7 @@ char Firefox_Installed(void) void Disconnect_All_Protocols(PPROTO_SETTINGS settings, int disconnect) { - int count, c, i, status; + int count = 0, c, i, status; PROTOCOLDESCRIPTOR **plist; Proto_EnumProtocols(&c, &plist); diff --git a/plugins/ProxySwitch/src/stdafx.h b/plugins/ProxySwitch/src/stdafx.h index 59ccea28cd..8e0de00058 100644 --- a/plugins/ProxySwitch/src/stdafx.h +++ b/plugins/ProxySwitch/src/stdafx.h @@ -68,23 +68,22 @@ typedef struct { } NETWORK_INTERFACE_LIST; // structure holding an information about local end of an active connections -typedef struct { - ULONG IP; - unsigned short Port; -} ACTIVE_CONNECTION, *PACTIVE_CONNECTION; +struct ACTIVE_CONNECTION +{ + ACTIVE_CONNECTION(ULONG _ip, unsigned short _port) : + IP(_ip), + Port(_port) + {} -// list of structures holding local end of active connections -typedef struct { - PACTIVE_CONNECTION item; - UCHAR count; - UCHAR _alloc; -} ACTIVE_CONNECTION_LIST; + ULONG IP; + unsigned short Port; +}; +extern OBJLIST<ACTIVE_CONNECTION> g_arConnections; /**** Global variables *********************************************************************/ extern NETWORK_INTERFACE_LIST NIF_List; -extern ACTIVE_CONNECTION_LIST Connection_List; extern mir_cs csNIF_List; extern mir_cs csConnection_List; extern HANDLE hEventRebound; |