Commit 18a02d8f authored by Bruno Jesus's avatar Bruno Jesus Committed by Alexandre Julliard

ws2_32: Try harder to get the host name address in getaddrinfo.

parent 614afcef
...@@ -5996,7 +5996,7 @@ int WINAPI WS_getaddrinfo(LPCSTR nodename, LPCSTR servname, const struct WS_addr ...@@ -5996,7 +5996,7 @@ int WINAPI WS_getaddrinfo(LPCSTR nodename, LPCSTR servname, const struct WS_addr
struct addrinfo *unixaires = NULL; struct addrinfo *unixaires = NULL;
int result; int result;
struct addrinfo unixhints, *punixhints = NULL; struct addrinfo unixhints, *punixhints = NULL;
char *hostname = NULL; char *hostname;
const char *node; const char *node;
*res = NULL; *res = NULL;
...@@ -6006,13 +6006,13 @@ int WINAPI WS_getaddrinfo(LPCSTR nodename, LPCSTR servname, const struct WS_addr ...@@ -6006,13 +6006,13 @@ int WINAPI WS_getaddrinfo(LPCSTR nodename, LPCSTR servname, const struct WS_addr
return WSAHOST_NOT_FOUND; return WSAHOST_NOT_FOUND;
} }
hostname = get_hostname();
if (!hostname) return WSA_NOT_ENOUGH_MEMORY;
if (!nodename) if (!nodename)
node = NULL; node = NULL;
else if (!nodename[0]) else if (!nodename[0])
{ node = hostname;
node = hostname = get_hostname();
if (!node) return WSA_NOT_ENOUGH_MEMORY;
}
else else
node = nodename; node = nodename;
...@@ -6056,6 +6056,14 @@ int WINAPI WS_getaddrinfo(LPCSTR nodename, LPCSTR servname, const struct WS_addr ...@@ -6056,6 +6056,14 @@ int WINAPI WS_getaddrinfo(LPCSTR nodename, LPCSTR servname, const struct WS_addr
/* getaddrinfo(3) is thread safe, no need to wrap in CS */ /* getaddrinfo(3) is thread safe, no need to wrap in CS */
result = getaddrinfo(node, servname, punixhints, &unixaires); result = getaddrinfo(node, servname, punixhints, &unixaires);
if (result && !strcmp(hostname, node))
{
/* If it didn't work it means the host name IP is not in /etc/hosts, try again
* by sending a NULL host and avoid sending a NULL servname too because that
* is invalid */
ERR_(winediag)("Failed to resolve your host name IP\n");
result = getaddrinfo(NULL, servname ? servname : "0", punixhints, &unixaires);
}
TRACE("%s, %s %p -> %p %d\n", debugstr_a(nodename), debugstr_a(servname), hints, res, result); TRACE("%s, %s %p -> %p %d\n", debugstr_a(nodename), debugstr_a(servname), hints, res, result);
HeapFree(GetProcessHeap(), 0, hostname); HeapFree(GetProcessHeap(), 0, hostname);
......
...@@ -6313,6 +6313,8 @@ static void test_GetAddrInfoW(void) ...@@ -6313,6 +6313,8 @@ static void test_GetAddrInfoW(void)
static const WCHAR zero[] = {'0',0}; static const WCHAR zero[] = {'0',0};
int i, ret; int i, ret;
ADDRINFOW *result, *result2, *p, hint; ADDRINFOW *result, *result2, *p, hint;
WCHAR name[256];
DWORD size = sizeof(name);
if (!pGetAddrInfoW || !pFreeAddrInfoW) if (!pGetAddrInfoW || !pFreeAddrInfoW)
{ {
...@@ -6320,6 +6322,8 @@ static void test_GetAddrInfoW(void) ...@@ -6320,6 +6322,8 @@ static void test_GetAddrInfoW(void)
return; return;
} }
memset(&hint, 0, sizeof(ADDRINFOW)); memset(&hint, 0, sizeof(ADDRINFOW));
name[0] = 0;
GetComputerNameExW( ComputerNamePhysicalDnsHostname, name, &size );
result = (ADDRINFOW *)0xdeadbeef; result = (ADDRINFOW *)0xdeadbeef;
WSASetLastError(0xdeadbeef); WSASetLastError(0xdeadbeef);
...@@ -6395,6 +6399,30 @@ static void test_GetAddrInfoW(void) ...@@ -6395,6 +6399,30 @@ static void test_GetAddrInfoW(void)
ok(WSAGetLastError() == 0, "expected 0, got %d\n", WSAGetLastError()); ok(WSAGetLastError() == 0, "expected 0, got %d\n", WSAGetLastError());
pFreeAddrInfoW(result); pFreeAddrInfoW(result);
/* try to get information from the computer name, result is the same
* as if requesting with an empty host name. */
ret = pGetAddrInfoW(name, NULL, NULL, &result);
ok(!ret, "GetAddrInfoW failed with %d\n", WSAGetLastError());
ok(result != NULL, "GetAddrInfoW failed\n");
ret = pGetAddrInfoW(empty, NULL, NULL, &result2);
ok(!ret, "GetAddrInfoW failed with %d\n", WSAGetLastError());
ok(result != NULL, "GetAddrInfoW failed\n");
compare_addrinfow(result, result2);
pFreeAddrInfoW(result);
pFreeAddrInfoW(result2);
ret = pGetAddrInfoW(name, empty, NULL, &result);
ok(!ret, "GetAddrInfoW failed with %d\n", WSAGetLastError());
ok(result != NULL, "GetAddrInfoW failed\n");
ret = pGetAddrInfoW(empty, empty, NULL, &result2);
ok(!ret, "GetAddrInfoW failed with %d\n", WSAGetLastError());
ok(result != NULL, "GetAddrInfoW failed\n");
compare_addrinfow(result, result2);
pFreeAddrInfoW(result);
pFreeAddrInfoW(result2);
result = (ADDRINFOW *)0xdeadbeef; result = (ADDRINFOW *)0xdeadbeef;
WSASetLastError(0xdeadbeef); WSASetLastError(0xdeadbeef);
ret = pGetAddrInfoW(NULL, NULL, NULL, &result); ret = pGetAddrInfoW(NULL, NULL, NULL, &result);
...@@ -6475,6 +6503,8 @@ static void test_getaddrinfo(void) ...@@ -6475,6 +6503,8 @@ static void test_getaddrinfo(void)
{ {
int i, ret; int i, ret;
ADDRINFOA *result, *result2, *p, hint; ADDRINFOA *result, *result2, *p, hint;
CHAR name[256];
DWORD size = sizeof(name);
if (!pgetaddrinfo || !pfreeaddrinfo) if (!pgetaddrinfo || !pfreeaddrinfo)
{ {
...@@ -6482,6 +6512,7 @@ static void test_getaddrinfo(void) ...@@ -6482,6 +6512,7 @@ static void test_getaddrinfo(void)
return; return;
} }
memset(&hint, 0, sizeof(ADDRINFOA)); memset(&hint, 0, sizeof(ADDRINFOA));
GetComputerNameExA( ComputerNamePhysicalDnsHostname, name, &size );
result = (ADDRINFOA *)0xdeadbeef; result = (ADDRINFOA *)0xdeadbeef;
WSASetLastError(0xdeadbeef); WSASetLastError(0xdeadbeef);
...@@ -6558,6 +6589,30 @@ static void test_getaddrinfo(void) ...@@ -6558,6 +6589,30 @@ static void test_getaddrinfo(void)
ok(WSAGetLastError() == 0, "expected 0, got %d\n", WSAGetLastError()); ok(WSAGetLastError() == 0, "expected 0, got %d\n", WSAGetLastError());
pfreeaddrinfo(result); pfreeaddrinfo(result);
/* try to get information from the computer name, result is the same
* as if requesting with an empty host name. */
ret = pgetaddrinfo(name, NULL, NULL, &result);
ok(!ret, "getaddrinfo failed with %d\n", WSAGetLastError());
ok(result != NULL, "GetAddrInfoW failed\n");
ret = pgetaddrinfo("", NULL, NULL, &result2);
ok(!ret, "getaddrinfo failed with %d\n", WSAGetLastError());
ok(result != NULL, "GetAddrInfoW failed\n");
compare_addrinfo(result, result2);
pfreeaddrinfo(result);
pfreeaddrinfo(result2);
ret = pgetaddrinfo(name, "", NULL, &result);
ok(!ret, "getaddrinfo failed with %d\n", WSAGetLastError());
ok(result != NULL, "GetAddrInfoW failed\n");
ret = pgetaddrinfo("", "", NULL, &result2);
ok(!ret, "getaddrinfo failed with %d\n", WSAGetLastError());
ok(result != NULL, "GetAddrInfoW failed\n");
compare_addrinfo(result, result2);
pfreeaddrinfo(result);
pfreeaddrinfo(result2);
result = (ADDRINFOA *)0xdeadbeef; result = (ADDRINFOA *)0xdeadbeef;
WSASetLastError(0xdeadbeef); WSASetLastError(0xdeadbeef);
ret = pgetaddrinfo("nxdomain.codeweavers.com", NULL, NULL, &result); ret = pgetaddrinfo("nxdomain.codeweavers.com", NULL, NULL, &result);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment