node/doc/api/zlib.markdown

96 lines
2.2 KiB
Markdown
Raw Normal View History

2011-09-07 07:13:05 +08:00
## Zlib
You can access this module with:
var zlib = require('zlib');
var gzip = zlib.createGzip();
var fs = require('fs');
var inp = fs.createReadStream('input.txt');
var out = fs.createWriteStream('input.txt.gz');
inp.pipe(gzip).pipe(out);
This provides bindings to Gzip/Gunzip, Deflate/Inflate, and
DeflateRaw/InflateRaw classes. Each class takes the same options, and
is a readable/writable Stream.
### Constants
All of the constants defined in zlib.h are also defined on
`require('zlib')`. They are described in more detail in the zlib
documentation. See <http://zlib.net/manual.html#Constants>
for more details.
### zlib.Gzip
Compress data using gzip.
### zlib.Gunzip
Decompress a gzip stream.
### zlib.Deflate
Compress data using deflate.
### zlib.Inflate
Decompress a deflate stream.
### zlib.DeflateRaw
Compress data using deflate, and do not append a zlib header.
### zlib.InflateRaw
Decompress a raw deflate stream.
### zlib.Unzip
Decompress either a Gzip- or Deflate-compressed stream by auto-detecting
the header.
### Options
Each class takes an options object. All options are optional.
Note that some options are only
relevant when compressing, and are ignored by the decompression classes.
* chunkSize (default: 16*1024)
* windowBits
* level (compression only)
* memLevel (compression only)
* strategy (compression only)
See the description of `deflateInit2` and `inflateInit2` at
<http://zlib.net/manual.html#Advanced> for more information on these.
### Memory Usage Tuning
From `zlib/zconf.h`, modified to node's usage:
The memory requirements for deflate are (in bytes):
(1 << (windowBits+2)) + (1 << (memLevel+9))
that is: 128K for windowBits=15 + 128K for memLevel = 8
(default values) plus a few kilobytes for small objects.
For example, if you want to reduce
the default memory requirements from 256K to 128K, set the options to:
{ windowBits: 14, memLevel: 7 }
Of course this will generally degrade compression (there's no free lunch).
The memory requirements for inflate are (in bytes)
1 << windowBits
that is, 32K for windowBits=15 (default value) plus a few kilobytes
for small objects.
This is in addition to a single internal output slab buffer of size
`chunkSize`, which defaults to 16K.