summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/core/network.c15
-rw-r--r--src/core/network.h3
-rw-r--r--src/core/server.c14
3 files changed, 24 insertions, 8 deletions
diff --git a/src/core/network.c b/src/core/network.c
index e034e609..5a6e276a 100644
--- a/src/core/network.c
+++ b/src/core/network.c
@@ -340,7 +340,7 @@ int net_gethostbyname(const char *addr, IPADDR *ip)
freeaddrinfo(ai);
#else
hp = gethostbyname(addr);
- if (hp == NULL) return -1;
+ if (hp == NULL) return h_errno;
ip->family = AF_INET;
memcpy(&ip->addr, hp->h_addr, 4);
@@ -467,7 +467,7 @@ const char *net_gethosterror(int error)
return gai_strerror(error);
#else
- switch (h_errno) {
+ switch (error) {
case HOST_NOT_FOUND:
return _("Host not found");
case NO_ADDRESS:
@@ -483,6 +483,17 @@ const char *net_gethosterror(int error)
#endif
}
+/* return TRUE if host lookup failed because it didn't exist (ie. not
+ some error with name server) */
+int net_hosterror_notfound(int error)
+{
+#ifdef HAVE_IPV6
+ return error != 1 && (error == EAI_NONAME || error == EAI_NODATA);
+#else
+ return error == HOST_NOT_FOUND || error == NO_ADDRESS;
+#endif
+}
+
int is_ipv4_address(const char *host)
{
while (*host != '\0') {
diff --git a/src/core/network.h b/src/core/network.h
index b7e6a30f..613434c4 100644
--- a/src/core/network.h
+++ b/src/core/network.h
@@ -58,6 +58,9 @@ int net_gethostbyname(const char *addr, IPADDR *ip);
int net_gethostbyaddr(IPADDR *ip, char **name);
/* get error of net_gethostname() */
const char *net_gethosterror(int error);
+/* return TRUE if host lookup failed because it didn't exist (ie. not
+ some error with name server) */
+int net_hosterror_notfound(int error);
/* Get socket address/port */
int net_getsockname(int handle, IPADDR *addr, int *port);
diff --git a/src/core/server.c b/src/core/server.c
index 98cbce54..f46893e4 100644
--- a/src/core/server.c
+++ b/src/core/server.c
@@ -141,20 +141,22 @@ static void server_connect_callback_readpipe(SERVER_REC *server, int handle)
server->connect_pipe[1] = -1;
conn = server->connrec;
- server->handle = iprec.error == -1 ? -1 :
+ server->handle = iprec.error != 0 ? -1 :
net_connect_ip(&iprec.ip, conn->proxy != NULL ?
conn->proxy_port : conn->port,
conn->own_ip != NULL ? conn->own_ip : NULL);
if (server->handle == -1) {
/* failed */
- if (iprec.error != -1) {
- /* reconnect only if connect() was the one that
- failed, if host lookup failed we most probably
- don't want to try reconnecting back. */
+ if (iprec.error == 0 || !net_hosterror_notfound(iprec.error)) {
+ /* reconnect back only if either
+ 1) connect() failed
+ 2) host name lookup failed not because the host
+ wasn't found, but because there was some
+ other error in nameserver */
server->connection_lost = TRUE;
}
server_cant_connect(server,
- iprec.error != -1 ? g_strerror(errno) : /* connect() failed */
+ iprec.error == 0 ? g_strerror(errno) : /* connect() failed */
(iprec.errorstr != NULL ? iprec.errorstr : "Host lookup failed")); /* gethostbyname() failed */
g_free_not_null(iprec.errorstr);
return;