aboutsummaryrefslogtreecommitdiff
path: root/lib/asyn-thread.c
diff options
context:
space:
mode:
authorChristian Hägele <haegele@teamviewer.com>2011-08-06 15:21:42 +0200
committerDaniel Stenberg <daniel@haxx.se>2011-08-06 15:21:42 +0200
commit704dc1844073fbd775cc67f0abe8892ef0f8c340 (patch)
tree66a769b844c2a2f2fdc89ee1960a2e111ecf952f /lib/asyn-thread.c
parentb0f18c4beb51cc0e3962935ade63358aae408ea1 (diff)
asyn-thread: check for dotted addresses before thread starts
Diffstat (limited to 'lib/asyn-thread.c')
-rw-r--r--lib/asyn-thread.c18
1 files changed, 16 insertions, 2 deletions
diff --git a/lib/asyn-thread.c b/lib/asyn-thread.c
index d2a6dde49..38cde5df7 100644
--- a/lib/asyn-thread.c
+++ b/lib/asyn-thread.c
@@ -626,14 +626,28 @@ Curl_addrinfo *Curl_resolver_getaddrinfo(struct connectdata *conn,
int *waitp)
{
struct addrinfo hints;
+ struct in_addr in;
Curl_addrinfo *res;
int error;
char sbuf[NI_MAXSERV];
int pf = PF_INET;
+#ifdef CURLRES_IPV6
+ struct in6_addr in6;
+#endif /* CURLRES_IPV6 */
*waitp = 0; /* default to synchronous response */
-#ifndef CURLRES_IPV4
+ /* First check if this is an IPv4 address string */
+ if(Curl_inet_pton(AF_INET, hostname, &in) > 0)
+ /* This is a dotted IP address 123.123.123.123-style */
+ return Curl_ip2addr(AF_INET, &in, hostname, port);
+
+#ifdef CURLRES_IPV6
+ /* check if this is an IPv6 address string */
+ if(Curl_inet_pton (AF_INET6, hostname, &in6) > 0)
+ /* This is an IPv6 address literal */
+ return Curl_ip2addr(AF_INET6, &in6, hostname, port);
+
/*
* Check if a limited name resolve has been requested.
*/
@@ -653,7 +667,7 @@ Curl_addrinfo *Curl_resolver_getaddrinfo(struct connectdata *conn,
/* the stack seems to be a non-ipv6 one */
pf = PF_INET;
-#endif /* !CURLRES_IPV4 */
+#endif /* CURLRES_IPV6 */
memset(&hints, 0, sizeof(hints));
hints.ai_family = pf;