summaryrefslogtreecommitdiff
path: root/deps/zlib/compress.c
diff options
context:
space:
mode:
authorSam Roberts <vieuxtech@gmail.com>2017-01-20 11:01:40 -0800
committerSam Roberts <vieuxtech@gmail.com>2017-02-20 08:45:48 -0800
commitdfa8abe1b500b86ffb3951736c209e57d83ed3ed (patch)
tree462f78ca30dee5776c09642559dedc7ee5f1d3b2 /deps/zlib/compress.c
parent4e6efc1dec0eb924b68d74648b661433119306fe (diff)
downloadandroid-node-v8-dfa8abe1b500b86ffb3951736c209e57d83ed3ed.tar.gz
android-node-v8-dfa8abe1b500b86ffb3951736c209e57d83ed3ed.tar.bz2
android-node-v8-dfa8abe1b500b86ffb3951736c209e57d83ed3ed.zip
deps: upgrade zlib to 1.2.11
PR-URL: https://github.com/nodejs/node/pull/10980 Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl> Reviewed-By: Shigeki Ohtsu <ohtsu@iij.ad.jp>
Diffstat (limited to 'deps/zlib/compress.c')
-rw-r--r--deps/zlib/compress.c42
1 files changed, 24 insertions, 18 deletions
diff --git a/deps/zlib/compress.c b/deps/zlib/compress.c
index 6e9762676a..e2db404abf 100644
--- a/deps/zlib/compress.c
+++ b/deps/zlib/compress.c
@@ -1,5 +1,5 @@
/* compress.c -- compress a memory buffer
- * Copyright (C) 1995-2005 Jean-loup Gailly.
+ * Copyright (C) 1995-2005, 2014, 2016 Jean-loup Gailly, Mark Adler
* For conditions of distribution and use, see copyright notice in zlib.h
*/
@@ -28,16 +28,11 @@ int ZEXPORT compress2 (dest, destLen, source, sourceLen, level)
{
z_stream stream;
int err;
+ const uInt max = (uInt)-1;
+ uLong left;
- stream.next_in = (z_const Bytef *)source;
- stream.avail_in = (uInt)sourceLen;
-#ifdef MAXSEG_64K
- /* Check for source > 64K on 16-bit machine: */
- if ((uLong)stream.avail_in != sourceLen) return Z_BUF_ERROR;
-#endif
- stream.next_out = dest;
- stream.avail_out = (uInt)*destLen;
- if ((uLong)stream.avail_out != *destLen) return Z_BUF_ERROR;
+ left = *destLen;
+ *destLen = 0;
stream.zalloc = (alloc_func)0;
stream.zfree = (free_func)0;
@@ -46,15 +41,26 @@ int ZEXPORT compress2 (dest, destLen, source, sourceLen, level)
err = deflateInit(&stream, level);
if (err != Z_OK) return err;
- err = deflate(&stream, Z_FINISH);
- if (err != Z_STREAM_END) {
- deflateEnd(&stream);
- return err == Z_OK ? Z_BUF_ERROR : err;
- }
- *destLen = stream.total_out;
+ stream.next_out = dest;
+ stream.avail_out = 0;
+ stream.next_in = (z_const Bytef *)source;
+ stream.avail_in = 0;
+
+ do {
+ if (stream.avail_out == 0) {
+ stream.avail_out = left > (uLong)max ? max : (uInt)left;
+ left -= stream.avail_out;
+ }
+ if (stream.avail_in == 0) {
+ stream.avail_in = sourceLen > (uLong)max ? max : (uInt)sourceLen;
+ sourceLen -= stream.avail_in;
+ }
+ err = deflate(&stream, sourceLen ? Z_NO_FLUSH : Z_FINISH);
+ } while (err == Z_OK);
- err = deflateEnd(&stream);
- return err;
+ *destLen = stream.total_out;
+ deflateEnd(&stream);
+ return err == Z_STREAM_END ? Z_OK : err;
}
/* ===========================================================================