curl/lib
Daniel Stenberg e01b7c1ede - Bug report #2709004 (http://curl.haxx.se/bug/view.cgi?id=2709004) by Tim
Chen pointed out how curl couldn't upload with resume when reading from a
  pipe.

  This ended up with the introduction of a new return code for the
  CURLOPT_SEEKFUNCTION callback that basically says that the seek failed but
  that libcurl may try to resolve the situation anyway. In our case this means
  libcurl will attempt to instead read that much data from the stream instead
  of seeking and that way curl can now upload with resume when data is read
  from a stream!
2009-04-28 11:19:10 +00:00
..
.cvsignore - I renamed everything in the windows builds files that used the name 'curllib' 2009-02-23 09:36:54 +00:00
amigaos.c Indentation fixes, untabify and related whitespace-cleanup. No code changed. 2009-02-27 08:53:10 +00:00
amigaos.h ntoa() and inet_ntoa_r() no longer used 2008-09-24 12:22:16 +00:00
arpa_telnet.h
base64.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
CMakeLists.txt Fixed compile defines in CMake scripts 2009-04-08 11:42:45 +00:00
config-amigaos.h Refactor configure script detection of functions used to set sockets into 2008-11-13 18:56:55 +00:00
config-mac.h Refactor configure script detection of functions used to set sockets into 2008-11-13 18:56:55 +00:00
config-os400.h changed HAVE_SIN6_SCOPE_ID define to HAVE_SOCKADDR_IN6_SIN6_SCOPE_ID since just found that ares already uses this define. 2008-12-30 08:05:38 +00:00
config-riscos.h changed HAVE_SIN6_SCOPE_ID define to HAVE_SOCKADDR_IN6_SIN6_SCOPE_ID since just found that ares already uses this define. 2008-12-30 08:05:38 +00:00
config-symbian.h Added new libcurl source files to Symbian OS build files. 2009-04-11 07:06:34 +00:00
config-tpf.h changed HAVE_SIN6_SCOPE_ID define to HAVE_SOCKADDR_IN6_SIN6_SCOPE_ID since just found that ares already uses this define. 2008-12-30 08:05:38 +00:00
config-win32.h use HAVE_LIMITS_H symbol to protect limits.h inclusion 2009-04-14 13:50:32 +00:00
config-win32ce.h use HAVE_LIMITS_H symbol to protect limits.h inclusion 2009-04-14 13:50:32 +00:00
config.dos Added HAVE_LIMITS_H. 2009-04-18 16:50:09 +00:00
config.h.cmake Cleaned up the custom definition I added (replaced by CURL_STATICLIB) 2009-04-09 19:59:38 +00:00
connect.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
connect.h - Bug #2218480 (http://curl.haxx.se/bug/view.cgi?id=2218480) pointed out a 2008-11-03 16:24:56 +00:00
content_encoding.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
content_encoding.h
cookie.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
cookie.h Indentation fixes, untabify and related whitespace-cleanup. No code changed. 2009-02-27 08:53:10 +00:00
curl_addrinfo.c Further narrow the use of the icc 9.1 optimizer workaround. 2009-04-25 10:24:11 +00:00
curl_addrinfo.h Merged existing IPv4 and IPv6 Curl_ip2addr functions into a single one 2008-11-06 17:19:56 +00:00
curl_base64.h libcurl internal base64.h header file renamed to curl_base64.h 2008-08-17 00:25:38 +00:00
curl_ldap.h
curl_md5.h libcurl internal md5.h header file renamed to curl_md5.h 2008-08-17 00:01:26 +00:00
curl_memory.h libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
curl_sspi.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
curl_sspi.h Provide another definition missing in MinGW's headers 2009-01-30 01:37:37 +00:00
curlx.h Renamed Curl_ascii_equal to Curl_raw_equal and bugfixed the my_toupper function 2008-10-16 08:23:48 +00:00
dict.c - Using the libssh2 0.19 function libssh2_session_block_directions(), libcurl 2008-12-19 21:14:52 +00:00
dict.h
easy.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
easyif.h
escape.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
escape.h
file.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
file.h
firefox-db2pem.sh - Running 'make ca-firefox' in the root build dir will now run the new 2008-08-23 22:02:41 +00:00
formdata.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
formdata.h
ftp.c - Bug report #2709004 (http://curl.haxx.se/bug/view.cgi?id=2709004) by Tim 2009-04-28 11:19:10 +00:00
ftp.h
getenv.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
getinfo.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
getinfo.h
gtls.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
gtls.h Added support for Digest and NTLM authentication using GnuTLS. 2009-02-12 20:48:40 +00:00
hash.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
hash.h
hostares.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
hostasyn.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
hostip4.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
hostip6.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
hostip.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
hostip.h Merged existing IPv4 and IPv6 Curl_ip2addr functions into a single one 2008-11-06 17:19:56 +00:00
hostsyn.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
hostthre.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
http_chunks.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
http_chunks.h
http_digest.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
http_digest.h
http_negotiate.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
http_negotiate.h
http_ntlm.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
http_ntlm.h Indentation fixes, untabify and related whitespace-cleanup. No code changed. 2009-02-27 08:53:10 +00:00
http.c - Bug report #2709004 (http://curl.haxx.se/bug/view.cgi?id=2709004) by Tim 2009-04-28 11:19:10 +00:00
http.h - Test cases 1051, 1052 and 1055 were added by Daniel Fandrich on July 30 and 2008-08-04 22:00:22 +00:00
if2ip.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
if2ip.h the IP address we want/request/use from the interface is the 'local' 2008-11-17 19:08:35 +00:00
inet_ntop.c Remove usage of inet_ntoa and inet_ntoa_r 2008-09-23 19:17:19 +00:00
inet_ntop.h
inet_pton.c backport fix for failures to reject certain malformed literals 2008-11-17 02:40:41 +00:00
inet_pton.h HAVE_INET_PTON will only be defined when an IPv6 capable working 2008-09-24 19:13:01 +00:00
krb4.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
krb4.h
krb5.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
ldap.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
libcurl.def
libcurl.dsw - I renamed everything in the windows builds files that used the name 'curllib' 2009-02-23 09:36:54 +00:00
libcurl.imp
libcurl.plist
libcurl.rc
llist.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
llist.h
Makefile.am Add missing cmake files to the tarball (thanks to Richard Atterer's report) 2009-04-27 12:26:41 +00:00
makefile.amiga Added new libcurl source files to Amiga, RiscOS and VC6 build files. 2009-04-23 04:12:04 +00:00
Makefile.b32
makefile.dj Added rule to generate '../include/curl/curlbuild.h'. 2008-08-21 13:51:07 +00:00
Makefile.inc libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
Makefile.m32 some minor Makefile tweaks for latest libssh2. 2009-04-09 02:50:09 +00:00
Makefile.netware moved HAVE_LIMITS_H to common defines (no idea why I didnt this initially already) 2009-04-15 04:11:33 +00:00
Makefile.riscos Added new libcurl source files to Amiga, RiscOS and VC6 build files. 2009-04-23 04:12:04 +00:00
Makefile.vc6 Added new libcurl source files to Amiga, RiscOS and VC6 build files. 2009-04-23 04:12:04 +00:00
Makefile.Watcom libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
md5.c Added support for Digest and NTLM authentication using GnuTLS. 2009-02-12 20:48:40 +00:00
memdebug.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
memdebug.h Moved potential inclusion of system's malloc.h and memory.h header files to 2009-04-21 10:26:58 +00:00
mk-ca-bundle.pl removed obsolete slash in URL. 2008-08-23 21:31:09 +00:00
mprintf.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
msvcproj.foot This file must be kept in CVS with DOS style CR+LF line endings. 2008-08-28 03:31:54 +00:00
msvcproj.head - I renamed everything in the windows builds files that used the name 'curllib' 2009-02-23 09:36:54 +00:00
multi.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
multiif.h fix compiler warning: defined but not used 2008-09-13 15:59:14 +00:00
netrc.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
netrc.h Made a parameter const 2008-08-01 00:49:29 +00:00
nss.c - Kamil Dudka fixed another NSS-related leak when client certs were used. 2009-04-24 21:55:18 +00:00
nssg.h Forgot it's a struct 2008-10-17 22:33:08 +00:00
nwlib.c remove unnecessary typecasting of malloc() 2008-09-06 05:29:05 +00:00
nwos.c
parsedate.c moved the Curl_raw_ functions into the new lib/rawstr.c file for easier curlx_ 2008-10-23 11:49:19 +00:00
parsedate.h
progress.c fix compiler warning: explicit conversion of a 64-bit integral type to a smaller integral type 2008-10-11 01:56:04 +00:00
progress.h
qssl.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
qssl.h
rawstr.c Moved Curl_strntoupper() to the rawstr.c file where the other raw string 2009-02-07 22:53:37 +00:00
rawstr.h Moved Curl_strntoupper() to the rawstr.c file where the other raw string 2009-02-07 22:53:37 +00:00
README.ares
README.curl_off_t spell! (most of it fixed by Tor Arntsen) 2008-08-27 06:10:47 +00:00
README.curlx
README.encoding
README.hostip
README.httpauth
README.memoryleak
README.multi_socket
README.NSS
README.pipelining
security.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
select.c
select.h
sendf.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
sendf.h made Curl_read_plain() return an 'int' instead of CURLcode since it actually 2008-09-29 11:13:37 +00:00
setup_once.h Moved potential inclusion of system's malloc.h and memory.h header files to 2009-04-21 10:26:58 +00:00
setup-os400.h the IP address we want/request/use from the interface is the 'local' 2008-11-17 19:08:35 +00:00
setup.h Added support for Digest and NTLM authentication using GnuTLS. 2009-02-12 20:48:40 +00:00
share.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
share.h
slist.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
slist.h - Frank Hempel found out a bug and provided the fix: 2009-03-09 12:21:46 +00:00
sockaddr.h
socks_gssapi.c Moved potential inclusion of system's malloc.h and memory.h header files to 2009-04-21 10:26:58 +00:00
socks_sspi.c Moved potential inclusion of system's malloc.h and memory.h header files to 2009-04-21 10:26:58 +00:00
socks.c Moved potential inclusion of system's malloc.h and memory.h header files to 2009-04-21 10:26:58 +00:00
socks.h - Markus Moeller introduced two new options to libcurl: 2009-01-28 21:33:58 +00:00
speedcheck.c
speedcheck.h
splay.c make the debug/helper function output to stderr as that makes it play nicer 2008-12-20 21:48:34 +00:00
splay.h
ssh.c - Bug report #2709004 (http://curl.haxx.se/bug/view.cgi?id=2709004) by Tim 2009-04-28 11:19:10 +00:00
ssh.h Remove trailing #undef value. Typo? 2008-12-22 18:46:12 +00:00
sslgen.c - Bug report #2779733 (http://curl.haxx.se/bug/view.cgi?id=2779733) by Sven 2009-04-26 11:56:22 +00:00
sslgen.h - Rainer Canavan filed bug #2255627 2008-11-11 22:19:27 +00:00
ssluse.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
ssluse.h - Introducing CURLOPT_CERTINFO and the corresponding CURLINFO_CERTINFO. By 2008-09-05 14:29:21 +00:00
strdup.c remove unnecessary typecasting of malloc() 2008-09-06 05:29:05 +00:00
strdup.h
strequal.c moved the Curl_raw_ functions into the new lib/rawstr.c file for easier curlx_ 2008-10-23 11:49:19 +00:00
strequal.h moved the Curl_raw_ functions into the new lib/rawstr.c file for easier curlx_ 2008-10-23 11:49:19 +00:00
strerror.c ensure that errno is not modified inside Curl_strerror() 2008-09-12 10:51:57 +00:00
strerror.h
strtok.c
strtok.h
strtoofft.c
strtoofft.h MSVC's __int64 data type is only available when _INTEGRAL_MAX_BITS >= 64 2008-08-21 06:58:12 +00:00
telnet.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
telnet.h
tftp.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
tftp.h
timeval.c
timeval.h
transfer.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
transfer.h
url.c libcurl's memory.h renamed to curl_memory.h 2009-04-21 11:46:16 +00:00
url.h Moved Curl_strntoupper() to the rawstr.c file where the other raw string 2009-02-07 22:53:37 +00:00
urldata.h - Kamil Dudka fixed another NSS-related leak when client certs were used. 2009-04-24 21:55:18 +00:00
vc8proj.foot
vc8proj.head - I renamed everything in the windows builds files that used the name 'curllib' 2009-02-23 09:36:54 +00:00
version.c - Use libssh2_version() to present the libssh2 version in case the libssh2 2009-03-13 09:58:15 +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.