simplify Win32 loop
thanks to irwir ! see https://github.com/miniupnp/miniupnp/pull/362
This commit is contained in:
parent
c8566d6ebd
commit
9132003aa0
|
@ -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;
|
||||||
|
|
Loading…
Reference in New Issue