curl/lib
Daniel Stenberg 89ab5f4380 Robson Braga Araujo reported bug #1618359
(http://curl.haxx.se/bug/view.cgi?id=1618359) and subsequently provided a
patch for it: when downloading 2 zero byte files in a row, curl 7.16.0
enters an infinite loop, while curl 7.16.1-20061218 does one additional
unnecessary request.

Fix: During the "Major overhaul introducing http pipelining support and
shared connection cache within the multi handle." change, headerbytecount
was moved to live in the Curl_transfer_keeper structure. But that structure
is reset in the Transfer method, losing the information that we had about
the header size. This patch moves it back to the connectdata struct.
2006-12-21 10:15:38 +00:00
..
.cvsignore
amigaos.c
amigaos.h
arpa_telnet.h
base64.c Avoid typecasting a signed char to an int when using is*() functions, as that 2006-10-17 21:32:56 +00:00
base64.h
ca-bundle.crt
config-amigaos.h Define HAVE_SIGNAL_H, HAVE_SIG_ATOMIC_T and HAVE_SIG_ATOMIC_T_VOLATILE 2006-11-24 16:38:58 +00:00
config-mac.h Make sure RETSIGTYPE is properly defined 2006-11-25 01:02:52 +00:00
config-riscos.h Define HAVE_SIGNAL_H, HAVE_SIG_ATOMIC_T and HAVE_SIG_ATOMIC_T_VOLATILE 2006-11-24 16:38:58 +00:00
config-tpf.h Define HAVE_SIGNAL_H, HAVE_SIG_ATOMIC_T and HAVE_SIG_ATOMIC_T_VOLATILE 2006-11-24 16:38:58 +00:00
config-win32.h better preprocessor check for recent MSVC versions 2006-12-05 15:24:18 +00:00
config-win32ce.h Make sure RETSIGTYPE is properly defined 2006-11-25 01:02:52 +00:00
config.dos Define HAVE_SIGNAL_H, HAVE_SIG_ATOMIC_T and HAVE_SIG_ATOMIC_T_VOLATILE 2006-11-24 16:38:58 +00:00
connect.c Check for USE_WINSOCK instead of WIN32 where the check was done 2006-10-18 21:05:40 +00:00
connect.h Constify some arguments in Curl_connecthost() and singleipconnect(). 2006-07-21 06:50:39 +00:00
content_encoding.c Based on a patch by Armel Asselin, the FTP code no longer re-issues the TYPE 2006-08-19 21:18:36 +00:00
content_encoding.h Based on a patch by Armel Asselin, the FTP code no longer re-issues the TYPE 2006-08-19 21:18:36 +00:00
cookie.c As reported in bug: #1566077 the former URL mentioned in the generated cookie 2006-09-27 21:00:45 +00:00
cookie.h Removed "#ifndef__WATCOMC__". Use "#ifdef HAVE_SYS_TIME_H" instead. 2006-08-30 16:17:06 +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 Remove redundant __CYGWIN__ symbol check 2006-10-11 16:01:16 +00:00
dict.h
easy.c Jared Lundell filed bug report #1604956 2006-12-05 15:36:26 +00:00
easyif.h Update copyright year, since the file has been modified 2006-10-27 03:47:57 +00:00
escape.c Avoid typecasting a signed char to an int when using is*() functions, as that 2006-10-17 21:32:56 +00:00
escape.h
file.c use the return code from lseek() to detect problems and bail out if so 2006-10-18 14:47:58 +00:00
file.h
formdata.c Avoid Metaware's High-C warning "'=' encountered where '==' may have been intended." 2006-08-29 21:11:55 +00:00
formdata.h Yves Lejeune fixed so that replacing Content-Type: when doing multipart 2006-07-27 22:35:09 +00:00
ftp.c Robson Braga Araujo reported bug #1618359 2006-12-21 10:15:38 +00:00
ftp.h
getenv.c
getinfo.c Compiler warning fix 2006-09-25 00:54:32 +00:00
getinfo.h
gtls.c Brendan Jurd provided a fix that now prevents libcurl from getting a SIGPIPE 2006-12-16 21:33:51 +00:00
gtls.h cleaned up Curl_write() and the sub functions it uses for various protocols. 2006-11-11 21:34:43 +00:00
hash.c Added a useful debug function within #if 0. The function makes it easy to 2006-09-10 22:12:24 +00:00
hash.h
hostares.c Jeff helped me pinpoint that we didn't properly set the expire timer during 2006-10-17 08:06:27 +00:00
hostasyn.c Simplify check for NEED_MALLOC_H, and make more explicit that NEED_MALLOC_H shall be defined if <malloc.h> header file must be included even when including <stdlib.h>. 2006-07-25 13:49:49 +00:00
hostip4.c Update copyright year, since the file has been modified 2006-10-27 03:47:57 +00:00
hostip6.c put back the correct logic, as the change dated July 11th 2006 added bad 2006-07-27 22:28:53 +00:00
hostip.c Workaround for Cray UNICOS 9.0 to fix ftp. 2006-08-21 22:28:19 +00:00
hostip.h Compilation fix 2006-09-08 05:18:07 +00:00
hostsyn.c Simplify check for NEED_MALLOC_H, and make more explicit that NEED_MALLOC_H shall be defined if <malloc.h> header file must be included even when including <stdlib.h>. 2006-07-25 13:49:49 +00:00
hostthre.c clear the struct size not the pointer size, pointed out in bug report 2006-10-17 20:34:11 +00:00
http_chunks.c Avoid typecasting a signed char to an int when using is*() functions, as that 2006-10-17 21:32:56 +00:00
http_chunks.h
http_digest.c Avoid typecasting a signed char to an int when using is*() functions, as that 2006-10-17 21:32:56 +00:00
http_digest.h Major overhaul introducing http pipelining support and shared connection 2006-09-07 21:49:20 +00:00
http_negotiate.c Avoid typecasting a signed char to an int when using is*() functions, as that 2006-10-17 21:32:56 +00:00
http_negotiate.h
http_ntlm.c prototype for gethostname is in unistd.h 2006-11-02 00:33:43 +00:00
http_ntlm.h
http.c Robson Braga Araujo reported bug #1618359 2006-12-21 10:15:38 +00:00
http.h Andrew Biggs pointed out a "Expect: 100-continue" flaw where libcurl didn't 2006-08-18 22:54:57 +00:00
if2ip.c updated copyright year 2006-10-25 07:19:45 +00:00
if2ip.h
inet_ntoa_r.h
inet_ntop.c Check for USE_WINSOCK instead of WIN32 where the check was done 2006-10-18 21:05:40 +00:00
inet_ntop.h
inet_pton.c Check for USE_WINSOCK instead of WIN32 where the check was done 2006-10-18 21:05:40 +00:00
inet_pton.h
krb4.c
krb4.h cleaned up Curl_write() and the sub functions it uses for various protocols. 2006-11-11 21:34:43 +00:00
ldap.c Make more human readable and maintainable previous 2006-10-29 14:58:59 +00:00
ldap.h
libcurl.def
libcurl.framework.make Nir Soffer updated libcurl.framework.make: fix symlinks, should link to 2006-11-09 21:58:28 +00:00
libcurl.imp
libcurl.plist
libcurl.rc
llist.c updated copyright year 2006-10-25 07:19:45 +00:00
llist.h
Makefile.am Support for FTP third party transfers is now dropped 2006-09-30 20:31:11 +00:00
makefile.amiga
Makefile.b32
makefile.dj Don't include zlib headers in dependency output. 2006-08-29 18:13:54 +00:00
Makefile.inc James Housley brought support for SCP transfers 2006-11-02 21:56:40 +00:00
Makefile.m32
Makefile.netware Define HAVE_SIGNAL_H, HAVE_SIG_ATOMIC_T and HAVE_SIG_ATOMIC_T_VOLATILE 2006-11-24 16:38:58 +00:00
Makefile.riscos
Makefile.vc6 Fix misplaced runtime library specification for 'release-dll' target 2006-10-21 16:25:31 +00:00
Makefile.Watcom Dmitriy Sergeyev provided a patch that made the SOCKS[45] code work better as 2006-09-23 19:07:20 +00:00
md5.c
md5.h
memdebug.c Prevent multiple initialization of memdebug configuration variables. 2006-11-05 12:42:50 +00:00
memdebug.h Update copyright year, since the file has been modified 2006-10-27 03:47:57 +00:00
memory.h
mprintf.c Avoid typecasting a signed char to an int when using is*() functions, as that 2006-10-17 21:32:56 +00:00
msvcproj.foot
msvcproj.head
multi.c Jared Lundell filed bug report #1604956 2006-12-05 15:36:26 +00:00
multiif.h Reported in #1561470 (http://curl.haxx.se/bug/view.cgi?id=1561470), libcurl 2006-09-28 21:26:06 +00:00
netrc.c
netrc.h
nwlib.c
parsedate.c Martin Skinner brought back bug report #1230118 to haunt us once again. 2006-12-05 14:57:43 +00:00
parsedate.h
progress.c Update copyright year, since the file has been modified 2006-10-27 03:47:57 +00:00
progress.h
README.ares Update the information about what c-ares version that's required. 1.3.1 had 2006-11-03 10:56:37 +00:00
README.curlx
README.encoding
README.hostip
README.httpauth
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 cleaned up Curl_write() and the sub functions it uses for various protocols. 2006-11-11 21:34:43 +00:00
select.c Matt Witherspoon fixed a problem case when the CPU load went to 100% when a 2006-12-05 13:37:05 +00:00
select.h Cory Nelson made libcurl use the WSAPoll() function if built for Windows 2006-09-24 10:41:00 +00:00
sendf.c Stefan Krause pointed out a compiler warning with a picky MSCV compiler when 2006-12-05 21:40:14 +00:00
sendf.h Update copyright year, since the file has been modified 2006-10-27 03:47:57 +00:00
setup_once.h recv() doesn't take MSG_NOSIGNAL in its forth argument so let's not pass it. 2006-12-16 22:28:08 +00:00
setup.h Introduce symbol USE_WINSOCK which will be defined when 2006-10-18 15:57:49 +00:00
share.c
share.h Added support for Salford-C under Win32 (scc). HAVE_MALLOC_H and 2006-04-26 17:11:05 +00:00
sockaddr.h
socks.c Compiler warning fix 2006-10-27 02:18:29 +00:00
socks.h standard curl source code headers 2006-09-23 19:09:39 +00:00
speedcheck.c make the low_speed check set the expire timer so that it has a chance to work 2006-10-17 09:05:44 +00:00
speedcheck.h
splay.c Jari Sundell's minor cleanup, added comments and some extra error-checkings 2006-09-04 22:19:13 +00:00
splay.h don't use 'new' in the proto 2006-07-15 18:57:51 +00:00
ssh.c James Housley fixed SCP downloading by setting the maxdownload. 2006-11-25 09:49:29 +00:00
ssh.h James Housley did lots of work and introduced SFTP downloads. 2006-11-24 22:14:39 +00:00
sslgen.c Brendan Jurd pointed out these typos 2006-12-16 21:05:33 +00:00
sslgen.h cleaned up Curl_write() and the sub functions it uses for various protocols. 2006-11-11 21:34:43 +00:00
ssluse.c cleaned up Curl_write() and the sub functions it uses for various protocols. 2006-11-11 21:34:43 +00:00
ssluse.h fix header to match actual proto 2006-11-11 22:05:33 +00:00
strdup.c Return NULL if argument is NULL. 2006-07-17 15:25:37 +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 Update copyright year, since the file has been modified 2006-10-27 03:47:57 +00:00
strequal.h
strerror.c James Housley brought support for SCP transfers 2006-11-02 21:56:40 +00:00
strerror.h
strtok.c
strtok.h
strtoofft.c Avoid typecasting a signed char to an int when using is*() functions, as that 2006-10-17 21:32:56 +00:00
strtoofft.h
telnet.c Fix copy-paste error 2006-10-21 12:36:10 +00:00
telnet.h
tftp.c Ciprian Badescu found a SIGSEGV when doing multiple TFTP transfers using the 2006-11-09 21:36:18 +00:00
tftp.h
timeval.c
timeval.h Update copyright year, since the file has been modified 2006-10-27 03:47:57 +00:00
transfer.c Robson Braga Araujo reported bug #1618359 2006-12-21 10:15:38 +00:00
transfer.h Update copyright year, since the file has been modified 2006-10-27 03:47:57 +00:00
url.c Robson Braga Araujo reported bug #1618359 2006-12-21 10:15:38 +00:00
url.h Jared Lundell filed bug report #1604956 2006-12-05 15:36:26 +00:00
urldata.h Robson Braga Araujo reported bug #1618359 2006-12-21 10:15:38 +00:00
vc8proj.foot Michael Jerris added magic that builds lib/curllib.vcproj automatically (for 2006-07-25 22:06:42 +00:00
vc8proj.head Michael Jerris added magic that builds lib/curllib.vcproj automatically (for 2006-07-25 22:06:42 +00:00
version.c James Housley did lots of work and introduced SFTP downloads. 2006-11-24 22:14:39 +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.