diff options
-rw-r--r-- | lib/url.c | 66 |
1 files changed, 46 insertions, 20 deletions
@@ -1116,11 +1116,7 @@ ConnectionStore(struct SessionHandle *data, static CURLcode ConnectPlease(struct SessionHandle *data, struct connectdata *conn) { -#if defined(WIN32) - unsigned long nonblock = 0; - fd_set connectfd; - struct timeval conntimeout; -#endif + long max_time=300000; /* milliseconds, default to five minutes */ #ifndef ENABLE_IPV6 conn->firstsocket = socket(AF_INET, SOCK_STREAM, 0); @@ -1252,9 +1248,34 @@ static CURLcode ConnectPlease(struct SessionHandle *data, #endif /*ENABLE_IPV6*/ /************************************************************* + * Figure out what maximum time we have left + *************************************************************/ + if(data->set.timeout || data->set.connecttimeout) { + double has_passed; + + /* Evaluate how much that that has passed */ + has_passed = Curl_tvdiff(Curl_tvnow(), data->progress.start); + +#ifndef min +#define min(a, b) ((a) < (b) ? (a) : (b)) +#endif + + /* get the most strict timeout of the ones converted to milliseconds */ + max_time = min(data->set.timeout, data->set.connecttimeout)*1000; + + /* subtract the passed time */ + max_time -= (long)(has_passed * 1000); + + if(max_time < 0) + /* a precaution, no need to continue if time already is up */ + return CURLE_OPERATION_TIMEOUTED; + } + + /************************************************************* * Connect to server/proxy *************************************************************/ return Curl_connecthost(conn, + max_time, conn->firstsocket, /* might be bind()ed */ &conn->firstsocket); } @@ -1643,21 +1664,6 @@ static CURLcode CreateConnection(struct SessionHandle *data, } /************************************************************* - * Set timeout if that is being used - *************************************************************/ - if(data->set.timeout || data->set.connecttimeout) { - /* We set the timeout on the connection/resolving phase first, separately - * from the download/upload part to allow a maximum time on everything */ - - /* myalarm() makes a signal get sent when the timeout fires off, and that - will abort system calls */ - if(data->set.connecttimeout) - myalarm(data->set.connecttimeout); - else - myalarm(data->set.timeout); - } - - /************************************************************* * Setup internals depending on protocol *************************************************************/ @@ -2055,6 +2061,23 @@ static CURLcode CreateConnection(struct SessionHandle *data, } /************************************************************* + * Set timeout if that is being used + *************************************************************/ + if(data->set.timeout || data->set.connecttimeout) { + /* We set the timeout on the name resolving phase first, separately from + * the download/upload part to allow a maximum time on everything. This is + * a signal-based timeout, why it won't work and shouldn't be used in + * multi-threaded environments. */ + + /* myalarm() makes a signal get sent when the timeout fires off, and that + will abort system calls */ + if(data->set.connecttimeout) + myalarm(data->set.connecttimeout); + else + myalarm(data->set.timeout); + } + + /************************************************************* * Resolve the name of the server or proxy *************************************************************/ if(!data->change.proxy) { @@ -2088,6 +2111,9 @@ static CURLcode CreateConnection(struct SessionHandle *data, } } Curl_pgrsTime(data, TIMER_NAMELOOKUP); + if(data->set.timeout || data->set.connecttimeout) + /* switch off signal-based timeouts */ + myalarm(0); /************************************************************* * Proxy authentication |