diff options
author | Daniel Stenberg <daniel@haxx.se> | 2002-03-04 10:15:44 +0000 |
---|---|---|
committer | Daniel Stenberg <daniel@haxx.se> | 2002-03-04 10:15:44 +0000 |
commit | 9fc62a8dd0e940668c8ee6310fa9d4530cda744a (patch) | |
tree | ad2a95036584ba1e96b7c5d44ff4bc8e2d8e6ce1 /docs/examples/multi-double.c | |
parent | 61540b98c2e80042113db9780e61623aae8f69a1 (diff) | |
download | curl-9fc62a8dd0e940668c8ee6310fa9d4530cda744a.tar.gz |
multi interface using examples
Diffstat (limited to 'docs/examples/multi-double.c')
-rw-r--r-- | docs/examples/multi-double.c | 87 |
1 files changed, 87 insertions, 0 deletions
diff --git a/docs/examples/multi-double.c b/docs/examples/multi-double.c new file mode 100644 index 000000000..c850b0fe4 --- /dev/null +++ b/docs/examples/multi-double.c @@ -0,0 +1,87 @@ +/* + * This is a simple example using the multi interface. + */ + +#include <stdio.h> +#include <string.h> + +/* somewhat unix-specific */ +#include <sys/time.h> +#include <unistd.h> + +/* To start with, we include the header from the lib directory. This should + later of course be moved to the proper include dir. */ +#include "../lib/multi.h" + +/* + * Simply download two HTTP files! + */ +int main(int argc, char **argv) +{ + CURL *http_handle; + CURL *http_handle2; + CURLM *multi_handle; + + int still_running; /* keep number of running handles */ + + http_handle = curl_easy_init(); + http_handle2 = curl_easy_init(); + + /* set options */ + curl_easy_setopt(http_handle, CURLOPT_URL, "http://www.haxx.se/"); + + /* set options */ + curl_easy_setopt(http_handle2, CURLOPT_URL, "http://localhost/"); + + /* init a multi stack */ + multi_handle = curl_multi_init(); + + /* add the individual transfers */ + curl_multi_add_handle(multi_handle, http_handle); + curl_multi_add_handle(multi_handle, http_handle2); + + /* we start some action by calling perform right away */ + while(CURLM_CALL_MULTI_PERFORM == + curl_multi_perform(multi_handle, &still_running)); + + while(still_running) { + struct timeval timeout; + int rc; /* select() return code */ + + fd_set fdread; + fd_set fdwrite; + fd_set fdexcep; + int maxfd; + + FD_ZERO(&fdread); + FD_ZERO(&fdwrite); + FD_ZERO(&fdexcep); + + /* set a suitable timeout to play around with */ + timeout.tv_sec = 1; + timeout.tv_usec = 0; + + /* get file descriptors from the transfers */ + curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd); + + rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout); + + switch(rc) { + case -1: + /* select error */ + break; + case 0: + default: + /* timeout or readable/writable sockets */ + curl_multi_perform(multi_handle, &still_running); + break; + } + } + + curl_multi_cleanup(multi_handle); + + curl_easy_cleanup(http_handle); + curl_easy_cleanup(http_handle2); + + return 0; +} |