curl/lib
Daniel Stenberg c6df788866 - Kevin Reed filed bug report #1879375
(http://curl.haxx.se/bug/view.cgi?id=1879375) which describes how libcurl
  got lost in this scenario: proxy tunnel (or HTTPS over proxy), ask to do any
  proxy authentication and the proxy replies with an auth (like NTLM) and then
  closes the connection after that initial informational response.

  libcurl would not properly re-initialize the connection to the proxy and
  continue the auth negotiation like supposed. It does now however, as it will
  now detect if one or more authentication methods were available and asked
  for, and will thus retry the connection and continue from there.

- I made the progress callback get called properly during proxy CONNECT.
2008-01-25 23:33:45 +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 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
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 "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
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
escape.c if () => if() 2007-11-07 09:21:35 +00:00
escape.h
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
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
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
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 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
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 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
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 Using fdopen() is a more correct way to implement the CURLOPT_NEW_FILE_PREMS 2007-06-28 11:11:29 +00:00
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 Linking with wldap32.lib needed for Windows LDAP client 32 API support 2007-10-02 14:26:04 +00:00
multi.c Dmitry Kurochkin's pipelining close-down segfault fix 2008-01-23 12:22:04 +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
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 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
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 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
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 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
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 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
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.