mirror of
https://github.com/reactos/reactos.git
synced 2025-01-01 12:04:51 +00:00
Fixed case of zero DNS servers specified in the registry.
svn path=/trunk/; revision=8056
This commit is contained in:
parent
b58dac7496
commit
022e7cfde7
1 changed files with 24 additions and 8 deletions
|
@ -534,31 +534,43 @@ GetNetworkParams(PFIXED_INFO pFixedInfo, PULONG pOutBufLen)
|
||||||
/* Now we have the name servers, place the first one in the struct,
|
/* Now we have the name servers, place the first one in the struct,
|
||||||
and follow it with the rest */
|
and follow it with the rest */
|
||||||
if (!PrivateNSEnum.NumServers)
|
if (!PrivateNSEnum.NumServers)
|
||||||
RtlZeroMemory( &pFixedInfo->DnsServerList, sizeof(IP_ADDR_STRING) );
|
RtlZeroMemory( &pFixedInfo->DnsServerList,
|
||||||
|
sizeof(pFixedInfo->DnsServerList) );
|
||||||
else
|
else
|
||||||
memcpy( &pFixedInfo->DnsServerList, &PrivateNSEnum.AddrString[0],
|
memcpy( &pFixedInfo->DnsServerList, &PrivateNSEnum.AddrString[0],
|
||||||
sizeof(PrivateNSEnum.AddrString[0]) );
|
sizeof(PrivateNSEnum.AddrString[0]) );
|
||||||
|
|
||||||
|
if (PrivateNSEnum.NumServers > 1) {
|
||||||
pFixedInfo->CurrentDnsServer = &pFixedInfo->DnsServerList;
|
pFixedInfo->CurrentDnsServer = &pFixedInfo->DnsServerList;
|
||||||
if (PrivateNSEnum.NumServers > 1)
|
|
||||||
memcpy( &AddressAfterFixedInfo[0],
|
memcpy( &AddressAfterFixedInfo[0],
|
||||||
&PrivateNSEnum.AddrString[1],
|
&PrivateNSEnum.AddrString[1],
|
||||||
sizeof(IP_ADDR_STRING) * (PrivateNSEnum.NumServers - 1) );
|
sizeof(IP_ADDR_STRING) * (PrivateNSEnum.NumServers - 1) );
|
||||||
else
|
} else if (PrivateNSEnum.NumServers == 0) {
|
||||||
pFixedInfo->CurrentDnsServer->Next = 0;
|
pFixedInfo->CurrentDnsServer = &pFixedInfo->DnsServerList;
|
||||||
|
} else {
|
||||||
|
pFixedInfo->CurrentDnsServer = 0;
|
||||||
|
}
|
||||||
|
|
||||||
for( CurrentServer = 0;
|
for( CurrentServer = 0;
|
||||||
|
PrivateNSEnum.NumServers &&
|
||||||
CurrentServer < PrivateNSEnum.NumServers - 1;
|
CurrentServer < PrivateNSEnum.NumServers - 1;
|
||||||
CurrentServer++ ) {
|
CurrentServer++ ) {
|
||||||
pFixedInfo->CurrentDnsServer->Next = &AddressAfterFixedInfo[CurrentServer];
|
pFixedInfo->CurrentDnsServer->Next = &AddressAfterFixedInfo[CurrentServer];
|
||||||
pFixedInfo->CurrentDnsServer = &AddressAfterFixedInfo[CurrentServer];
|
pFixedInfo->CurrentDnsServer = &AddressAfterFixedInfo[CurrentServer];
|
||||||
pFixedInfo->CurrentDnsServer->Next = 0;
|
pFixedInfo->CurrentDnsServer->Next = 0;
|
||||||
}
|
}
|
||||||
/* For now, set the first server as the current server */
|
|
||||||
|
/* For now, set the first server as the current server, if there are any */
|
||||||
|
if( PrivateNSEnum.NumServers ) {
|
||||||
pFixedInfo->CurrentDnsServer = &pFixedInfo->DnsServerList;
|
pFixedInfo->CurrentDnsServer = &pFixedInfo->DnsServerList;
|
||||||
|
}
|
||||||
|
|
||||||
free(PrivateNSEnum.AddrString);
|
free(PrivateNSEnum.AddrString);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
WSH_DbgPrint( MIN_TRACE,
|
||||||
|
("Open Tcpip parameters key: error %08x\n", errCode ));
|
||||||
result = ERROR_NO_DATA; // No adapter information exists for the local computer
|
result = ERROR_NO_DATA; // No adapter information exists for the local computer
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -587,7 +599,11 @@ GetNetworkParams(PFIXED_INFO pFixedInfo, PULONG pOutBufLen)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
WSH_DbgPrint(MIN_TRACE,
|
||||||
|
("iphlpapi: Ignoring lack of netbios data for now.\n"));
|
||||||
|
#if 0
|
||||||
result = ERROR_NO_DATA; // No adapter information exists for the local computer
|
result = ERROR_NO_DATA; // No adapter information exists for the local computer
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
|
|
Loading…
Reference in a new issue