input/curl: query timeout from CURL

Use curl_multi_timeout() to determine the select() timeout, instead of
hard-coding one second.
This commit is contained in:
Max Kellermann 2010-07-20 22:37:34 +02:00
parent 8b055c3127
commit a4908dca42

View File

@ -241,7 +241,6 @@ input_curl_select(struct input_curl *c)
fd_set rfds, wfds, efds; fd_set rfds, wfds, efds;
int max_fd, ret; int max_fd, ret;
CURLMcode mcode; CURLMcode mcode;
/* XXX hard coded timeout value.. */
struct timeval timeout = { struct timeval timeout = {
.tv_sec = 1, .tv_sec = 1,
.tv_usec = 0, .tv_usec = 0,
@ -262,6 +261,24 @@ input_curl_select(struct input_curl *c)
assert(max_fd >= 0); assert(max_fd >= 0);
#if LIBCURL_VERSION_NUM >= 0x070f00
long timeout2;
mcode = curl_multi_timeout(c->multi, &timeout2);
if (mcode != CURLM_OK) {
g_warning("curl_multi_timeout() failed: %s\n",
curl_multi_strerror(mcode));
return -1;
}
if (timeout2 >= 0) {
if (timeout2 > 10000)
timeout2 = 10000;
timeout.tv_sec = timeout2 / 1000;
timeout.tv_usec = (timeout2 % 1000) * 1000;
}
#endif
ret = select(max_fd + 1, &rfds, &wfds, &efds, &timeout); ret = select(max_fd + 1, &rfds, &wfds, &efds, &timeout);
if (ret < 0) if (ret < 0)
g_warning("select() failed: %s\n", strerror(errno)); g_warning("select() failed: %s\n", strerror(errno));