curl/lib
Daniel Stenberg 87fdfe770d Dmitry Kurochkin: In "real world" testing I found more bugs in
pipelining. Broken connection is not restored and we get into infinite
loop. It happens because of wrong is_in_pipeline values.
2008-01-27 22:53:09 +00:00
..
.cvsignore ignore curllib.dsp 2004-08-10 10:43:41 +00:00
amigaos.c proper symbol definition check for all AmigaOS flavours 2007-02-28 14:45:48 +00:00
amigaos.h proper symbol definition check for all AmigaOS flavours 2007-02-28 14:45:48 +00:00
arpa_telnet.h Make some more arrays of pointers const. 2004-12-20 18:23:43 +00:00
base64.c removed space after if and while before the parenthesis for better source code 2007-11-05 09:45:09 +00:00
base64.h - David McCreedy made changes to allow base64 encoding/decoding to work on 2007-01-03 23:04:38 +00:00
ca-bundle.crt
config-amigaos.h proper symbol definition check for all AmigaOS flavours 2007-02-28 14:45:48 +00:00
config-mac.h Make sure RETSIGTYPE is properly defined 2006-11-25 01:02:52 +00:00
config-os400.h Fix dynamic CURLOPT_POSTFIELDS bug: back to static. 2007-10-15 18:32:01 +00:00
config-riscos.h Patrick Monnerat modified the LDAP code and approach in curl. Starting now, 2007-08-11 20:57:54 +00:00
config-tpf.h Patrick Monnerat modified the LDAP code and approach in curl. Starting now, 2007-08-11 20:57:54 +00:00
config-win32.h MSVC 9.0 (VS2008) does not support Windows build targets prior to WinXP, 2007-12-18 18:08:19 +00:00
config-win32ce.h MSVC versions prior to VS2005 do not complain about portable C functions 2007-11-07 18:18:42 +00:00
config.dos DOS targets do have setmode(). 2007-04-03 10:18:38 +00:00
connect.c Change typecast due to http://cool.haxx.se/cvs.cgi/curl/include/curl/curl.h.diff?r1=1.336&r2=1.337 2008-01-08 01:05:50 +00:00
connect.h use macros ERRNO, SET_ERRNO(), SOCKERRNO and SET_SOCKERRNO() for errno handling 2007-02-16 18:19:35 +00:00
content_encoding.c struct HandleData is now called struct SingleRequest, and is only for data that 2007-11-24 23:16:55 +00:00
content_encoding.h struct HandleData is now called struct SingleRequest, and is only for data that 2007-11-24 23:16:55 +00:00
cookie.c "Igor" pointed out that CURLOPT_COOKIELIST set to "ALL" leaked memory, and so 2008-01-23 22:22:12 +00:00
cookie.h "Igor" pointed out that CURLOPT_COOKIELIST set to "ALL" leaked memory, and so 2008-01-23 22:22:12 +00:00
curl_ldap.h Added per-protocol callback static tables, replacing callback ptr storage 2007-10-12 13:36:37 +00:00
curllib.dsw
curlx.h Update copyright year, since the file has been modified 2006-10-27 03:47:57 +00:00
dict.c All static functions that were previously name Curl_* something no longer 2007-12-08 22:50:55 +00:00
dict.h Added per-protocol callback static tables, replacing callback ptr storage 2007-10-12 13:36:37 +00:00
easy.c Woops, partly revert my previous commit and do it slightly differently instead. 2008-01-15 22:44:12 +00:00
easyif.h Update copyright year, since the file has been modified 2006-10-27 03:47:57 +00:00
escape.c if () => if() 2007-11-07 09:21:35 +00:00
escape.h First commit of David McCreedy's EBCDIC and TPF changes. 2006-04-07 21:50:47 +00:00
file.c fix compiler warning 2008-01-11 16:49:35 +00:00
file.h Fixed an OOM problem with file: URLs 2007-10-30 23:00:40 +00:00
formdata.c removed space after if and while before the parenthesis for better source code 2007-11-05 09:45:09 +00:00
formdata.h update copyright year notice 2007-01-27 03:43:05 +00:00
ftp.c Calls to Curl_failf() are not supposed to provide a trailing newline as the 2008-01-15 23:19:02 +00:00
ftp.h Added per-protocol callback static tables, replacing callback ptr storage 2007-10-12 13:36:37 +00:00
getenv.c if () => if() 2007-11-07 09:21:35 +00:00
getinfo.c if () => if() 2007-11-07 09:21:35 +00:00
getinfo.h
gtls.c if () => if() 2007-11-07 09:21:35 +00:00
gtls.h Renamed a few variables to avoid shadowing global declarations. 2007-09-27 02:45:58 +00:00
hash.c if () => if() 2007-11-07 09:21:35 +00:00
hash.h Robert Iakobashvili re-arranged the internal hash code to work with a custom 2007-06-26 21:09:28 +00:00
hostares.c if () => if() 2007-11-07 09:21:35 +00:00
hostasyn.c Adapted the c-ares code to the API change c-ares 1.5.0 brings in the 2007-09-28 21:48:28 +00:00
hostip4.c if () => if() 2007-11-07 09:21:35 +00:00
hostip6.c if () => if() 2007-11-07 09:21:35 +00:00
hostip.c Woops, partly revert my previous commit and do it slightly differently instead. 2008-01-15 22:44:12 +00:00
hostip.h Woops, partly revert my previous commit and do it slightly differently instead. 2008-01-15 22:44:12 +00:00
hostsyn.c update copyright year 2007-04-03 18:25:18 +00:00
hostthre.c removed space after if and while before the parenthesis for better source code 2007-11-05 09:45:09 +00:00
http_chunks.c - I fixed two cases of missing return code checks when handling chunked 2008-01-02 22:30:34 +00:00
http_chunks.h - Ravi Pratap provided work on libcurl making pipelining more robust and 2007-02-21 21:59:40 +00:00
http_digest.c Nikitinskit Dmitriy filed bug report #1868255 2008-01-10 09:17:07 +00:00
http_digest.h Fixed some minor type mismatches and missing consts mainly found by splint. 2007-08-27 06:31:28 +00:00
http_negotiate.c While inspecting the Negotiate code, I noticed how the proxy auth was using 2007-11-20 23:17:08 +00:00
http_negotiate.h Mark Davies fixed Negotiate authentication over proxy, and also introduced 2007-09-21 11:05:31 +00:00
http_ntlm.c removed space after if and while before the parenthesis for better source code 2007-11-05 09:45:09 +00:00
http_ntlm.h Fixed some minor type mismatches and missing consts mainly found by splint. 2007-08-27 06:31:28 +00:00
http.c - Kevin Reed filed bug report #1879375 2008-01-25 23:33:45 +00:00
http.h Added per-protocol callback static tables, replacing callback ptr storage 2007-10-12 13:36:37 +00:00
if2ip.c if () => if() 2007-11-07 09:21:35 +00:00
if2ip.h build fix for Interix 2006-03-04 22:39:31 +00:00
inet_ntoa_r.h provide the proper copyright texts for these 2005-05-26 20:56:25 +00:00
inet_ntop.c if () => if() 2007-11-07 09:21:35 +00:00
inet_ntop.h Yang Tse: fixes the use of Curl_inet_ntop and Curl_inet_pton with no 2005-11-25 22:20:02 +00:00
inet_pton.c if () => if() 2007-11-07 09:21:35 +00:00
inet_pton.h Yang Tse's changes to provide an inet_pton() proto for the platforms who 2005-11-28 20:21:35 +00:00
krb4.c Calls to Curl_failf() are not supposed to provide a trailing newline as the 2008-01-15 23:19:02 +00:00
krb4.h Thomas J. Moore provided a patch that introduces Kerberos5 support in 2007-07-01 22:01:18 +00:00
krb5.c Fix getsockname argument type 2007-08-08 10:37:07 +00:00
ldap.c reqdata doesn't exist anymore and the path moved to the UrlState struct 2007-11-24 23:18:21 +00:00
libcurl.def Yang Tse: msvc7+ has deprecated the 'DESCRIPTION' section in 2005-11-14 07:48:05 +00:00
libcurl.framework.make Nir Soffer updated libcurl.framework.make: fix symlinks, should link to 2006-11-09 21:58:28 +00:00
libcurl.imp there's an curl_easy_unescape too now 2006-04-18 09:23:03 +00:00
libcurl.plist Matt Veenstra updated to 7.12.3. Starting now, we'll update the version number 2004-12-08 23:09:23 +00:00
libcurl.rc use copyright define instead of hardcoded string. 2008-01-24 14:10:59 +00:00
llist.c Dmitry Kurochkin worked a lot on improving the HTTP Pipelining support that 2008-01-16 12:24:00 +00:00
llist.h Dmitry Kurochkin worked a lot on improving the HTTP Pipelining support that 2008-01-16 12:24:00 +00:00
Makefile.am let 7.17.1 be version-info 4:1:0 2007-10-29 10:19:07 +00:00
makefile.amiga Diego Casorran patches to make (lib)curl build fine on Amiga again 2005-07-13 18:06:40 +00:00
Makefile.b32 Static lib is libcurl.lib and import lib libcurl_imp.lib. 2004-11-14 13:48:15 +00:00
makefile.dj Added TOPDIR variable. Put dependencies in external file. 2007-02-27 15:24:32 +00:00
Makefile.inc Patrick Monnerat modified the LDAP code and approach in curl. Starting now, 2007-08-11 20:57:54 +00:00
Makefile.m32 updated lib versions. 2008-01-17 01:25:46 +00:00
Makefile.netware updated makefiles to use global copyright define. 2008-01-24 15:28:47 +00:00
Makefile.riscos GnuTLS updates 2005-04-07 21:10:31 +00:00
Makefile.vc6 update openssl version 2008-01-23 07:27:40 +00:00
Makefile.Watcom Removed building 'libcurl_wc.lib' as this isn't a static-library 2007-12-09 09:44:05 +00:00
md5.c if () => if() 2007-11-07 09:21:35 +00:00
md5.h Add 'const' to immutable arrays. 2004-12-15 01:38:25 +00:00
memdebug.c if () => if() 2007-11-07 09:21:35 +00:00
memdebug.h Using fdopen() is a more correct way to implement the CURLOPT_NEW_FILE_PREMS 2007-06-28 11:11:29 +00:00
memory.h removed tabs and trailing whitespace from source 2004-10-06 07:50:18 +00:00
mprintf.c fix the treatment of the parameter-based precision, as in "%.*s%s" as 2007-11-20 10:03:33 +00:00
msvcproj.foot new attempt at an improved DSP-file generation 2004-05-11 07:54:55 +00:00
msvcproj.head Linking with wldap32.lib needed for Windows LDAP client 32 API support 2007-10-02 14:26:04 +00:00
multi.c Dmitry Kurochkin: In "real world" testing I found more bugs in 2008-01-27 22:53:09 +00:00
multiif.h Fixed some minor mismatched types found by splint. 2007-08-26 05:53:26 +00:00
netrc.c if () => if() 2007-11-07 09:21:35 +00:00
netrc.h
nss.c Calls to Curl_failf() are not supposed to provide a trailing newline as the 2008-01-15 23:19:02 +00:00
nssg.h Renamed a few variables to avoid shadowing global declarations. 2007-09-27 02:45:58 +00:00
nwlib.c happy new year 2008-01-23 02:12:13 +00:00
nwos.c if () => if() 2007-11-07 09:21:35 +00:00
parsedate.c Jeff Johnson filed bug report #1863171 2008-01-06 10:50:57 +00:00
parsedate.h Updated the copyright year since changes have been this year. 2005-03-31 07:02:02 +00:00
progress.c struct HandleData is now called struct SingleRequest, and is only for data that 2007-11-24 23:16:55 +00:00
progress.h clean up start time and t_startsingle use so that redirect_time works properly 2004-11-15 11:27:03 +00:00
qssl.c Calls to Curl_failf() are not supposed to provide a trailing newline as the 2008-01-15 23:19:02 +00:00
qssl.h Patrick Monnerat restored qssl successful compilation and loading 2007-07-30 21:41:12 +00:00
README.ares When transferring 500 downloads in parallel with a c-ares enabled build only 2007-05-31 11:34:32 +00:00
README.curlx updated with more and new info 2004-04-30 08:51:19 +00:00
README.encoding Fixed a lingering omission of gzip support. 2005-12-08 18:59:19 +00:00
README.hostip Added README.hostip 2005-01-14 13:43:29 +00:00
README.httpauth HTTP "auth done right". See lib/README.httpauth 2004-11-24 16:11:35 +00:00
README.memoryleak corrected how tests/memanalyze.pl is used 2006-10-29 23:00:52 +00:00
README.multi_socket updated to current status 2006-10-29 09:18:32 +00:00
README.pipelining updated to reflect reality 2006-10-29 09:11:44 +00:00
security.c if () => if() 2007-11-07 09:21:35 +00:00
select.c removed space after if and while before the parenthesis for better source code 2007-11-05 09:45:09 +00:00
select.h check availability of poll.h header at configuration time, and include 2008-01-22 14:52:54 +00:00
sendf.c Dmitry Kurochkin removed the cancelled state for pipelining, as we agreed 2008-01-21 23:48:58 +00:00
sendf.h Reverted the const change--what was I thinking? 2007-10-29 20:57:03 +00:00
setup_once.h Windows build targets have socklen_t definition in ws2tcpip.h but some 2007-10-24 14:39:07 +00:00
setup-os400.h Porting library to OS/400 2007-08-23 14:30:24 +00:00
setup.h Define WIN32 when build target is Win32 API. 2007-11-08 18:13:54 +00:00
share.c if () => if() 2007-11-07 09:21:35 +00:00
share.h Added support for Salford-C under Win32 (scc). HAVE_MALLOC_H and 2006-04-26 17:11:05 +00:00
sockaddr.h oops * 2 2005-11-12 22:13:20 +00:00
socks.c fix compiler warning 2008-01-14 19:40:10 +00:00
socks.h Richard Atterer brought a patch that added support for SOCKS4a proxies, which 2008-01-02 21:40:11 +00:00
speedcheck.c Renamed several libcurl error codes and options to make them more general 2007-08-30 20:34:57 +00:00
speedcheck.h
splay.c removed space after if and while before the parenthesis for better source code 2007-11-05 09:45:09 +00:00
splay.h Enabled a few more gcc warnings with --enable-debug. Renamed a few 2007-09-27 01:45:22 +00:00
ssh.c when unable to initialize sftp session, also log failure reason 2008-01-22 17:26:42 +00:00
ssh.h Added per-protocol callback static tables, replacing callback ptr storage 2007-10-12 13:36:37 +00:00
sslgen.c added missing semicolon fromn last commit. 2007-12-25 13:26:01 +00:00
sslgen.h Fixed some minor type mismatches and missing consts mainly found by splint. 2007-08-27 06:31:28 +00:00
ssluse.c Calls to Curl_failf() are not supposed to provide a trailing newline as the 2008-01-15 23:19:02 +00:00
ssluse.h Bug report #1759542 (http://curl.haxx.se/bug/view.cgi?id=1759542). A bad use 2007-07-29 12:54:05 +00:00
strdup.c if () => if() 2007-11-07 09:21:35 +00:00
strdup.h Moved strdup replacement from src/main.c into src/strdup.c so it's available 2006-07-11 17:02:06 +00:00
strequal.c if () => if() 2007-11-07 09:21:35 +00:00
strequal.h modified this year 2005-04-22 20:48:07 +00:00
strerror.c if () => if() 2007-11-07 09:21:35 +00:00
strerror.h removed trailing whitespace 2004-10-11 17:26:24 +00:00
strtok.c if () => if() 2007-11-07 09:21:35 +00:00
strtok.h
strtoofft.c removed space after if and while before the parenthesis for better source code 2007-11-05 09:45:09 +00:00
strtoofft.h Added prototype for _strtoi64(). 2007-11-06 16:20:54 +00:00
telnet.c All static functions that were previously name Curl_* something no longer 2007-12-08 22:50:55 +00:00
telnet.h Added per-protocol callback static tables, replacing callback ptr storage 2007-10-12 13:36:37 +00:00
tftp.c Calls to Curl_failf() are not supposed to provide a trailing newline as the 2008-01-15 23:19:02 +00:00
tftp.h Added per-protocol callback static tables, replacing callback ptr storage 2007-10-12 13:36:37 +00:00
timeval.c moved includes to setup.h so that the project headers also pick them up (eleminate gcc warning). 2007-06-30 23:45:57 +00:00
timeval.h update copyright year 2007-04-03 18:25:18 +00:00
transfer.c Dmitry Kurochkin worked a lot on improving the HTTP Pipelining support that 2008-01-16 12:24:00 +00:00
transfer.h Rearranged code and changed Curl_readwrite_init() and Curl_pre_readwrite() into 2007-11-15 21:45:45 +00:00
url.c Dmitry Kurochkin removed the cancelled state for pipelining, as we agreed 2008-01-21 23:48:58 +00:00
url.h Dmitry Kurochkin worked a lot on improving the HTTP Pipelining support that 2008-01-16 12:24:00 +00:00
urldata.h Dmitry Kurochkin removed the cancelled state for pipelining, as we agreed 2008-01-21 23:48:58 +00:00
vc8proj.foot Use DOS line-endings. 2007-01-29 19:08:04 +00:00
vc8proj.head Use DOS line-endings. 2007-01-29 19:08:04 +00:00
version.c if () => if() 2007-11-07 09:21:35 +00:00

HTTP Pipelining with libcurl
============================

Background

Since pipelining implies that one or more requests are sent to a server before
the previous response(s) have been received, we only support it for multi
interface use.

Considerations

When using the multi interface, you create one easy handle for each transfer.
Bascially any number of handles can be created, added and used with the multi
interface - simultaneously. It is an interface designed to allow many
simultaneous transfers while still using a single thread. Pipelining does not
change any of these details.

API

We've added a new option to curl_multi_setopt() called CURLMOPT_PIPELINING
that enables "attempted pipelining" and then all easy handles used on that
handle will attempt to use an existing pipeline.

Details

- A pipeline is only created if a previous connection exists to the same IP
  address that the new request is being made to use.

- Pipelines are only supported for HTTP(S) as no other currently supported
  protocol has features resemembling this, but we still name this feature
  plain 'pipelining' to possibly one day support it for other protocols as
  well.

- HTTP Pipelining is for GET and HEAD requests only.

- When a pipeline is in use, we must take precautions so that when used easy
  handles (i.e those who still wait for a response) are removed from the multi
  handle, we must deal with the outstanding response nicely.

- Explicitly asking for pipelining handle X and handle Y won't be supported.
  It isn't easy for an app to do this association. The lib should probably
  still resolve the second one properly to make sure that they actually _can_
  be considered for pipelining. Also, asking for explicit pipelining on handle
  X may be tricky when handle X get a closed connection.

- We need options to control max pipeline length, and probably how to behave
  if we reach that limit. As was discussed on the list, it can probably be
  made very complicated, so perhaps we can think of a way to pass all
  variables involved to a callback and let the application decide how to act
  in specific situations. Either way, these fancy options are only interesting
  to work on when everything is working and we have working apps to test with.