aboutsummaryrefslogtreecommitdiffstats
path: root/contrib/libs/curl/lib/content_encoding.c
diff options
context:
space:
mode:
authordeshevoy <deshevoy@yandex-team.ru>2022-02-10 16:46:57 +0300
committerDaniil Cherednik <dcherednik@yandex-team.ru>2022-02-10 16:46:57 +0300
commit28148f76dbfcc644d96427d41c92f36cbf2fdc6e (patch)
treeb83306b6e37edeea782e9eed673d89286c4fef35 /contrib/libs/curl/lib/content_encoding.c
parente988f30484abe5fdeedcc7a5d3c226c01a21800c (diff)
downloadydb-28148f76dbfcc644d96427d41c92f36cbf2fdc6e.tar.gz
Restoring authorship annotation for <deshevoy@yandex-team.ru>. Commit 2 of 2.
Diffstat (limited to 'contrib/libs/curl/lib/content_encoding.c')
-rw-r--r--contrib/libs/curl/lib/content_encoding.c1336
1 files changed, 668 insertions, 668 deletions
diff --git a/contrib/libs/curl/lib/content_encoding.c b/contrib/libs/curl/lib/content_encoding.c
index 1f04d4ec06..68da3fa1cf 100644
--- a/contrib/libs/curl/lib/content_encoding.c
+++ b/contrib/libs/curl/lib/content_encoding.c
@@ -24,37 +24,37 @@
#include "urldata.h"
#include <curl/curl.h>
-#include <stddef.h>
-
-#ifdef HAVE_ZLIB_H
-#include <zlib.h>
-#endif
-
-#ifdef HAVE_BROTLI
-#error #include <brotli/decode.h>
-#endif
-
+#include <stddef.h>
+
+#ifdef HAVE_ZLIB_H
+#include <zlib.h>
+#endif
+
+#ifdef HAVE_BROTLI
+#error #include <brotli/decode.h>
+#endif
+
#ifdef HAVE_ZSTD
#error #include <zstd.h>
#endif
#include "sendf.h"
-#include "http.h"
+#include "http.h"
#include "content_encoding.h"
-#include "strdup.h"
-#include "strcase.h"
+#include "strdup.h"
+#include "strcase.h"
#include "curl_memory.h"
#include "memdebug.h"
-#define CONTENT_ENCODING_DEFAULT "identity"
-
-#ifndef CURL_DISABLE_HTTP
-
-#define DSIZ CURL_MAX_WRITE_SIZE /* buffer size for decompressed data */
-
-
-#ifdef HAVE_LIBZ
-
+#define CONTENT_ENCODING_DEFAULT "identity"
+
+#ifndef CURL_DISABLE_HTTP
+
+#define DSIZ CURL_MAX_WRITE_SIZE /* buffer size for decompressed data */
+
+
+#ifdef HAVE_LIBZ
+
/* Comment this out if zlib is always going to be at least ver. 1.2.0.4
(doing so will reduce code size slightly). */
#define OLD_ZLIB_SUPPORT 1
@@ -70,24 +70,24 @@
#define COMMENT 0x10 /* bit 4 set: file comment present */
#define RESERVED 0xE0 /* bits 5..7: reserved */
-typedef enum {
- ZLIB_UNINIT, /* uninitialized */
- ZLIB_INIT, /* initialized */
- ZLIB_INFLATING, /* inflating started. */
- ZLIB_EXTERNAL_TRAILER, /* reading external trailer */
- ZLIB_GZIP_HEADER, /* reading gzip header */
- ZLIB_GZIP_INFLATING, /* inflating gzip stream */
- ZLIB_INIT_GZIP /* initialized in transparent gzip mode */
-} zlibInitState;
-
-/* Writer parameters. */
+typedef enum {
+ ZLIB_UNINIT, /* uninitialized */
+ ZLIB_INIT, /* initialized */
+ ZLIB_INFLATING, /* inflating started. */
+ ZLIB_EXTERNAL_TRAILER, /* reading external trailer */
+ ZLIB_GZIP_HEADER, /* reading gzip header */
+ ZLIB_GZIP_INFLATING, /* inflating gzip stream */
+ ZLIB_INIT_GZIP /* initialized in transparent gzip mode */
+} zlibInitState;
+
+/* Writer parameters. */
struct zlib_params {
- zlibInitState zlib_init; /* zlib init state */
- uInt trailerlen; /* Remaining trailer byte count. */
- z_stream z; /* State structure for zlib. */
+ zlibInitState zlib_init; /* zlib init state */
+ uInt trailerlen; /* Remaining trailer byte count. */
+ z_stream z; /* State structure for zlib. */
};
-
-
+
+
static voidpf
zalloc_cb(voidpf opaque, unsigned int items, unsigned int size)
{
@@ -106,249 +106,249 @@ zfree_cb(voidpf opaque, voidpf ptr)
static CURLcode
process_zlib_error(struct connectdata *conn, z_stream *z)
{
- struct Curl_easy *data = conn->data;
+ struct Curl_easy *data = conn->data;
if(z->msg)
- failf(data, "Error while processing content unencoding: %s",
- z->msg);
+ failf(data, "Error while processing content unencoding: %s",
+ z->msg);
else
- failf(data, "Error while processing content unencoding: "
- "Unknown failure within decompression software.");
+ failf(data, "Error while processing content unencoding: "
+ "Unknown failure within decompression software.");
return CURLE_BAD_CONTENT_ENCODING;
}
static CURLcode
-exit_zlib(struct connectdata *conn,
- z_stream *z, zlibInitState *zlib_init, CURLcode result)
+exit_zlib(struct connectdata *conn,
+ z_stream *z, zlibInitState *zlib_init, CURLcode result)
{
- if(*zlib_init == ZLIB_GZIP_HEADER)
- Curl_safefree(z->next_in);
-
- if(*zlib_init != ZLIB_UNINIT) {
- if(inflateEnd(z) != Z_OK && result == CURLE_OK)
- result = process_zlib_error(conn, z);
- *zlib_init = ZLIB_UNINIT;
- }
-
+ if(*zlib_init == ZLIB_GZIP_HEADER)
+ Curl_safefree(z->next_in);
+
+ if(*zlib_init != ZLIB_UNINIT) {
+ if(inflateEnd(z) != Z_OK && result == CURLE_OK)
+ result = process_zlib_error(conn, z);
+ *zlib_init = ZLIB_UNINIT;
+ }
+
return result;
}
static CURLcode process_trailer(struct connectdata *conn,
struct zlib_params *zp)
{
- z_stream *z = &zp->z;
- CURLcode result = CURLE_OK;
- uInt len = z->avail_in < zp->trailerlen? z->avail_in: zp->trailerlen;
-
- /* Consume expected trailer bytes. Terminate stream if exhausted.
- Issue an error if unexpected bytes follow. */
-
- zp->trailerlen -= len;
- z->avail_in -= len;
- z->next_in += len;
- if(z->avail_in)
- result = CURLE_WRITE_ERROR;
- if(result || !zp->trailerlen)
- result = exit_zlib(conn, z, &zp->zlib_init, result);
- else {
- /* Only occurs for gzip with zlib < 1.2.0.4 or raw deflate. */
- zp->zlib_init = ZLIB_EXTERNAL_TRAILER;
- }
- return result;
-}
-
-static CURLcode inflate_stream(struct connectdata *conn,
+ z_stream *z = &zp->z;
+ CURLcode result = CURLE_OK;
+ uInt len = z->avail_in < zp->trailerlen? z->avail_in: zp->trailerlen;
+
+ /* Consume expected trailer bytes. Terminate stream if exhausted.
+ Issue an error if unexpected bytes follow. */
+
+ zp->trailerlen -= len;
+ z->avail_in -= len;
+ z->next_in += len;
+ if(z->avail_in)
+ result = CURLE_WRITE_ERROR;
+ if(result || !zp->trailerlen)
+ result = exit_zlib(conn, z, &zp->zlib_init, result);
+ else {
+ /* Only occurs for gzip with zlib < 1.2.0.4 or raw deflate. */
+ zp->zlib_init = ZLIB_EXTERNAL_TRAILER;
+ }
+ return result;
+}
+
+static CURLcode inflate_stream(struct connectdata *conn,
struct contenc_writer *writer,
zlibInitState started)
-{
+{
struct zlib_params *zp = (struct zlib_params *) &writer->params;
- z_stream *z = &zp->z; /* zlib state structure */
+ z_stream *z = &zp->z; /* zlib state structure */
uInt nread = z->avail_in;
Bytef *orig_in = z->next_in;
- bool done = FALSE;
+ bool done = FALSE;
CURLcode result = CURLE_OK; /* Curl_client_write status */
char *decomp; /* Put the decompressed data here. */
- /* Check state. */
- if(zp->zlib_init != ZLIB_INIT &&
- zp->zlib_init != ZLIB_INFLATING &&
- zp->zlib_init != ZLIB_INIT_GZIP &&
- zp->zlib_init != ZLIB_GZIP_INFLATING)
- return exit_zlib(conn, z, &zp->zlib_init, CURLE_WRITE_ERROR);
-
+ /* Check state. */
+ if(zp->zlib_init != ZLIB_INIT &&
+ zp->zlib_init != ZLIB_INFLATING &&
+ zp->zlib_init != ZLIB_INIT_GZIP &&
+ zp->zlib_init != ZLIB_GZIP_INFLATING)
+ return exit_zlib(conn, z, &zp->zlib_init, CURLE_WRITE_ERROR);
+
/* Dynamically allocate a buffer for decompression because it's uncommonly
large to hold on the stack */
decomp = malloc(DSIZ);
- if(decomp == NULL)
- return exit_zlib(conn, z, &zp->zlib_init, CURLE_OUT_OF_MEMORY);
+ if(decomp == NULL)
+ return exit_zlib(conn, z, &zp->zlib_init, CURLE_OUT_OF_MEMORY);
/* because the buffer size is fixed, iteratively decompress and transfer to
- the client via downstream_write function. */
- while(!done) {
- int status; /* zlib status */
- done = TRUE;
-
+ the client via downstream_write function. */
+ while(!done) {
+ int status; /* zlib status */
+ done = TRUE;
+
/* (re)set buffer for decompressed output for every iteration */
- z->next_out = (Bytef *) decomp;
+ z->next_out = (Bytef *) decomp;
z->avail_out = DSIZ;
-#ifdef Z_BLOCK
- /* Z_BLOCK is only available in zlib ver. >= 1.2.0.5 */
- status = inflate(z, Z_BLOCK);
-#else
- /* fallback for zlib ver. < 1.2.0.5 */
+#ifdef Z_BLOCK
+ /* Z_BLOCK is only available in zlib ver. >= 1.2.0.5 */
+ status = inflate(z, Z_BLOCK);
+#else
+ /* fallback for zlib ver. < 1.2.0.5 */
status = inflate(z, Z_SYNC_FLUSH);
-#endif
-
- /* Flush output data if some. */
- if(z->avail_out != DSIZ) {
- if(status == Z_OK || status == Z_STREAM_END) {
- zp->zlib_init = started; /* Data started. */
- result = Curl_unencode_write(conn, writer->downstream, decomp,
- DSIZ - z->avail_out);
+#endif
+
+ /* Flush output data if some. */
+ if(z->avail_out != DSIZ) {
+ if(status == Z_OK || status == Z_STREAM_END) {
+ zp->zlib_init = started; /* Data started. */
+ result = Curl_unencode_write(conn, writer->downstream, decomp,
+ DSIZ - z->avail_out);
if(result) {
- exit_zlib(conn, z, &zp->zlib_init, result);
- break;
+ exit_zlib(conn, z, &zp->zlib_init, result);
+ break;
}
}
- }
-
- /* Dispatch by inflate() status. */
- switch(status) {
- case Z_OK:
- /* Always loop: there may be unflushed latched data in zlib state. */
- done = FALSE;
- break;
- case Z_BUF_ERROR:
- /* No more data to flush: just exit loop. */
- break;
- case Z_STREAM_END:
- result = process_trailer(conn, zp);
- break;
- case Z_DATA_ERROR:
+ }
+
+ /* Dispatch by inflate() status. */
+ switch(status) {
+ case Z_OK:
+ /* Always loop: there may be unflushed latched data in zlib state. */
+ done = FALSE;
+ break;
+ case Z_BUF_ERROR:
+ /* No more data to flush: just exit loop. */
+ break;
+ case Z_STREAM_END:
+ result = process_trailer(conn, zp);
+ break;
+ case Z_DATA_ERROR:
/* some servers seem to not generate zlib headers, so this is an attempt
to fix and continue anyway */
- if(zp->zlib_init == ZLIB_INIT) {
- /* Do not use inflateReset2(): only available since zlib 1.2.3.4. */
- (void) inflateEnd(z); /* don't care about the return code */
- if(inflateInit2(z, -MAX_WBITS) == Z_OK) {
- z->next_in = orig_in;
- z->avail_in = nread;
- zp->zlib_init = ZLIB_INFLATING;
- zp->trailerlen = 4; /* Tolerate up to 4 unknown trailer bytes. */
- done = FALSE;
- break;
- }
- zp->zlib_init = ZLIB_UNINIT; /* inflateEnd() already called. */
+ if(zp->zlib_init == ZLIB_INIT) {
+ /* Do not use inflateReset2(): only available since zlib 1.2.3.4. */
+ (void) inflateEnd(z); /* don't care about the return code */
+ if(inflateInit2(z, -MAX_WBITS) == Z_OK) {
+ z->next_in = orig_in;
+ z->avail_in = nread;
+ zp->zlib_init = ZLIB_INFLATING;
+ zp->trailerlen = 4; /* Tolerate up to 4 unknown trailer bytes. */
+ done = FALSE;
+ break;
+ }
+ zp->zlib_init = ZLIB_UNINIT; /* inflateEnd() already called. */
}
- /* FALLTHROUGH */
- default:
- result = exit_zlib(conn, z, &zp->zlib_init, process_zlib_error(conn, z));
- break;
+ /* FALLTHROUGH */
+ default:
+ result = exit_zlib(conn, z, &zp->zlib_init, process_zlib_error(conn, z));
+ break;
}
}
- free(decomp);
-
- /* We're about to leave this call so the `nread' data bytes won't be seen
- again. If we are in a state that would wrongly allow restart in raw mode
- at the next call, assume output has already started. */
- if(nread && zp->zlib_init == ZLIB_INIT)
- zp->zlib_init = started; /* Cannot restart anymore. */
-
- return result;
+ free(decomp);
+
+ /* We're about to leave this call so the `nread' data bytes won't be seen
+ again. If we are in a state that would wrongly allow restart in raw mode
+ at the next call, assume output has already started. */
+ if(nread && zp->zlib_init == ZLIB_INIT)
+ zp->zlib_init = started; /* Cannot restart anymore. */
+
+ return result;
}
-
-/* Deflate handler. */
-static CURLcode deflate_init_writer(struct connectdata *conn,
+
+/* Deflate handler. */
+static CURLcode deflate_init_writer(struct connectdata *conn,
struct contenc_writer *writer)
{
struct zlib_params *zp = (struct zlib_params *) &writer->params;
- z_stream *z = &zp->z; /* zlib state structure */
-
- if(!writer->downstream)
- return CURLE_WRITE_ERROR;
-
- /* Initialize zlib */
- z->zalloc = (alloc_func) zalloc_cb;
- z->zfree = (free_func) zfree_cb;
-
- if(inflateInit(z) != Z_OK)
- return process_zlib_error(conn, z);
- zp->zlib_init = ZLIB_INIT;
- return CURLE_OK;
-}
-
-static CURLcode deflate_unencode_write(struct connectdata *conn,
+ z_stream *z = &zp->z; /* zlib state structure */
+
+ if(!writer->downstream)
+ return CURLE_WRITE_ERROR;
+
+ /* Initialize zlib */
+ z->zalloc = (alloc_func) zalloc_cb;
+ z->zfree = (free_func) zfree_cb;
+
+ if(inflateInit(z) != Z_OK)
+ return process_zlib_error(conn, z);
+ zp->zlib_init = ZLIB_INIT;
+ return CURLE_OK;
+}
+
+static CURLcode deflate_unencode_write(struct connectdata *conn,
struct contenc_writer *writer,
- const char *buf, size_t nbytes)
-{
+ const char *buf, size_t nbytes)
+{
struct zlib_params *zp = (struct zlib_params *) &writer->params;
- z_stream *z = &zp->z; /* zlib state structure */
-
+ z_stream *z = &zp->z; /* zlib state structure */
+
/* Set the compressed input when this function is called */
- z->next_in = (Bytef *) buf;
- z->avail_in = (uInt) nbytes;
+ z->next_in = (Bytef *) buf;
+ z->avail_in = (uInt) nbytes;
+
+ if(zp->zlib_init == ZLIB_EXTERNAL_TRAILER)
+ return process_trailer(conn, zp);
- if(zp->zlib_init == ZLIB_EXTERNAL_TRAILER)
- return process_trailer(conn, zp);
-
/* Now uncompress the data */
- return inflate_stream(conn, writer, ZLIB_INFLATING);
+ return inflate_stream(conn, writer, ZLIB_INFLATING);
}
-static void deflate_close_writer(struct connectdata *conn,
+static void deflate_close_writer(struct connectdata *conn,
struct contenc_writer *writer)
-{
+{
struct zlib_params *zp = (struct zlib_params *) &writer->params;
- z_stream *z = &zp->z; /* zlib state structure */
-
- exit_zlib(conn, z, &zp->zlib_init, CURLE_OK);
-}
-
+ z_stream *z = &zp->z; /* zlib state structure */
+
+ exit_zlib(conn, z, &zp->zlib_init, CURLE_OK);
+}
+
static const struct content_encoding deflate_encoding = {
- "deflate",
- NULL,
- deflate_init_writer,
- deflate_unencode_write,
- deflate_close_writer,
+ "deflate",
+ NULL,
+ deflate_init_writer,
+ deflate_unencode_write,
+ deflate_close_writer,
sizeof(struct zlib_params)
-};
-
-
-/* Gzip handler. */
-static CURLcode gzip_init_writer(struct connectdata *conn,
+};
+
+
+/* Gzip handler. */
+static CURLcode gzip_init_writer(struct connectdata *conn,
struct contenc_writer *writer)
-{
+{
struct zlib_params *zp = (struct zlib_params *) &writer->params;
- z_stream *z = &zp->z; /* zlib state structure */
-
- if(!writer->downstream)
- return CURLE_WRITE_ERROR;
-
- /* Initialize zlib */
- z->zalloc = (alloc_func) zalloc_cb;
- z->zfree = (free_func) zfree_cb;
-
- if(strcmp(zlibVersion(), "1.2.0.4") >= 0) {
- /* zlib ver. >= 1.2.0.4 supports transparent gzip decompressing */
- if(inflateInit2(z, MAX_WBITS + 32) != Z_OK) {
- return process_zlib_error(conn, z);
- }
- zp->zlib_init = ZLIB_INIT_GZIP; /* Transparent gzip decompress state */
- }
- else {
- /* we must parse the gzip header and trailer ourselves */
- if(inflateInit2(z, -MAX_WBITS) != Z_OK) {
- return process_zlib_error(conn, z);
- }
- zp->trailerlen = 8; /* A CRC-32 and a 32-bit input size (RFC 1952, 2.2) */
- zp->zlib_init = ZLIB_INIT; /* Initial call state */
- }
-
- return CURLE_OK;
-}
-
+ z_stream *z = &zp->z; /* zlib state structure */
+
+ if(!writer->downstream)
+ return CURLE_WRITE_ERROR;
+
+ /* Initialize zlib */
+ z->zalloc = (alloc_func) zalloc_cb;
+ z->zfree = (free_func) zfree_cb;
+
+ if(strcmp(zlibVersion(), "1.2.0.4") >= 0) {
+ /* zlib ver. >= 1.2.0.4 supports transparent gzip decompressing */
+ if(inflateInit2(z, MAX_WBITS + 32) != Z_OK) {
+ return process_zlib_error(conn, z);
+ }
+ zp->zlib_init = ZLIB_INIT_GZIP; /* Transparent gzip decompress state */
+ }
+ else {
+ /* we must parse the gzip header and trailer ourselves */
+ if(inflateInit2(z, -MAX_WBITS) != Z_OK) {
+ return process_zlib_error(conn, z);
+ }
+ zp->trailerlen = 8; /* A CRC-32 and a 32-bit input size (RFC 1952, 2.2) */
+ zp->zlib_init = ZLIB_INIT; /* Initial call state */
+ }
+
+ return CURLE_OK;
+}
+
#ifdef OLD_ZLIB_SUPPORT
/* Skip over the gzip header */
static enum {
@@ -387,7 +387,7 @@ static enum {
extra_len = (data[1] << 8) | data[0];
- if(len < (extra_len + 2))
+ if(len < (extra_len + 2))
return GZIP_UNDERFLOW;
len -= (extra_len + 2);
@@ -433,25 +433,25 @@ static enum {
}
#endif
-static CURLcode gzip_unencode_write(struct connectdata *conn,
+static CURLcode gzip_unencode_write(struct connectdata *conn,
struct contenc_writer *writer,
- const char *buf, size_t nbytes)
+ const char *buf, size_t nbytes)
{
struct zlib_params *zp = (struct zlib_params *) &writer->params;
- z_stream *z = &zp->z; /* zlib state structure */
+ z_stream *z = &zp->z; /* zlib state structure */
- if(zp->zlib_init == ZLIB_INIT_GZIP) {
+ if(zp->zlib_init == ZLIB_INIT_GZIP) {
/* Let zlib handle the gzip decompression entirely */
- z->next_in = (Bytef *) buf;
- z->avail_in = (uInt) nbytes;
+ z->next_in = (Bytef *) buf;
+ z->avail_in = (uInt) nbytes;
/* Now uncompress the data */
- return inflate_stream(conn, writer, ZLIB_INIT_GZIP);
+ return inflate_stream(conn, writer, ZLIB_INIT_GZIP);
}
#ifndef OLD_ZLIB_SUPPORT
/* Support for old zlib versions is compiled away and we are running with
an old version, so return an error. */
- return exit_zlib(conn, z, &zp->zlib_init, CURLE_WRITE_ERROR);
+ return exit_zlib(conn, z, &zp->zlib_init, CURLE_WRITE_ERROR);
#else
/* This next mess is to get around the potential case where there isn't
@@ -464,18 +464,18 @@ static CURLcode gzip_unencode_write(struct connectdata *conn,
* can handle the gzip header themselves.
*/
- switch(zp->zlib_init) {
+ switch(zp->zlib_init) {
/* Skip over gzip header? */
case ZLIB_INIT:
{
/* Initial call state */
ssize_t hlen;
- switch(check_gzip_header((unsigned char *) buf, nbytes, &hlen)) {
+ switch(check_gzip_header((unsigned char *) buf, nbytes, &hlen)) {
case GZIP_OK:
- z->next_in = (Bytef *) buf + hlen;
- z->avail_in = (uInt) (nbytes - hlen);
- zp->zlib_init = ZLIB_GZIP_INFLATING; /* Inflating stream state */
+ z->next_in = (Bytef *) buf + hlen;
+ z->avail_in = (uInt) (nbytes - hlen);
+ zp->zlib_init = ZLIB_GZIP_INFLATING; /* Inflating stream state */
break;
case GZIP_UNDERFLOW:
@@ -486,19 +486,19 @@ static CURLcode gzip_unencode_write(struct connectdata *conn,
* the first place, and it's even more unlikely for a transfer to fail
* immediately afterwards, it should seldom be a problem.
*/
- z->avail_in = (uInt) nbytes;
+ z->avail_in = (uInt) nbytes;
z->next_in = malloc(z->avail_in);
if(z->next_in == NULL) {
- return exit_zlib(conn, z, &zp->zlib_init, CURLE_OUT_OF_MEMORY);
+ return exit_zlib(conn, z, &zp->zlib_init, CURLE_OUT_OF_MEMORY);
}
- memcpy(z->next_in, buf, z->avail_in);
- zp->zlib_init = ZLIB_GZIP_HEADER; /* Need more gzip header data state */
+ memcpy(z->next_in, buf, z->avail_in);
+ zp->zlib_init = ZLIB_GZIP_HEADER; /* Need more gzip header data state */
/* We don't have any data to inflate yet */
return CURLE_OK;
case GZIP_BAD:
default:
- return exit_zlib(conn, z, &zp->zlib_init, process_zlib_error(conn, z));
+ return exit_zlib(conn, z, &zp->zlib_init, process_zlib_error(conn, z));
}
}
@@ -508,22 +508,22 @@ static CURLcode gzip_unencode_write(struct connectdata *conn,
{
/* Need more gzip header data state */
ssize_t hlen;
- z->avail_in += (uInt) nbytes;
- z->next_in = Curl_saferealloc(z->next_in, z->avail_in);
+ z->avail_in += (uInt) nbytes;
+ z->next_in = Curl_saferealloc(z->next_in, z->avail_in);
if(z->next_in == NULL) {
- return exit_zlib(conn, z, &zp->zlib_init, CURLE_OUT_OF_MEMORY);
+ return exit_zlib(conn, z, &zp->zlib_init, CURLE_OUT_OF_MEMORY);
}
/* Append the new block of data to the previous one */
- memcpy(z->next_in + z->avail_in - nbytes, buf, nbytes);
+ memcpy(z->next_in + z->avail_in - nbytes, buf, nbytes);
- switch(check_gzip_header(z->next_in, z->avail_in, &hlen)) {
+ switch(check_gzip_header(z->next_in, z->avail_in, &hlen)) {
case GZIP_OK:
/* This is the zlib stream data */
free(z->next_in);
/* Don't point into the malloced block since we just freed it */
- z->next_in = (Bytef *) buf + hlen + nbytes - z->avail_in;
- z->avail_in = (uInt) (z->avail_in - hlen);
- zp->zlib_init = ZLIB_GZIP_INFLATING; /* Inflating stream state */
+ z->next_in = (Bytef *) buf + hlen + nbytes - z->avail_in;
+ z->avail_in = (uInt) (z->avail_in - hlen);
+ zp->zlib_init = ZLIB_GZIP_INFLATING; /* Inflating stream state */
break;
case GZIP_UNDERFLOW:
@@ -532,22 +532,22 @@ static CURLcode gzip_unencode_write(struct connectdata *conn,
case GZIP_BAD:
default:
- return exit_zlib(conn, z, &zp->zlib_init, process_zlib_error(conn, z));
+ return exit_zlib(conn, z, &zp->zlib_init, process_zlib_error(conn, z));
}
}
break;
- case ZLIB_EXTERNAL_TRAILER:
- z->next_in = (Bytef *) buf;
- z->avail_in = (uInt) nbytes;
- return process_trailer(conn, zp);
-
+ case ZLIB_EXTERNAL_TRAILER:
+ z->next_in = (Bytef *) buf;
+ z->avail_in = (uInt) nbytes;
+ return process_trailer(conn, zp);
+
case ZLIB_GZIP_INFLATING:
default:
/* Inflating stream state */
- z->next_in = (Bytef *) buf;
- z->avail_in = (uInt) nbytes;
+ z->next_in = (Bytef *) buf;
+ z->avail_in = (uInt) nbytes;
break;
}
@@ -557,159 +557,159 @@ static CURLcode gzip_unencode_write(struct connectdata *conn,
}
/* We've parsed the header, now uncompress the data */
- return inflate_stream(conn, writer, ZLIB_GZIP_INFLATING);
+ return inflate_stream(conn, writer, ZLIB_GZIP_INFLATING);
#endif
}
-static void gzip_close_writer(struct connectdata *conn,
+static void gzip_close_writer(struct connectdata *conn,
struct contenc_writer *writer)
-{
+{
struct zlib_params *zp = (struct zlib_params *) &writer->params;
- z_stream *z = &zp->z; /* zlib state structure */
-
- exit_zlib(conn, z, &zp->zlib_init, CURLE_OK);
-}
-
+ z_stream *z = &zp->z; /* zlib state structure */
+
+ exit_zlib(conn, z, &zp->zlib_init, CURLE_OK);
+}
+
static const struct content_encoding gzip_encoding = {
- "gzip",
- "x-gzip",
- gzip_init_writer,
- gzip_unencode_write,
- gzip_close_writer,
+ "gzip",
+ "x-gzip",
+ gzip_init_writer,
+ gzip_unencode_write,
+ gzip_close_writer,
sizeof(struct zlib_params)
-};
-
-#endif /* HAVE_LIBZ */
-
-
-#ifdef HAVE_BROTLI
-/* Writer parameters. */
+};
+
+#endif /* HAVE_LIBZ */
+
+
+#ifdef HAVE_BROTLI
+/* Writer parameters. */
struct brotli_params {
- BrotliDecoderState *br; /* State structure for brotli. */
+ BrotliDecoderState *br; /* State structure for brotli. */
};
-
-static CURLcode brotli_map_error(BrotliDecoderErrorCode be)
-{
- switch(be) {
- case BROTLI_DECODER_ERROR_FORMAT_EXUBERANT_NIBBLE:
- case BROTLI_DECODER_ERROR_FORMAT_EXUBERANT_META_NIBBLE:
- case BROTLI_DECODER_ERROR_FORMAT_SIMPLE_HUFFMAN_ALPHABET:
- case BROTLI_DECODER_ERROR_FORMAT_SIMPLE_HUFFMAN_SAME:
- case BROTLI_DECODER_ERROR_FORMAT_CL_SPACE:
- case BROTLI_DECODER_ERROR_FORMAT_HUFFMAN_SPACE:
- case BROTLI_DECODER_ERROR_FORMAT_CONTEXT_MAP_REPEAT:
- case BROTLI_DECODER_ERROR_FORMAT_BLOCK_LENGTH_1:
- case BROTLI_DECODER_ERROR_FORMAT_BLOCK_LENGTH_2:
- case BROTLI_DECODER_ERROR_FORMAT_TRANSFORM:
- case BROTLI_DECODER_ERROR_FORMAT_DICTIONARY:
- case BROTLI_DECODER_ERROR_FORMAT_WINDOW_BITS:
- case BROTLI_DECODER_ERROR_FORMAT_PADDING_1:
- case BROTLI_DECODER_ERROR_FORMAT_PADDING_2:
-#ifdef BROTLI_DECODER_ERROR_COMPOUND_DICTIONARY
- case BROTLI_DECODER_ERROR_COMPOUND_DICTIONARY:
-#endif
-#ifdef BROTLI_DECODER_ERROR_DICTIONARY_NOT_SET
- case BROTLI_DECODER_ERROR_DICTIONARY_NOT_SET:
-#endif
- case BROTLI_DECODER_ERROR_INVALID_ARGUMENTS:
- return CURLE_BAD_CONTENT_ENCODING;
- case BROTLI_DECODER_ERROR_ALLOC_CONTEXT_MODES:
- case BROTLI_DECODER_ERROR_ALLOC_TREE_GROUPS:
- case BROTLI_DECODER_ERROR_ALLOC_CONTEXT_MAP:
- case BROTLI_DECODER_ERROR_ALLOC_RING_BUFFER_1:
- case BROTLI_DECODER_ERROR_ALLOC_RING_BUFFER_2:
- case BROTLI_DECODER_ERROR_ALLOC_BLOCK_TYPE_TREES:
- return CURLE_OUT_OF_MEMORY;
- default:
- break;
- }
- return CURLE_WRITE_ERROR;
-}
-
-static CURLcode brotli_init_writer(struct connectdata *conn,
+
+static CURLcode brotli_map_error(BrotliDecoderErrorCode be)
+{
+ switch(be) {
+ case BROTLI_DECODER_ERROR_FORMAT_EXUBERANT_NIBBLE:
+ case BROTLI_DECODER_ERROR_FORMAT_EXUBERANT_META_NIBBLE:
+ case BROTLI_DECODER_ERROR_FORMAT_SIMPLE_HUFFMAN_ALPHABET:
+ case BROTLI_DECODER_ERROR_FORMAT_SIMPLE_HUFFMAN_SAME:
+ case BROTLI_DECODER_ERROR_FORMAT_CL_SPACE:
+ case BROTLI_DECODER_ERROR_FORMAT_HUFFMAN_SPACE:
+ case BROTLI_DECODER_ERROR_FORMAT_CONTEXT_MAP_REPEAT:
+ case BROTLI_DECODER_ERROR_FORMAT_BLOCK_LENGTH_1:
+ case BROTLI_DECODER_ERROR_FORMAT_BLOCK_LENGTH_2:
+ case BROTLI_DECODER_ERROR_FORMAT_TRANSFORM:
+ case BROTLI_DECODER_ERROR_FORMAT_DICTIONARY:
+ case BROTLI_DECODER_ERROR_FORMAT_WINDOW_BITS:
+ case BROTLI_DECODER_ERROR_FORMAT_PADDING_1:
+ case BROTLI_DECODER_ERROR_FORMAT_PADDING_2:
+#ifdef BROTLI_DECODER_ERROR_COMPOUND_DICTIONARY
+ case BROTLI_DECODER_ERROR_COMPOUND_DICTIONARY:
+#endif
+#ifdef BROTLI_DECODER_ERROR_DICTIONARY_NOT_SET
+ case BROTLI_DECODER_ERROR_DICTIONARY_NOT_SET:
+#endif
+ case BROTLI_DECODER_ERROR_INVALID_ARGUMENTS:
+ return CURLE_BAD_CONTENT_ENCODING;
+ case BROTLI_DECODER_ERROR_ALLOC_CONTEXT_MODES:
+ case BROTLI_DECODER_ERROR_ALLOC_TREE_GROUPS:
+ case BROTLI_DECODER_ERROR_ALLOC_CONTEXT_MAP:
+ case BROTLI_DECODER_ERROR_ALLOC_RING_BUFFER_1:
+ case BROTLI_DECODER_ERROR_ALLOC_RING_BUFFER_2:
+ case BROTLI_DECODER_ERROR_ALLOC_BLOCK_TYPE_TREES:
+ return CURLE_OUT_OF_MEMORY;
+ default:
+ break;
+ }
+ return CURLE_WRITE_ERROR;
+}
+
+static CURLcode brotli_init_writer(struct connectdata *conn,
struct contenc_writer *writer)
-{
+{
struct brotli_params *bp = (struct brotli_params *) &writer->params;
- (void) conn;
-
- if(!writer->downstream)
- return CURLE_WRITE_ERROR;
-
- bp->br = BrotliDecoderCreateInstance(NULL, NULL, NULL);
- return bp->br? CURLE_OK: CURLE_OUT_OF_MEMORY;
-}
-
-static CURLcode brotli_unencode_write(struct connectdata *conn,
+ (void) conn;
+
+ if(!writer->downstream)
+ return CURLE_WRITE_ERROR;
+
+ bp->br = BrotliDecoderCreateInstance(NULL, NULL, NULL);
+ return bp->br? CURLE_OK: CURLE_OUT_OF_MEMORY;
+}
+
+static CURLcode brotli_unencode_write(struct connectdata *conn,
struct contenc_writer *writer,
- const char *buf, size_t nbytes)
-{
+ const char *buf, size_t nbytes)
+{
struct brotli_params *bp = (struct brotli_params *) &writer->params;
- const uint8_t *src = (const uint8_t *) buf;
- char *decomp;
- uint8_t *dst;
- size_t dstleft;
- CURLcode result = CURLE_OK;
- BrotliDecoderResult r = BROTLI_DECODER_RESULT_NEEDS_MORE_OUTPUT;
-
- if(!bp->br)
- return CURLE_WRITE_ERROR; /* Stream already ended. */
-
- decomp = malloc(DSIZ);
- if(!decomp)
- return CURLE_OUT_OF_MEMORY;
-
- while((nbytes || r == BROTLI_DECODER_RESULT_NEEDS_MORE_OUTPUT) &&
- result == CURLE_OK) {
- dst = (uint8_t *) decomp;
- dstleft = DSIZ;
- r = BrotliDecoderDecompressStream(bp->br,
- &nbytes, &src, &dstleft, &dst, NULL);
- result = Curl_unencode_write(conn, writer->downstream,
- decomp, DSIZ - dstleft);
- if(result)
- break;
- switch(r) {
- case BROTLI_DECODER_RESULT_NEEDS_MORE_OUTPUT:
- case BROTLI_DECODER_RESULT_NEEDS_MORE_INPUT:
- break;
- case BROTLI_DECODER_RESULT_SUCCESS:
- BrotliDecoderDestroyInstance(bp->br);
- bp->br = NULL;
- if(nbytes)
- result = CURLE_WRITE_ERROR;
- break;
- default:
- result = brotli_map_error(BrotliDecoderGetErrorCode(bp->br));
- break;
- }
- }
- free(decomp);
- return result;
-}
-
-static void brotli_close_writer(struct connectdata *conn,
+ const uint8_t *src = (const uint8_t *) buf;
+ char *decomp;
+ uint8_t *dst;
+ size_t dstleft;
+ CURLcode result = CURLE_OK;
+ BrotliDecoderResult r = BROTLI_DECODER_RESULT_NEEDS_MORE_OUTPUT;
+
+ if(!bp->br)
+ return CURLE_WRITE_ERROR; /* Stream already ended. */
+
+ decomp = malloc(DSIZ);
+ if(!decomp)
+ return CURLE_OUT_OF_MEMORY;
+
+ while((nbytes || r == BROTLI_DECODER_RESULT_NEEDS_MORE_OUTPUT) &&
+ result == CURLE_OK) {
+ dst = (uint8_t *) decomp;
+ dstleft = DSIZ;
+ r = BrotliDecoderDecompressStream(bp->br,
+ &nbytes, &src, &dstleft, &dst, NULL);
+ result = Curl_unencode_write(conn, writer->downstream,
+ decomp, DSIZ - dstleft);
+ if(result)
+ break;
+ switch(r) {
+ case BROTLI_DECODER_RESULT_NEEDS_MORE_OUTPUT:
+ case BROTLI_DECODER_RESULT_NEEDS_MORE_INPUT:
+ break;
+ case BROTLI_DECODER_RESULT_SUCCESS:
+ BrotliDecoderDestroyInstance(bp->br);
+ bp->br = NULL;
+ if(nbytes)
+ result = CURLE_WRITE_ERROR;
+ break;
+ default:
+ result = brotli_map_error(BrotliDecoderGetErrorCode(bp->br));
+ break;
+ }
+ }
+ free(decomp);
+ return result;
+}
+
+static void brotli_close_writer(struct connectdata *conn,
struct contenc_writer *writer)
-{
+{
struct brotli_params *bp = (struct brotli_params *) &writer->params;
- (void) conn;
-
- if(bp->br) {
- BrotliDecoderDestroyInstance(bp->br);
- bp->br = NULL;
- }
-}
-
+ (void) conn;
+
+ if(bp->br) {
+ BrotliDecoderDestroyInstance(bp->br);
+ bp->br = NULL;
+ }
+}
+
static const struct content_encoding brotli_encoding = {
- "br",
- NULL,
- brotli_init_writer,
- brotli_unencode_write,
- brotli_close_writer,
+ "br",
+ NULL,
+ brotli_init_writer,
+ brotli_unencode_write,
+ brotli_close_writer,
sizeof(struct brotli_params)
-};
-#endif
-
-
+};
+#endif
+
+
#ifdef HAVE_ZSTD
/* Writer parameters. */
struct zstd_params {
@@ -799,316 +799,316 @@ static const struct content_encoding zstd_encoding = {
#endif
-/* Identity handler. */
-static CURLcode identity_init_writer(struct connectdata *conn,
+/* Identity handler. */
+static CURLcode identity_init_writer(struct connectdata *conn,
struct contenc_writer *writer)
-{
- (void) conn;
- return writer->downstream? CURLE_OK: CURLE_WRITE_ERROR;
-}
-
-static CURLcode identity_unencode_write(struct connectdata *conn,
+{
+ (void) conn;
+ return writer->downstream? CURLE_OK: CURLE_WRITE_ERROR;
+}
+
+static CURLcode identity_unencode_write(struct connectdata *conn,
struct contenc_writer *writer,
- const char *buf, size_t nbytes)
-{
- return Curl_unencode_write(conn, writer->downstream, buf, nbytes);
-}
-
-static void identity_close_writer(struct connectdata *conn,
+ const char *buf, size_t nbytes)
+{
+ return Curl_unencode_write(conn, writer->downstream, buf, nbytes);
+}
+
+static void identity_close_writer(struct connectdata *conn,
struct contenc_writer *writer)
-{
- (void) conn;
- (void) writer;
-}
-
+{
+ (void) conn;
+ (void) writer;
+}
+
static const struct content_encoding identity_encoding = {
- "identity",
- "none",
- identity_init_writer,
- identity_unencode_write,
- identity_close_writer,
- 0
-};
-
-
-/* supported content encodings table. */
+ "identity",
+ "none",
+ identity_init_writer,
+ identity_unencode_write,
+ identity_close_writer,
+ 0
+};
+
+
+/* supported content encodings table. */
static const struct content_encoding * const encodings[] = {
- &identity_encoding,
-#ifdef HAVE_LIBZ
- &deflate_encoding,
- &gzip_encoding,
-#endif
-#ifdef HAVE_BROTLI
- &brotli_encoding,
-#endif
+ &identity_encoding,
+#ifdef HAVE_LIBZ
+ &deflate_encoding,
+ &gzip_encoding,
+#endif
+#ifdef HAVE_BROTLI
+ &brotli_encoding,
+#endif
#ifdef HAVE_ZSTD
&zstd_encoding,
#endif
- NULL
-};
-
-
-/* Return a list of comma-separated names of supported encodings. */
-char *Curl_all_content_encodings(void)
-{
- size_t len = 0;
+ NULL
+};
+
+
+/* Return a list of comma-separated names of supported encodings. */
+char *Curl_all_content_encodings(void)
+{
+ size_t len = 0;
const struct content_encoding * const *cep;
const struct content_encoding *ce;
- char *ace;
-
- for(cep = encodings; *cep; cep++) {
- ce = *cep;
- if(!strcasecompare(ce->name, CONTENT_ENCODING_DEFAULT))
- len += strlen(ce->name) + 2;
- }
-
- if(!len)
- return strdup(CONTENT_ENCODING_DEFAULT);
-
- ace = malloc(len);
- if(ace) {
- char *p = ace;
- for(cep = encodings; *cep; cep++) {
- ce = *cep;
- if(!strcasecompare(ce->name, CONTENT_ENCODING_DEFAULT)) {
- strcpy(p, ce->name);
- p += strlen(p);
- *p++ = ',';
- *p++ = ' ';
- }
- }
- p[-2] = '\0';
- }
-
- return ace;
-}
-
-
-/* Real client writer: no downstream. */
-static CURLcode client_init_writer(struct connectdata *conn,
+ char *ace;
+
+ for(cep = encodings; *cep; cep++) {
+ ce = *cep;
+ if(!strcasecompare(ce->name, CONTENT_ENCODING_DEFAULT))
+ len += strlen(ce->name) + 2;
+ }
+
+ if(!len)
+ return strdup(CONTENT_ENCODING_DEFAULT);
+
+ ace = malloc(len);
+ if(ace) {
+ char *p = ace;
+ for(cep = encodings; *cep; cep++) {
+ ce = *cep;
+ if(!strcasecompare(ce->name, CONTENT_ENCODING_DEFAULT)) {
+ strcpy(p, ce->name);
+ p += strlen(p);
+ *p++ = ',';
+ *p++ = ' ';
+ }
+ }
+ p[-2] = '\0';
+ }
+
+ return ace;
+}
+
+
+/* Real client writer: no downstream. */
+static CURLcode client_init_writer(struct connectdata *conn,
struct contenc_writer *writer)
-{
- (void) conn;
- return writer->downstream? CURLE_WRITE_ERROR: CURLE_OK;
-}
-
-static CURLcode client_unencode_write(struct connectdata *conn,
+{
+ (void) conn;
+ return writer->downstream? CURLE_WRITE_ERROR: CURLE_OK;
+}
+
+static CURLcode client_unencode_write(struct connectdata *conn,
struct contenc_writer *writer,
- const char *buf, size_t nbytes)
-{
- struct Curl_easy *data = conn->data;
- struct SingleRequest *k = &data->req;
-
- (void) writer;
-
- if(!nbytes || k->ignorebody)
- return CURLE_OK;
-
- return Curl_client_write(conn, CLIENTWRITE_BODY, (char *) buf, nbytes);
-}
-
-static void client_close_writer(struct connectdata *conn,
+ const char *buf, size_t nbytes)
+{
+ struct Curl_easy *data = conn->data;
+ struct SingleRequest *k = &data->req;
+
+ (void) writer;
+
+ if(!nbytes || k->ignorebody)
+ return CURLE_OK;
+
+ return Curl_client_write(conn, CLIENTWRITE_BODY, (char *) buf, nbytes);
+}
+
+static void client_close_writer(struct connectdata *conn,
struct contenc_writer *writer)
-{
- (void) conn;
- (void) writer;
-}
-
+{
+ (void) conn;
+ (void) writer;
+}
+
static const struct content_encoding client_encoding = {
- NULL,
- NULL,
- client_init_writer,
- client_unencode_write,
- client_close_writer,
- 0
-};
-
-
-/* Deferred error dummy writer. */
-static CURLcode error_init_writer(struct connectdata *conn,
+ NULL,
+ NULL,
+ client_init_writer,
+ client_unencode_write,
+ client_close_writer,
+ 0
+};
+
+
+/* Deferred error dummy writer. */
+static CURLcode error_init_writer(struct connectdata *conn,
struct contenc_writer *writer)
-{
- (void) conn;
- return writer->downstream? CURLE_OK: CURLE_WRITE_ERROR;
-}
-
-static CURLcode error_unencode_write(struct connectdata *conn,
+{
+ (void) conn;
+ return writer->downstream? CURLE_OK: CURLE_WRITE_ERROR;
+}
+
+static CURLcode error_unencode_write(struct connectdata *conn,
struct contenc_writer *writer,
- const char *buf, size_t nbytes)
-{
- char *all = Curl_all_content_encodings();
-
- (void) writer;
- (void) buf;
- (void) nbytes;
-
- if(!all)
- return CURLE_OUT_OF_MEMORY;
- failf(conn->data, "Unrecognized content encoding type. "
- "libcurl understands %s content encodings.", all);
- free(all);
- return CURLE_BAD_CONTENT_ENCODING;
-}
-
-static void error_close_writer(struct connectdata *conn,
+ const char *buf, size_t nbytes)
+{
+ char *all = Curl_all_content_encodings();
+
+ (void) writer;
+ (void) buf;
+ (void) nbytes;
+
+ if(!all)
+ return CURLE_OUT_OF_MEMORY;
+ failf(conn->data, "Unrecognized content encoding type. "
+ "libcurl understands %s content encodings.", all);
+ free(all);
+ return CURLE_BAD_CONTENT_ENCODING;
+}
+
+static void error_close_writer(struct connectdata *conn,
struct contenc_writer *writer)
-{
- (void) conn;
- (void) writer;
-}
-
+{
+ (void) conn;
+ (void) writer;
+}
+
static const struct content_encoding error_encoding = {
- NULL,
- NULL,
- error_init_writer,
- error_unencode_write,
- error_close_writer,
- 0
-};
-
-/* Create an unencoding writer stage using the given handler. */
+ NULL,
+ NULL,
+ error_init_writer,
+ error_unencode_write,
+ error_close_writer,
+ 0
+};
+
+/* Create an unencoding writer stage using the given handler. */
static struct contenc_writer *
new_unencoding_writer(struct connectdata *conn,
const struct content_encoding *handler,
struct contenc_writer *downstream)
-{
+{
size_t sz = offsetof(struct contenc_writer, params) + handler->paramsize;
struct contenc_writer *writer = (struct contenc_writer *)calloc(1, sz);
-
- if(writer) {
- writer->handler = handler;
- writer->downstream = downstream;
- if(handler->init_writer(conn, writer)) {
- free(writer);
- writer = NULL;
- }
- }
-
- return writer;
-}
-
-/* Write data using an unencoding writer stack. */
+
+ if(writer) {
+ writer->handler = handler;
+ writer->downstream = downstream;
+ if(handler->init_writer(conn, writer)) {
+ free(writer);
+ writer = NULL;
+ }
+ }
+
+ return writer;
+}
+
+/* Write data using an unencoding writer stack. */
CURLcode Curl_unencode_write(struct connectdata *conn,
struct contenc_writer *writer,
- const char *buf, size_t nbytes)
-{
- if(!nbytes)
- return CURLE_OK;
- return writer->handler->unencode_write(conn, writer, buf, nbytes);
-}
-
-/* Close and clean-up the connection's writer stack. */
+ const char *buf, size_t nbytes)
+{
+ if(!nbytes)
+ return CURLE_OK;
+ return writer->handler->unencode_write(conn, writer, buf, nbytes);
+}
+
+/* Close and clean-up the connection's writer stack. */
void Curl_unencode_cleanup(struct connectdata *conn)
{
- struct Curl_easy *data = conn->data;
+ struct Curl_easy *data = conn->data;
struct SingleRequest *k = &data->req;
struct contenc_writer *writer = k->writer_stack;
-
- while(writer) {
- k->writer_stack = writer->downstream;
- writer->handler->close_writer(conn, writer);
- free(writer);
- writer = k->writer_stack;
- }
+
+ while(writer) {
+ k->writer_stack = writer->downstream;
+ writer->handler->close_writer(conn, writer);
+ free(writer);
+ writer = k->writer_stack;
+ }
}
-/* Find the content encoding by name. */
+/* Find the content encoding by name. */
static const struct content_encoding *find_encoding(const char *name,
size_t len)
-{
+{
const struct content_encoding * const *cep;
-
- for(cep = encodings; *cep; cep++) {
+
+ for(cep = encodings; *cep; cep++) {
const struct content_encoding *ce = *cep;
- if((strncasecompare(name, ce->name, len) && !ce->name[len]) ||
- (ce->alias && strncasecompare(name, ce->alias, len) && !ce->alias[len]))
- return ce;
- }
- return NULL;
-}
-
-/* Set-up the unencoding stack from the Content-Encoding header value.
- * See RFC 7231 section 3.1.2.2. */
-CURLcode Curl_build_unencoding_stack(struct connectdata *conn,
- const char *enclist, int maybechunked)
-{
- struct Curl_easy *data = conn->data;
- struct SingleRequest *k = &data->req;
-
- do {
- const char *name;
- size_t namelen;
-
- /* Parse a single encoding name. */
- while(ISSPACE(*enclist) || *enclist == ',')
- enclist++;
-
- name = enclist;
-
- for(namelen = 0; *enclist && *enclist != ','; enclist++)
- if(!ISSPACE(*enclist))
- namelen = enclist - name + 1;
-
- /* Special case: chunked encoding is handled at the reader level. */
- if(maybechunked && namelen == 7 && strncasecompare(name, "chunked", 7)) {
- k->chunk = TRUE; /* chunks coming our way. */
- Curl_httpchunk_init(conn); /* init our chunky engine. */
- }
- else if(namelen) {
+ if((strncasecompare(name, ce->name, len) && !ce->name[len]) ||
+ (ce->alias && strncasecompare(name, ce->alias, len) && !ce->alias[len]))
+ return ce;
+ }
+ return NULL;
+}
+
+/* Set-up the unencoding stack from the Content-Encoding header value.
+ * See RFC 7231 section 3.1.2.2. */
+CURLcode Curl_build_unencoding_stack(struct connectdata *conn,
+ const char *enclist, int maybechunked)
+{
+ struct Curl_easy *data = conn->data;
+ struct SingleRequest *k = &data->req;
+
+ do {
+ const char *name;
+ size_t namelen;
+
+ /* Parse a single encoding name. */
+ while(ISSPACE(*enclist) || *enclist == ',')
+ enclist++;
+
+ name = enclist;
+
+ for(namelen = 0; *enclist && *enclist != ','; enclist++)
+ if(!ISSPACE(*enclist))
+ namelen = enclist - name + 1;
+
+ /* Special case: chunked encoding is handled at the reader level. */
+ if(maybechunked && namelen == 7 && strncasecompare(name, "chunked", 7)) {
+ k->chunk = TRUE; /* chunks coming our way. */
+ Curl_httpchunk_init(conn); /* init our chunky engine. */
+ }
+ else if(namelen) {
const struct content_encoding *encoding = find_encoding(name, namelen);
struct contenc_writer *writer;
-
- if(!k->writer_stack) {
- k->writer_stack = new_unencoding_writer(conn, &client_encoding, NULL);
-
- if(!k->writer_stack)
- return CURLE_OUT_OF_MEMORY;
- }
-
- if(!encoding)
- encoding = &error_encoding; /* Defer error at stack use. */
-
- /* Stack the unencoding stage. */
- writer = new_unencoding_writer(conn, encoding, k->writer_stack);
- if(!writer)
- return CURLE_OUT_OF_MEMORY;
- k->writer_stack = writer;
- }
- } while(*enclist);
-
- return CURLE_OK;
-}
-
-#else
-/* Stubs for builds without HTTP. */
-CURLcode Curl_build_unencoding_stack(struct connectdata *conn,
- const char *enclist, int maybechunked)
-{
- (void) conn;
- (void) enclist;
- (void) maybechunked;
- return CURLE_NOT_BUILT_IN;
-}
-
+
+ if(!k->writer_stack) {
+ k->writer_stack = new_unencoding_writer(conn, &client_encoding, NULL);
+
+ if(!k->writer_stack)
+ return CURLE_OUT_OF_MEMORY;
+ }
+
+ if(!encoding)
+ encoding = &error_encoding; /* Defer error at stack use. */
+
+ /* Stack the unencoding stage. */
+ writer = new_unencoding_writer(conn, encoding, k->writer_stack);
+ if(!writer)
+ return CURLE_OUT_OF_MEMORY;
+ k->writer_stack = writer;
+ }
+ } while(*enclist);
+
+ return CURLE_OK;
+}
+
+#else
+/* Stubs for builds without HTTP. */
+CURLcode Curl_build_unencoding_stack(struct connectdata *conn,
+ const char *enclist, int maybechunked)
+{
+ (void) conn;
+ (void) enclist;
+ (void) maybechunked;
+ return CURLE_NOT_BUILT_IN;
+}
+
CURLcode Curl_unencode_write(struct connectdata *conn,
struct contenc_writer *writer,
- const char *buf, size_t nbytes)
-{
- (void) conn;
- (void) writer;
- (void) buf;
- (void) nbytes;
- return CURLE_NOT_BUILT_IN;
-}
-
-void Curl_unencode_cleanup(struct connectdata *conn)
-{
- (void) conn;
-}
-
-char *Curl_all_content_encodings(void)
-{
- return strdup(CONTENT_ENCODING_DEFAULT); /* Satisfy caller. */
-}
-
-#endif /* CURL_DISABLE_HTTP */
+ const char *buf, size_t nbytes)
+{
+ (void) conn;
+ (void) writer;
+ (void) buf;
+ (void) nbytes;
+ return CURLE_NOT_BUILT_IN;
+}
+
+void Curl_unencode_cleanup(struct connectdata *conn)
+{
+ (void) conn;
+}
+
+char *Curl_all_content_encodings(void)
+{
+ return strdup(CONTENT_ENCODING_DEFAULT); /* Satisfy caller. */
+}
+
+#endif /* CURL_DISABLE_HTTP */