curl/lib
Daniel Stenberg a62e155ca4 - Niklas Angebrand made the cookie support in libcurl properly deal with the
"HttpOnly" feature introduced by Microsoft and apparently also supported by
  Firefox: http://msdn2.microsoft.com/en-us/library/ms533046.aspx . HttpOnly
  is now supported when received from servers in HTTP headers, when written to
  cookie jars and when read from existing cookie jars.
2008-01-31 12:21:57 +00:00
..
.cvsignore
amigaos.c
amigaos.h
arpa_telnet.h
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
ca-bundle.crt
config-amigaos.h
config-mac.h
config-os400.h
config-riscos.h
config-tpf.h
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
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
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 - Niklas Angebrand made the cookie support in libcurl properly deal with the 2008-01-31 12:21:57 +00:00
cookie.h - Niklas Angebrand made the cookie support in libcurl properly deal with the 2008-01-31 12:21:57 +00:00
curl_ldap.h
curllib.dsw
curlx.h
dict.c All static functions that were previously name Curl_* something no longer 2007-12-08 22:50:55 +00:00
dict.h
easy.c Woops, partly revert my previous commit and do it slightly differently instead. 2008-01-15 22:44:12 +00:00
easyif.h
escape.c if () => if() 2007-11-07 09:21:35 +00:00
escape.h
file.c - Dmitry Kurochkin moved several struct fields from the connectdata struct to 2008-01-31 12:04:33 +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
ftp.c - Dmitry Kurochkin moved several struct fields from the connectdata struct to 2008-01-31 12:04:33 +00:00
ftp.h
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
hash.c if () => if() 2007-11-07 09:21:35 +00:00
hash.h
hostares.c if () => if() 2007-11-07 09:21:35 +00:00
hostasyn.c
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
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 - Dmitry Kurochkin moved several struct fields from the connectdata struct to 2008-01-31 12:04:33 +00:00
http_chunks.h
http_digest.c Nikitinskit Dmitriy filed bug report #1868255 2008-01-10 09:17:07 +00:00
http_digest.h
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
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
http.c - Dmitry Kurochkin moved several struct fields from the connectdata struct to 2008-01-31 12:04:33 +00:00
http.h
if2ip.c if () => if() 2007-11-07 09:21:35 +00:00
if2ip.h
inet_ntoa_r.h
inet_ntop.c if () => if() 2007-11-07 09:21:35 +00:00
inet_ntop.h
inet_pton.c if () => if() 2007-11-07 09:21:35 +00:00
inet_pton.h
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
krb5.c
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
libcurl.framework.make
libcurl.imp
libcurl.plist
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
Makefile.b32
makefile.dj
Makefile.inc
Makefile.m32 silent stupid 'del' message when no files to delete found; 2008-01-29 23:46:41 +00:00
Makefile.netware updated makefiles to use global copyright define. 2008-01-24 15:28:47 +00:00
Makefile.riscos
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
memdebug.c if () => if() 2007-11-07 09:21:35 +00:00
memdebug.h
memory.h
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
msvcproj.head
multi.c Dmitry Kurochkin: In "real world" testing I found more bugs in 2008-01-27 22:53:09 +00:00
multiif.h
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
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
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
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
README.ares
README.curlx
README.encoding
README.hostip
README.httpauth
README.memoryleak
README.multi_socket
README.pipelining
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 this was modified this year so we bump the copyright year 2008-01-28 11:56:13 +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
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
sockaddr.h
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
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
ssh.c when unable to initialize sftp session, also log failure reason 2008-01-22 17:26:42 +00:00
ssh.h
sslgen.c added missing semicolon fromn last commit. 2007-12-25 13:26:01 +00:00
sslgen.h
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
strdup.c if () => if() 2007-11-07 09:21:35 +00:00
strdup.h
strequal.c if () => if() 2007-11-07 09:21:35 +00:00
strequal.h
strerror.c if () => if() 2007-11-07 09:21:35 +00:00
strerror.h
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
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
timeval.c
timeval.h
transfer.c - Dmitry Kurochkin moved several struct fields from the connectdata struct to 2008-01-31 12:04:33 +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 moved several struct fields from the connectdata struct to 2008-01-31 12:04:33 +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 moved several struct fields from the connectdata struct to 2008-01-31 12:04:33 +00:00
vc8proj.foot
vc8proj.head
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.