diff options
author | Alon Zakai <azakai@mozilla.com> | 2011-02-05 21:01:26 -0800 |
---|---|---|
committer | Alon Zakai <azakai@mozilla.com> | 2011-02-05 21:01:26 -0800 |
commit | d2ba2dcfc11846ec1f9a36c93055a7500a93f669 (patch) | |
tree | 196fc1f2fcd806f413be242389e29a9f6759654a /tests/zlib/uncompr.c | |
parent | 0805b2bec3ee27785259d76f1c9a5ccc555f1d6b (diff) |
zlib test
Diffstat (limited to 'tests/zlib/uncompr.c')
-rw-r--r-- | tests/zlib/uncompr.c | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/tests/zlib/uncompr.c b/tests/zlib/uncompr.c new file mode 100644 index 00000000..ad98be3a --- /dev/null +++ b/tests/zlib/uncompr.c @@ -0,0 +1,59 @@ +/* uncompr.c -- decompress a memory buffer + * Copyright (C) 1995-2003, 2010 Jean-loup Gailly. + * For conditions of distribution and use, see copyright notice in zlib.h + */ + +/* @(#) $Id$ */ + +#define ZLIB_INTERNAL +#include "zlib.h" + +/* =========================================================================== + Decompresses the source buffer into the destination buffer. sourceLen is + the byte length of the source buffer. Upon entry, destLen is the total + size of the destination buffer, which must be large enough to hold the + entire uncompressed data. (The size of the uncompressed data must have + been saved previously by the compressor and transmitted to the decompressor + by some mechanism outside the scope of this compression library.) + Upon exit, destLen is the actual size of the compressed buffer. + + uncompress returns Z_OK if success, Z_MEM_ERROR if there was not + enough memory, Z_BUF_ERROR if there was not enough room in the output + buffer, or Z_DATA_ERROR if the input data was corrupted. +*/ +int ZEXPORT uncompress (dest, destLen, source, sourceLen) + Bytef *dest; + uLongf *destLen; + const Bytef *source; + uLong sourceLen; +{ + z_stream stream; + int err; + + stream.next_in = (Bytef*)source; + stream.avail_in = (uInt)sourceLen; + /* Check for source > 64K on 16-bit machine: */ + if ((uLong)stream.avail_in != sourceLen) return Z_BUF_ERROR; + + stream.next_out = dest; + stream.avail_out = (uInt)*destLen; + if ((uLong)stream.avail_out != *destLen) return Z_BUF_ERROR; + + stream.zalloc = (alloc_func)0; + stream.zfree = (free_func)0; + + err = inflateInit(&stream); + if (err != Z_OK) return err; + + err = inflate(&stream, Z_FINISH); + if (err != Z_STREAM_END) { + inflateEnd(&stream); + if (err == Z_NEED_DICT || (err == Z_BUF_ERROR && stream.avail_in == 0)) + return Z_DATA_ERROR; + return err; + } + *destLen = stream.total_out; + + err = inflateEnd(&stream); + return err; +} |