ws2_32: Handle IPv6 in WSAStringToAddress.
diff --git a/configure b/configure
index 7e2549a..3f1ff43 100755
--- a/configure
+++ b/configure
@@ -15828,6 +15828,7 @@
 
 
 
+
 for ac_func in \
 	_pclose \
 	_popen \
@@ -15857,6 +15858,7 @@
 	gettid \
 	gettimeofday \
 	getuid \
+	inet_pton \
 	kqueue \
 	lstat \
 	memmove \
diff --git a/configure.ac b/configure.ac
index f499a70..b262128 100644
--- a/configure.ac
+++ b/configure.ac
@@ -1151,6 +1151,7 @@
 	gettid \
 	gettimeofday \
 	getuid \
+	inet_pton \
 	kqueue \
 	lstat \
 	memmove \
diff --git a/dlls/ws2_32/socket.c b/dlls/ws2_32/socket.c
index 90fa9b0..b3f1bae 100644
--- a/dlls/ws2_32/socket.c
+++ b/dlls/ws2_32/socket.c
@@ -4457,7 +4457,7 @@
 
     switch(AddressFamily)
     {
-    case AF_INET:
+    case WS_AF_INET:
     {
         struct in_addr inetaddr;
 
@@ -4494,8 +4494,9 @@
         break;
 
     }
-    case AF_INET6:
+    case WS_AF_INET6:
     {
+        struct in6_addr inetaddr;
         /* If lpAddressLength is too small, tell caller the size we need */
         if (*lpAddressLength < sizeof(SOCKADDR_IN6))
         {
@@ -4503,8 +4504,38 @@
             res = WSAEFAULT;
             break;
         }
-        FIXME("We don't support IPv6 yet.\n");
-        res = WSAEINVAL;
+#ifdef HAVE_INET_PTON
+        memset(lpAddress, 0, sizeof(SOCKADDR_IN6));
+
+        ((LPSOCKADDR_IN6)lpAddress)->sin6_family = WS_AF_INET6;
+
+        /* This one is a bit tricky. An IPv6 address contains colons, so the
+         * check from IPv4 doesn't work like that. However, IPv6 addresses that
+         * contain a port are written with braces like [fd12:3456:7890::1]:12345
+         * so what we will do is to look for ']', check if the next char is a
+         * colon, and if it is, parse the port as in IPv4. */
+
+        ptrPort = strchr(workBuffer, ']');
+        if(ptrPort && *(++ptrPort) == ':')
+        {
+            ((LPSOCKADDR_IN6)lpAddress)->sin6_port = (WS_u_short)atoi(ptrPort+1);
+            *ptrPort = '\0';
+        }
+        else
+        {
+            ((LPSOCKADDR_IN6)lpAddress)->sin6_port = 0;
+        }
+
+        if(inet_pton(AF_INET6, workBuffer, &inetaddr) > 0)
+        {
+            memcpy(&((LPSOCKADDR_IN6)lpAddress)->sin6_addr, &inetaddr,
+                    sizeof(struct in6_addr));
+            res = 0;
+        }
+        else
+#endif /* HAVE_INET_PTON */
+            res = WSAEINVAL;
+
         break;
     }
     default:
diff --git a/include/config.h.in b/include/config.h.in
index 331e5cc..09d133c 100644
--- a/include/config.h.in
+++ b/include/config.h.in
@@ -240,6 +240,9 @@
 /* Define to 1 if you have the `inet_network' function. */
 #undef HAVE_INET_NETWORK
 
+/* Define to 1 if you have the `inet_pton' function. */
+#undef HAVE_INET_PTON
+
 /* Define to 1 if you have the <inttypes.h> header file. */
 #undef HAVE_INTTYPES_H