From: Gisle Vanem Date: Sat, 15 Jan 2005 09:26:07 +0000 (+0000) Subject: errrno can by freak accident become EINTR on DOS or X-Git-Tag: curl-7_13_0~66 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=f5b8a26d9ad360680686e6eb7d21538a2e0f8758;p=thirdparty%2Fcurl.git errrno can by freak accident become EINTR on DOS or Windows (unrelated to select). select() can never set errno to EINTR on Windows. --- diff --git a/lib/select.c b/lib/select.c index 3a1b6bc449..5bd8ea466d 100644 --- a/lib/select.c +++ b/lib/select.c @@ -39,13 +39,17 @@ #error "We can't compile without select() support!" #endif -#include "select.h" - #ifdef __BEOS__ /* BeOS has FD_SET defined in socket.h */ #include #endif +#include + +#include "urldata.h" +#include "connect.h" +#include "select.h" + #ifdef WIN32 #define VALID_SOCK(s) (1) /* Win-sockets are not in range [0..FD_SETSIZE> */ #else @@ -148,7 +152,7 @@ int Curl_select(curl_socket_t readfd, curl_socket_t writefd, int timeout_ms) do { r = select(maxfd + 1, &fds_read, &fds_write, &fds_err, &timeout); - } while((r == -1) && (errno == EINTR)); + } while((r == -1) && (Curl_ourerrno() == EINTR)); if (r < 0) return -1; @@ -233,7 +237,7 @@ int Curl_poll(struct pollfd ufds[], unsigned int nfds, int timeout_ms) do { r = select(maxfd + 1, &fds_read, &fds_write, &fds_err, ptimeout); - } while((r == -1) && (errno == EINTR)); + } while((r == -1) && (Curl_ourerrno() == EINTR)); if (r < 0) return -1;