curl/lib
Yang Tse 66fb9ca5f6 For congruency sake with the naming of other CURL_XXXXXX_CURL_OFF_T macros,
the names of the curl_off_t formatting string directives now become
CURL_FORMAT_CURL_OFF_T and CURL_FORMAT_CURL_OFF_TU.

CURL_FMT_OFF_T  -> CURL_FORMAT_CURL_OFF_T
CURL_FMT_OFF_TU -> CURL_FORMAT_CURL_OFF_TU

Remove the use of an internal name for the curl_off_t formatting string directives
and use the common one available from the inside and outside of the library.

FORMAT_OFF_T  -> CURL_FORMAT_CURL_OFF_T
FORMAT_OFF_TU -> CURL_FORMAT_CURL_OFF_TU
2008-08-15 02:58:15 +00:00
..
.cvsignore ignore *.dist files 2008-07-29 02:05:07 +00:00
Makefile.Watcom Remved '-dDEBUG_THREADING_GETADDRINFO' (no longer used). 2008-08-13 08:19:51 +00:00
Makefile.am Initial support of curlbuild.h and curlrules.h which allows 2008-08-07 00:29:08 +00:00
Makefile.b32
Makefile.inc Removed the generated ca-bundle.h file. The verbatim value of $ca and 2008-03-31 12:09:43 +00:00
Makefile.m32 Internal time differences now use monotonic time source if available. 2008-05-09 16:31:51 +00:00
Makefile.netware For congruency sake with the naming of other CURL_XXXXXX_CURL_OFF_T macros, 2008-08-15 02:58:15 +00:00
Makefile.riscos
Makefile.vc6 Internal time differences now use monotonic time source if available. 2008-05-09 16:31:51 +00:00
README.NSS Added README.NSS to describe the current NSS situation. 2008-06-24 08:52:35 +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
amigaos.c proper symbol definition check for all AmigaOS flavours 2007-02-28 14:45:48 +00:00
amigaos.h proper symbol definition check for all AmigaOS flavours 2007-02-28 14:45:48 +00:00
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 - David McCreedy made changes to allow base64 encoding/decoding to work on 2007-01-03 23:04:38 +00:00
config-amigaos.h Initial support of curlbuild.h and curlrules.h which allows 2008-08-07 00:29:08 +00:00
config-mac.h when recvfrom prototype uses a void pointer for arguments 2, 5 or 6 this will 2008-07-21 00:36:55 +00:00
config-os400.h Initial support of curlbuild.h and curlrules.h which allows 2008-08-07 00:29:08 +00:00
config-riscos.h when recvfrom prototype uses a void pointer for arguments 2, 5 or 6 this will 2008-07-21 00:36:55 +00:00
config-symbian.h The size of long is a build time characteristic and as such it is now recorded 2008-08-13 15:32:20 +00:00
config-tpf.h The size of long is a build time characteristic and as such it is now recorded 2008-08-13 15:32:20 +00:00
config-win32.h Initial support of curlbuild.h and curlrules.h which allows 2008-08-07 00:29:08 +00:00
config-win32ce.h Initial support of curlbuild.h and curlrules.h which allows 2008-08-07 00:29:08 +00:00
config.dos Initial support of curlbuild.h and curlrules.h which allows 2008-08-07 00:29:08 +00:00
connect.c - Phil Blundell added the CURLOPT_SCOPE option, as well as adjusted the URL 2008-07-30 21:55:26 +00:00
connect.h - Introducing curl_easy_send() and curl_easy_recv(). They can be used to send 2008-05-12 21:43:24 +00:00
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 Added missing multiple header inclusion prevention definition 2008-07-11 18:42:30 +00:00
cookie.c For congruency sake with the naming of other CURL_XXXXXX_CURL_OFF_T macros, 2008-08-15 02:58:15 +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 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 - Constantine Sapuntzakis filed bug report #2042430 2008-08-11 20:29:36 +00:00
easyif.h
escape.c if () => if() 2007-11-07 09:21:35 +00:00
escape.h
file.c For congruency sake with the naming of other CURL_XXXXXX_CURL_OFF_T macros, 2008-08-15 02:58:15 +00:00
file.h Fixed an OOM problem with file: URLs 2007-10-30 23:00:40 +00:00
formdata.c For congruency sake with the naming of other CURL_XXXXXX_CURL_OFF_T macros, 2008-08-15 02:58:15 +00:00
formdata.h - Added CURLFORM_STREAM as a supported option to curl_formadd() to allow an 2008-03-31 10:02:23 +00:00
ftp.c For congruency sake with the naming of other CURL_XXXXXX_CURL_OFF_T macros, 2008-08-15 02:58:15 +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 Introcuding a new timestamp for curl_easy_getinfo(): 2008-07-03 06:56:03 +00:00
getinfo.h
gtls.c fix warning in GnuTLS build by making sure Curl_gtls_send() takes a const 2008-06-10 21:53:59 +00:00
gtls.h - I did a cleanup of the internal generic SSL layer and how the various SSL 2008-06-11 17:01: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 - Andreas Schuldei improved Phil Blundell's patch for IPv6 using c-ares, and I 2008-07-09 18:39:49 +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
hostip.c - Andreas Schuldei improved Phil Blundell's patch for IPv6 using c-ares, and I 2008-07-09 18:39:49 +00:00
hostip.h - Andreas Schuldei improved Phil Blundell's patch for IPv6 using c-ares, and I 2008-07-09 18:39:49 +00:00
hostip4.c - Andreas Schuldei improved Phil Blundell's patch for IPv6 using c-ares, and I 2008-07-09 18:39:49 +00:00
hostip6.c Eliminate a unnecessary socket creation in Curl_getaddrinfo for an IPv4 2008-07-27 02:20:34 +00:00
hostsyn.c update copyright year 2007-04-03 18:25:18 +00:00
hostthre.c Removed TRACE() code. 2008-08-06 08:05:09 +00:00
http.c For congruency sake with the naming of other CURL_XXXXXX_CURL_OFF_T macros, 2008-08-15 02:58:15 +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
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 - Ravi Pratap provided work on libcurl making pipelining more robust and 2007-02-21 21:59:40 +00:00
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 David Rosenstrauch reported that header files spnegohelp.h and 2008-05-26 03:10:34 +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 - Constantine Sapuntzakis filed bug report #2042430 2008-08-11 20:29:36 +00:00
http_ntlm.h - Constantine Sapuntzakis filed bug report #2042430 2008-08-11 20:29:36 +00:00
if2ip.c Support Open Watcom C on Linux (as well as Windows). 2008-07-02 18:34:00 +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 - Make Curl_write and it's callees accept a const pointer, in preparation 2008-05-09 11:27:54 +00:00
krb4.h - Make Curl_write and it's callees accept a const pointer, in preparation 2008-05-09 11:27:54 +00:00
krb5.c Fixed some include file problems on Windows reported by David Rosenstrauch 2008-05-22 19:44:10 +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.amiga
makefile.dj Added TOPDIR variable. Put dependencies in external file. 2007-02-27 15:24:32 +00:00
md5.c if () => if() 2007-11-07 09:21:35 +00:00
md5.h
memdebug.c Move the CURLDEBUG check after setup.h so it can be set there if necessary. 2008-05-14 23:36:26 +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
mk-ca-bundle.pl fixed version var. 2008-02-15 00:41:54 +00:00
mprintf.c s/SIZEOF_CURL_OFF_T/CURL_SIZEOF_CURL_OFF_T/g 2008-08-11 01:22:57 +00:00
msvcproj.foot
msvcproj.head Internal time differences now use monotonic time source if available. 2008-05-09 16:31:51 +00:00
multi.c Fixed an uninitialized variable in multi_runsingle() that could cause a 2008-08-08 01:52:08 +00:00
multiif.h Fixed some minor mismatched types found by splint. 2007-08-26 05:53:26 +00:00
netrc.c Made a parameter const 2008-08-01 00:49:29 +00:00
netrc.h Made a parameter const 2008-08-01 00:49:29 +00:00
nss.c made Curl_nss_send() take const data to kill compiler warning 2008-06-21 21:19:42 +00:00
nssg.h made Curl_nss_send() take const data to kill compiler warning 2008-06-21 21:19:42 +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 Stopped using ranges in scanf character sequences (e.g. %[a-z]) since that 2008-06-22 06:57:00 +00:00
parsedate.h fix multiple header inclusion prevention definition 2008-07-11 18:59:00 +00:00
progress.c For congruency sake with the naming of other CURL_XXXXXX_CURL_OFF_T macros, 2008-08-15 02:58:15 +00:00
progress.h Introcuding a new timestamp for curl_easy_getinfo(): 2008-07-03 06:56:03 +00:00
qssl.c Adapting last changes to OS400: 2008-05-20 10:21:50 +00:00
qssl.h New options added to OS400 wrapper and ILERPG definitions. 2008-07-07 10:39:46 +00:00
security.c fix: preprocessor complaining about macro redefinition 2008-05-26 01:59:00 +00:00
select.c Andreas Faerber and Scott McCreary made (lib)curl build for the Haiku OS 2008-05-26 15:09:28 +00:00
select.h Peter Lamberg filed bug report #2015126: "poll gives WSAEINVAL when POLLPRI 2008-07-10 18:01:44 +00:00
sendf.c - Hans-Jurgen May pointed out that trying SCP or SFTP over a SOCKS proxy 2008-06-20 10:43:32 +00:00
sendf.h - Hans-Jurgen May pointed out that trying SCP or SFTP over a SOCKS proxy 2008-06-20 10:43:32 +00:00
setup-os400.h minor reordering in OS/400 config/setup files 2008-07-22 00:12:06 +00:00
setup.h For congruency sake with the naming of other CURL_XXXXXX_CURL_OFF_T macros, 2008-08-15 02:58:15 +00:00
setup_once.h Change recvfrom's sixth argument data type to the 'historically standard' 'int' 2008-07-21 18:24:32 +00:00
share.c - Added curl_easy_getinfo typechecker. 2008-03-18 08:14:37 +00:00
share.h
sockaddr.h
socks.c - Hans-Jurgen May pointed out that trying SCP or SFTP over a SOCKS proxy 2008-06-20 10:43:32 +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 fix compiler warning: format '%ld' expects type 'long int' 2008-05-08 05:45:01 +00:00
splay.h Christopher Palow provided the patch (edited by me) that introduces 2008-05-07 15:41:41 +00:00
ssh.c For congruency sake with the naming of other CURL_XXXXXX_CURL_OFF_T macros, 2008-08-15 02:58:15 +00:00
ssh.h remove leftover proto that isn't used, I made it a macro instead 2008-06-20 10:45:26 +00:00
sslgen.c Introcuding a new timestamp for curl_easy_getinfo(): 2008-07-03 06:56:03 +00:00
sslgen.h fix compiler warning: empty body in an if-statement 2008-07-05 03:31:41 +00:00
ssluse.c - PHP's bug report #43158 (http://bugs.php.net/bug.php?id=43158) identifies a 2008-07-30 21:24:59 +00:00
ssluse.h - I did a cleanup of the internal generic SSL layer and how the various SSL 2008-06-11 17:01:58 +00:00
strdup.c Fix problem in strdup replacement when dealing with absolutely huge strings. 2008-02-06 19:01:13 +00:00
strdup.h move multiple header inclusion prevention definition to top of file 2008-07-11 18:52:35 +00:00
strequal.c if () => if() 2007-11-07 09:21:35 +00:00
strequal.h
strerror.c - Axel Tillequin and Arnaud Ebalard added support for CURLOPT_ISSUERCERT, for 2008-06-06 20:52:32 +00:00
strerror.h
strtok.c if () => if() 2007-11-07 09:21:35 +00:00
strtok.h move multiple header inclusion prevention definition to top of file 2008-07-11 18:52:35 +00:00
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 When using our internal curlx_strtoll function NEED_CURL_STRTOLL must be defined, 2008-08-14 11:56:55 +00:00
telnet.c Fixed a problem where telnet data would be lost if an EWOULDBLOCK 2008-06-03 18:03:11 +00:00
telnet.h Added per-protocol callback static tables, replacing callback ptr storage 2007-10-12 13:36:37 +00:00
tftp.c Undo using the sreadfrom() wrapper to replace recvfrom() in our code. 2008-07-30 05:10:42 +00:00
tftp.h Added per-protocol callback static tables, replacing callback ptr storage 2007-10-12 13:36:37 +00:00
timeval.c fallback to gettimeofday when monotonic clock is unavailable at run-time 2008-07-02 03:04:56 +00:00
timeval.h update copyright year 2007-04-03 18:25:18 +00:00
transfer.c For congruency sake with the naming of other CURL_XXXXXX_CURL_OFF_T macros, 2008-08-15 02:58:15 +00:00
transfer.h - To make it easier for applications that want lots of magic stuff done on 2008-04-30 21:20:08 +00:00
url.c For congruency sake with the naming of other CURL_XXXXXX_CURL_OFF_T macros, 2008-08-15 02:58:15 +00:00
url.h provide CURL_DEFAULT_PROXY_PORT set to 1080 for the default port libcurl 2008-04-05 21:13:31 +00:00
urldata.h - Phil Blundell added the CURLOPT_SCOPE option, as well as adjusted the URL 2008-07-30 21:55:26 +00:00
vc8proj.foot Use DOS line-endings. 2007-01-29 19:08:04 +00:00
vc8proj.head Use DOS line-endings. 2007-01-29 19:08:04 +00:00
version.c s/SIZEOF_CURL_OFF_T/CURL_SIZEOF_CURL_OFF_T/g 2008-08-11 01:22:57 +00:00

README.pipelining

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.