]> granicus.if.org Git - curl/commitdiff
Dan Fandrich changed CURLOPT_ENCODING to select all supported encodings if
authorDaniel Stenberg <daniel@haxx.se>
Mon, 12 May 2003 12:45:14 +0000 (12:45 +0000)
committerDaniel Stenberg <daniel@haxx.se>
Mon, 12 May 2003 12:45:14 +0000 (12:45 +0000)
 set to "".  This frees the application from having to know which encodings
 the library supports.

lib/README.encoding
lib/content_encoding.h
lib/transfer.c
lib/url.c

index 5f878038eb5f7bb378b45053b6e228b23e5ea3d8..d81cf50fe517c1d23c7bee3d3bda80f741c315f8 100644 (file)
@@ -42,7 +42,9 @@ Currently, libcurl only understands how to process responses that use the
 that will work (besides "identity," which does nothing) are "deflate" and
 "gzip" If a response is encoded using the "compress" or methods, libcurl will
 return an error indicating that the response could not be decoded.  If
-<string> is NULL or empty no Accept-Encoding header is generated.
+<string> is NULL no Accept-Encoding header is generated.  If <string> is a
+zero-length string, then an Accept-Encoding header containing all supported
+encodings will be generated.
 
 The CURLOPT_ENCODING must be set to any non-NULL value for content to be
 automatically decoded.  If it is not set and the server still sends encoded
index 348ceb154f5213525c42a80f3f327a85831c32fc..dfc7097c4ad142204ee001d18ac4803ab5f55a75 100644 (file)
  *
  * $Id$
  ***************************************************************************/
+#include "setup.h"
+
+/*
+ * Comma-separated list all supported Content-Encodings ('identity' is implied)
+ */
+#ifdef HAVE_LIBZ
+#define ALL_CONTENT_ENCODINGS "deflate, gzip"
+#else
+#define ALL_CONTENT_ENCODINGS "identity"
+#endif
 
 CURLcode Curl_unencode_deflate_write(struct SessionHandle *data, 
                                      struct Curl_transfer_keeper *k, 
index c5c2787a223bfa59be471c831813c31a2f1f6e64..9befa5585b45d88953c5b1db1544b6a31e98d8af 100644 (file)
@@ -893,7 +893,9 @@ CURLcode Curl_readwrite(struct connectdata *conn,
             if(k->badheader < HEADER_ALLBAD) {
               /* This switch handles various content encodings. If there's an
                  error here, be sure to check over the almost identical code
-                 in http_chunks.c. 08/29/02 jhrg */
+                 in http_chunks.c. 08/29/02 jhrg
+                 Make sure that ALL_CONTENT_ENCODINGS contains all the
+                 encodings handled here. */
 #ifdef HAVE_LIBZ
               switch (k->content_encoding) {
               case IDENTITY:
index 0cb690c0ce7b9b4179bd8cb4a120b07bfd98fb12..64d4c2a2df891214e9dcc57e009d2c4c8c253cfe 100644 (file)
--- a/lib/url.c
+++ b/lib/url.c
 #include "escape.h"
 #include "strtok.h"
 #include "share.h"
+#include "content_encoding.h"
 
 /* And now for the protocols */
 #include "ftp.h"
@@ -825,8 +826,16 @@ CURLcode Curl_setopt(struct SessionHandle *data, CURLoption option, ...)
   case CURLOPT_ENCODING:
     /*
      * String to use at the value of Accept-Encoding header. 08/28/02 jhrg
+     *
+     * If the encoding is set to "" we use an Accept-Encoding header that
+     * encompasses all the encodings we support.
+     * If the encoding is set to NULL we don't send an Accept-Encoding header
+     * and ignore an received Content-Encoding header.
+     *
      */
     data->set.encoding = va_arg(param, char *);
+    if(data->set.encoding && !*data->set.encoding)
+      data->set.encoding = (char*)ALL_CONTENT_ENCODINGS;
     break;
 
   case CURLOPT_USERPWD: