Commit accf5ef5 authored by Owen Rudge's avatar Owen Rudge Committed by Alexandre Julliard

ws2_32: Extract IPv6 address from brackets in getaddrinfo.

parent f254aec4
...@@ -6557,7 +6557,7 @@ int WINAPI WS_getaddrinfo(LPCSTR nodename, LPCSTR servname, const struct WS_addr ...@@ -6557,7 +6557,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; char *hostname, *nodeV6 = NULL;
const char *node; const char *node;
*res = NULL; *res = NULL;
...@@ -6575,8 +6575,28 @@ int WINAPI WS_getaddrinfo(LPCSTR nodename, LPCSTR servname, const struct WS_addr ...@@ -6575,8 +6575,28 @@ int WINAPI WS_getaddrinfo(LPCSTR nodename, LPCSTR servname, const struct WS_addr
else if (!nodename[0]) else if (!nodename[0])
node = hostname; node = hostname;
else else
{
node = nodename; node = nodename;
/* Check for [ipv6] or [ipv6]:portnumber, which are supported by Windows */
if (!hints || hints->ai_family == WS_AF_UNSPEC || hints->ai_family == WS_AF_INET6)
{
char *close_bracket;
if (node[0] == '[' && (close_bracket = strchr(node + 1, ']')))
{
nodeV6 = HeapAlloc(GetProcessHeap(), 0, close_bracket - node);
if (!nodeV6)
{
HeapFree(GetProcessHeap(), 0, hostname);
return WSA_NOT_ENOUGH_MEMORY;
}
lstrcpynA(nodeV6, node + 1, close_bracket - node);
node = nodeV6;
}
}
}
/* servname tweak required by OSX and BSD kernels */ /* servname tweak required by OSX and BSD kernels */
if (servname && !servname[0]) servname = "0"; if (servname && !servname[0]) servname = "0";
...@@ -6598,6 +6618,7 @@ int WINAPI WS_getaddrinfo(LPCSTR nodename, LPCSTR servname, const struct WS_addr ...@@ -6598,6 +6618,7 @@ int WINAPI WS_getaddrinfo(LPCSTR nodename, LPCSTR servname, const struct WS_addr
{ {
SetLastError(WSAESOCKTNOSUPPORT); SetLastError(WSAESOCKTNOSUPPORT);
HeapFree(GetProcessHeap(), 0, hostname); HeapFree(GetProcessHeap(), 0, hostname);
HeapFree(GetProcessHeap(), 0, nodeV6);
return SOCKET_ERROR; return SOCKET_ERROR;
} }
...@@ -6630,6 +6651,7 @@ int WINAPI WS_getaddrinfo(LPCSTR nodename, LPCSTR servname, const struct WS_addr ...@@ -6630,6 +6651,7 @@ int WINAPI WS_getaddrinfo(LPCSTR nodename, LPCSTR servname, const struct WS_addr
} }
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);
HeapFree(GetProcessHeap(), 0, nodeV6);
if (!result) { if (!result) {
struct addrinfo *xuai = unixaires; struct addrinfo *xuai = unixaires;
......
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