From: Daniel Stenberg Date: Fri, 12 Oct 2001 12:30:06 +0000 (+0000) Subject: better check for absolute URL redirects, adjusted to new Curl_tvdiff() proto X-Git-Tag: curl-7_9_1~86 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=2c5e4165916e845ef16b325d1d492a89432940b5;p=thirdparty%2Fcurl.git better check for absolute URL redirects, adjusted to new Curl_tvdiff() proto --- diff --git a/lib/transfer.c b/lib/transfer.c index 2a044a9ea4..80a2a75f9f 100644 --- a/lib/transfer.c +++ b/lib/transfer.c @@ -859,7 +859,8 @@ Transfer(struct connectdata *c_conn) conn->upload_bufsize=(long)min(data->progress.ulspeed, BUFSIZE); } - if (data->set.timeout && (Curl_tvdiff (now, start) > data->set.timeout)) { + if (data->set.timeout && + ((Curl_tvdiff(now, start)/1000) > data->set.timeout)) { failf (data, "Operation timed out with %d out of %d bytes received", bytecount, conn->size); return CURLE_OPERATION_TIMEOUTED; @@ -984,7 +985,7 @@ CURLcode Curl_perform(struct SessionHandle *data) data->change.referer_alloc = TRUE; /* yes, free this later */ } - if(2 != sscanf(newurl, "%15[^:]://%c", prot, &letter)) { + if(2 != sscanf(newurl, "%15[^?&/:]://%c", prot, &letter)) { /*** *DANG* this is an RFC 2068 violation. The URL is supposed to be absolute and this doesn't seem to be that!