curl/lib
Daniel Stenberg 1048043963 - Lots of good work by Krister Johansen, mostly related to pipelining:
Fix SIGSEGV on free'd easy_conn when pipe unexpectedly breaks
  Fix data corruption issue with re-connected transfers
  Fix use after free if we're completed but easy_conn not NULL
2009-08-21 07:11:20 +00:00
..
.cvsignore renamed generated config.h to curl_config.h in order to avoid clashes when libcurl is used with other projects which also have a config.h. 2009-07-14 13:25:14 +00:00
amigaos.c
amigaos.h
arpa_telnet.h Update copyright year, to force CVS to update the $Id date string format 2009-05-18 12:25:45 +00:00
base64.c fix shadowing of a global declaration 2009-06-04 23:55:56 +00:00
CMakeLists.txt ENH: add optional support for c-ares 2009-07-14 19:03:31 +00:00
config-amigaos.h sclose() function-like macro definition used to close a socket, 2009-06-19 00:41:03 +00:00
config-mac.h renamed generated config.h to curl_config.h in order to avoid clashes when libcurl is used with other projects which also have a config.h. 2009-07-14 13:25:14 +00:00
config-os400.h
config-riscos.h renamed generated config.h to curl_config.h in order to avoid clashes when libcurl is used with other projects which also have a config.h. 2009-07-14 13:25:14 +00:00
config-symbian.h
config-tpf.h
config-vxworks.h allow building libcurl for VxWorks 2009-06-04 19:11:11 +00:00
config-win32.h
config-win32ce.h
config.dos sclose() function-like macro definition used to close a socket, 2009-06-19 00:41:03 +00:00
connect.c - Eric Wong introduced curlx_nonblock() that the curl tool now (re-)uses for 2009-07-09 21:47:24 +00:00
connect.h - Eric Wong introduced curlx_nonblock() that the curl tool now (re-)uses for 2009-07-09 21:47:24 +00:00
content_encoding.c - Balint Szilakszi reported a memory leak when libcurl did gzip decompression 2009-05-11 09:55:28 +00:00
content_encoding.h - Balint Szilakszi reported a memory leak when libcurl did gzip decompression 2009-05-11 09:55:28 +00:00
cookie.c DEBUGBUILD / CURLDEBUG decoupling follow-up 2009-06-15 02:29:49 +00:00
cookie.h
curl_addrinfo.c Fix type cast 2009-05-10 10:24:53 +00:00
curl_addrinfo.h
curl_base64.h fix shadowing of a global declaration 2009-06-04 23:55:56 +00:00
curl_config.h.cmake ENH: move config.h.cmake to curl_config.h.cmake so it builds again 2009-07-14 13:46:45 +00:00
curl_ldap.h
curl_md5.h
curl_memory.h
curl_sspi.c
curl_sspi.h
curlx.h - Eric Wong introduced curlx_nonblock() that the curl tool now (re-)uses for 2009-07-09 21:47:24 +00:00
dict.c - Fabian Keil ran clang on the (lib)curl code, found a bunch of warnings and 2009-06-10 21:26:11 +00:00
dict.h fix shadowing of a global declaration 2009-06-04 23:55:56 +00:00
easy.c Replaced use of standard C library rand()/srand() by our own pseudo-random number generator. 2009-06-15 10:15:28 +00:00
easyif.h
escape.c
escape.h
file.c allow building libcurl for VxWorks 2009-06-04 19:11:11 +00:00
file.h
firefox-db2pem.sh
formdata.c Replaced use of standard C library rand()/srand() by our own pseudo-random number generator. 2009-06-15 10:15:28 +00:00
formdata.h Replaced use of standard C library rand()/srand() by our own pseudo-random number generator. 2009-06-15 10:15:28 +00:00
ftp.c - Benbuck Nason posted the bug report #2835196 2009-08-11 20:43:12 +00:00
ftp.h
getenv.c
getinfo.c
getinfo.h Update copyright year, to force CVS to update the $Id date string format 2009-05-18 12:25:45 +00:00
gtls.c - Curt Bogmine reported a problem with SNI enabled on a particular server. We 2009-08-01 22:11:58 +00:00
gtls.h
hash.c Adjusted to take in account that... 2009-06-10 02:49:42 +00:00
hash.h
hostares.c
hostasyn.c
hostip4.c
hostip6.c
hostip.c
hostip.h
hostsyn.c
hostthre.c
http_chunks.c - Fabian Keil ran clang on the (lib)curl code, found a bunch of warnings and 2009-06-10 21:26:11 +00:00
http_chunks.h
http_digest.c Removed some obsolete digest code that caused a valgrind error in test 551. 2009-05-22 17:26:49 +00:00
http_digest.h
http_negotiate.c
http_negotiate.h
http_ntlm.c
http_ntlm.h
http.c - Constantine Sapuntzakis posted bug report #2813123 2009-07-08 07:00:40 +00:00
http.h
if2ip.c
if2ip.h
inet_ntop.c
inet_ntop.h fix cast for some systems which are broken due to absense of socklen_t, therefore now use curl_socklen_t. 2009-08-07 23:32:38 +00:00
inet_pton.c
inet_pton.h
krb4.c
krb4.h
krb5.c
ldap.c
libcurl.def
libcurl.imp added missing curl_easy_pause to export list. 2009-08-16 15:03:58 +00:00
libcurl.plist
libcurl.rc DEBUGBUILD / CURLDEBUG decoupling follow-up 2009-06-15 02:29:49 +00:00
llist.c
llist.h
Makefile.am renamed generated config.h to curl_config.h in order to avoid clashes when libcurl is used with other projects which also have a config.h. 2009-07-14 13:25:14 +00:00
makefile.amiga Added nonblock.c to the non-automake makefiles (note that the dependencies 2009-07-15 21:49:47 +00:00
Makefile.b32 Remove empty line used to force CVS to update the $Id date string format 2009-05-19 12:12:22 +00:00
makefile.dj renamed generated config.h to curl_config.h in order to avoid clashes when libcurl is used with other projects which also have a config.h. 2009-07-14 13:25:14 +00:00
Makefile.inc - Eric Wong introduced curlx_nonblock() that the curl tool now (re-)uses for 2009-07-09 21:47:24 +00:00
Makefile.m32 DEBUGBUILD / CURLDEBUG decoupling follow-up 2009-06-15 02:29:49 +00:00
Makefile.netware renamed generated config.h to curl_config.h in order to avoid clashes when libcurl is used with other projects which also have a config.h. 2009-07-14 13:25:14 +00:00
Makefile.riscos Added nonblock.c to the non-automake makefiles (note that the dependencies 2009-07-15 21:49:47 +00:00
Makefile.vc6 add missing file, as pointed out by Karl M 2009-08-12 17:25:16 +00:00
Makefile.vxworks Igor Novoseltsev adjusted Makefile.vxworks to get sources and headers 2009-06-08 15:49:02 +00:00
Makefile.Watcom Added nonblock.c to the non-automake makefiles (note that the dependencies 2009-07-15 21:49:47 +00:00
md5.c
memdebug.c
memdebug.h fixed typo. 2009-07-15 01:10:18 +00:00
mk-ca-bundle.pl
mprintf.c
msvcproj.foot
msvcproj.head
multi.c - Lots of good work by Krister Johansen, mostly related to pipelining: 2009-08-21 07:11:20 +00:00
multiif.h Adjusted to take in account that... 2009-06-10 02:49:42 +00:00
netrc.c Adjusted to take in account that... 2009-06-10 02:49:42 +00:00
netrc.h
nonblock.c add these new files to CVS as well 2009-07-09 21:55:26 +00:00
nonblock.h add these new files to CVS as well 2009-07-09 21:55:26 +00:00
nss.c - Changed NSS code to not ignore the value of ssl.verifyhost and produce more 2009-08-13 16:04:51 +00:00
nssg.h
nwlib.c
nwos.c
parsedate.c
parsedate.h
progress.c
progress.h
qssl.c
qssl.h
rawstr.c
rawstr.h
README.ares
README.curl_off_t
README.curlx Remove empty line used to force CVS to update the $Id date string format 2009-05-19 12:12:22 +00:00
README.encoding
README.hostip
README.httpauth
README.memoryleak
README.multi_socket
README.NSS
README.pipelining
security.c silence a compiler warning 2009-07-11 09:57:54 +00:00
select.c
select.h
sendf.c - Fabian Keil ran clang on the (lib)curl code, found a bunch of warnings and 2009-06-10 21:26:11 +00:00
sendf.h
setup_once.h sclose() function-like macro definition used to close a socket, 2009-06-19 00:41:03 +00:00
setup-os400.h
setup.h renamed generated config.h to curl_config.h in order to avoid clashes when libcurl is used with other projects which also have a config.h. 2009-07-14 13:25:14 +00:00
share.c
share.h
slist.c
slist.h
sockaddr.h Update copyright year, to force CVS to update the $Id date string format 2009-05-18 12:25:45 +00:00
socks_gssapi.c
socks_sspi.c
socks.c - Eric Wong introduced curlx_nonblock() that the curl tool now (re-)uses for 2009-07-09 21:47:24 +00:00
socks.h
speedcheck.c
speedcheck.h Update copyright year, to force CVS to update the $Id date string format 2009-05-18 12:25:45 +00:00
splay.c Adjusted to take in account that... 2009-06-10 02:49:42 +00:00
splay.h Adjusted to take in account that... 2009-06-10 02:49:42 +00:00
ssh.c blocked sshkeycallback() with HAVE_LIBSSH2_KNOWNHOST_API to avoid compiler warnings. 2009-07-23 02:15:00 +00:00
ssh.h changed ssh.c to use HAVE_LIBSSH2_SESSION_BLOCK_DIRECTION define provided by libssh2.h; removed related define block from ssh.h. 2009-05-19 23:21:25 +00:00
sslgen.c
sslgen.h
ssluse.c - Peter Sylvester made the HTTPS test server use specific certificates for 2009-08-11 21:48:58 +00:00
ssluse.h
strdup.c
strdup.h
strequal.c
strequal.h
strerror.c - Added CURLOPT_SSH_KNOWNHOSTS, CURLOPT_SSH_KEYFUNCTION, CURLOPT_SSH_KEYDATA. 2009-07-22 22:49:01 +00:00
strerror.h Update copyright year, to force CVS to update the $Id date string format 2009-05-18 12:25:45 +00:00
strtok.c
strtok.h
strtoofft.c
strtoofft.h
telnet.c
telnet.h
tftp.c - Carsten Lange reported a bug and provided a patch for TFTP upload and the 2009-08-12 08:19:39 +00:00
tftp.h
timeval.c
timeval.h
transfer.c - Lots of good work by Krister Johansen, mostly related to pipelining: 2009-08-21 07:11:20 +00:00
transfer.h - Lots of good work by Krister Johansen, mostly related to pipelining: 2009-08-21 07:11:20 +00:00
url.c - Lots of good work by Krister Johansen, mostly related to pipelining: 2009-08-21 07:11:20 +00:00
url.h - Constantine Sapuntzakis fixed bug report #2784055 2009-05-08 10:59:40 +00:00
urldata.h - Lots of good work by Krister Johansen, mostly related to pipelining: 2009-08-21 07:11:20 +00:00
vc6libcurl.dsw Fix CR 2009-05-08 19:09:36 +00:00
vc8proj.foot
vc8proj.head
version.c Adjusted to take in account that... 2009-06-10 02:49:42 +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.