From: Michael Stapelberg Date: Mon, 3 Jan 2011 14:00:42 +0000 (+0100) Subject: Cache the result of the DNS query also if there is no IPv6 connectivity (Thanks dothe... X-Git-Tag: 2.3~25 X-Git-Url: https://git.sur5r.net/?a=commitdiff_plain;h=39feebea4d3a4cd05ea264202f8523202190f43f;p=i3%2Fi3status Cache the result of the DNS query also if there is no IPv6 connectivity (Thanks dothebart) --- diff --git a/src/print_ipv6_addr.c b/src/print_ipv6_addr.c index b370011..e96c0d3 100644 --- a/src/print_ipv6_addr.c +++ b/src/print_ipv6_addr.c @@ -70,6 +70,7 @@ static char *get_ipv6_addr() { memset(&hints, 0, sizeof(struct addrinfo)); hints.ai_family = AF_INET6; + hints.ai_socktype = SOCK_DGRAM; /* We resolve the K root server to get a public IPv6 address. You can * replace this with any other host which has an AAAA record, but the @@ -83,7 +84,11 @@ static char *get_ipv6_addr() { for (resp = result; resp != NULL; resp = resp->ai_next) { char *addr_string = get_sockname(resp); - if (!addr_string) + /* If we could not get our own address and there is more than + * one result for resolving k.root-servers.net, we cannot + * cache. Otherwise, no matter if we got IPv6 connectivity or + * not, we will cache the (single) result and are done. */ + if (!addr_string && result->ai_next != NULL) continue; if ((cached = malloc(sizeof(struct addrinfo))) == NULL)