simplify Win32 loop

thanks to irwir !
see https://github.com/miniupnp/miniupnp/pull/362
This commit is contained in:
Thomas Bernard 2019-05-08 15:46:52 +02:00
parent c8566d6ebd
commit 9132003aa0
No known key found for this signature in database
GPG Key ID: 0FF11B67A5C0863C
1 changed files with 8 additions and 11 deletions

View File

@ -546,15 +546,14 @@ ssdpDiscoverDevices(const char * const deviceTypes[],
destAddr.sin_addr.s_addr = inet_addr("223.255.255.255"); destAddr.sin_addr.s_addr = inet_addr("223.255.255.255");
destAddr.sin_port = 0; destAddr.sin_port = 0;
if (GetBestInterfaceEx((struct sockaddr *)&destAddr, &ifbestidx) == NO_ERROR) { if (GetBestInterfaceEx((struct sockaddr *)&destAddr, &ifbestidx) == NO_ERROR) {
DWORD dwRetVal = 0; DWORD dwRetVal = NO_ERROR;
PIP_ADAPTER_ADDRESSES pAddresses = NULL; PIP_ADAPTER_ADDRESSES pAddresses = NULL;
ULONG outBufLen = 0; ULONG outBufLen = 15360;
ULONG Iterations = 0; int Iterations;
PIP_ADAPTER_ADDRESSES pCurrAddresses = NULL; PIP_ADAPTER_ADDRESSES pCurrAddresses = NULL;
PIP_ADAPTER_UNICAST_ADDRESS pUnicast = NULL; PIP_ADAPTER_UNICAST_ADDRESS pUnicast = NULL;
outBufLen = 15360; for (Iterations = 0; Iterations < 3; Iterations++) {
do {
pAddresses = (IP_ADAPTER_ADDRESSES *) HeapAlloc(GetProcessHeap(), 0, outBufLen); pAddresses = (IP_ADAPTER_ADDRESSES *) HeapAlloc(GetProcessHeap(), 0, outBufLen);
if (pAddresses == NULL) { if (pAddresses == NULL) {
break; break;
@ -562,14 +561,12 @@ ssdpDiscoverDevices(const char * const deviceTypes[],
dwRetVal = GetAdaptersAddresses(AF_INET, GAA_FLAG_INCLUDE_PREFIX, NULL, pAddresses, &outBufLen); dwRetVal = GetAdaptersAddresses(AF_INET, GAA_FLAG_INCLUDE_PREFIX, NULL, pAddresses, &outBufLen);
if (dwRetVal == ERROR_BUFFER_OVERFLOW) { if (dwRetVal != ERROR_BUFFER_OVERFLOW) {
HeapFree(GetProcessHeap(), 0, pAddresses);
pAddresses = NULL;
} else {
break; break;
} }
Iterations++; HeapFree(GetProcessHeap(), 0, pAddresses);
} while ((dwRetVal == ERROR_BUFFER_OVERFLOW) && (Iterations < 3)); pAddresses = NULL;
}
if (dwRetVal == NO_ERROR) { if (dwRetVal == NO_ERROR) {
pCurrAddresses = pAddresses; pCurrAddresses = pAddresses;