From: Daniel Stenberg Date: Thu, 1 Jul 2004 13:54:24 +0000 (+0000) Subject: Gisle's win32-fix. 'errno' is not used for errors when socket() fails on X-Git-Tag: upstream/1.10.0~1414 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=5c1ec168f69ca713fc5a2250ffffe7c8d8b5990b;p=platform%2Fupstream%2Fc-ares.git Gisle's win32-fix. 'errno' is not used for errors when socket() fails on Windows. --- diff --git a/ares_process.c b/ares_process.c index a8dd0c7..121c449 100644 --- a/ares_process.c +++ b/ares_process.c @@ -35,6 +35,12 @@ #include "ares_dns.h" #include "ares_private.h" +#ifdef WIN32 +#define GET_ERRNO() WSAGetLastError() +#else +#define GET_ERRNO() errno +#endif + static void write_tcp_data(ares_channel channel, fd_set *write_fds, time_t now); static void read_tcp_data(ares_channel channel, fd_set *read_fds, time_t now); @@ -476,18 +482,20 @@ static int open_tcp_socket(ares_channel channel, struct server_state *server) return -1; } #endif - + /* Connect to the server. */ memset(&sockin, 0, sizeof(sockin)); sockin.sin_family = AF_INET; sockin.sin_addr = server->addr; sockin.sin_port = channel->tcp_port; - if (connect(s, (struct sockaddr *) &sockin, sizeof(sockin)) == -1 - && errno != EINPROGRESS) - { + if (connect(s, (struct sockaddr *) &sockin, sizeof(sockin)) == -1) { + int err = GET_ERRNO(); + + if (err != EINPROGRESS && err != EWOULDBLOCK) { closesocket(s); return -1; } + } server->tcp_socket = s; return 0;