Page
Library
Module
Module type
Parameter
Class
Class type
Source
DeSourceRFC1951/DEFLATE is a IETF standard. Module provides non-blocking streaming codec to decode and encode DEFLATE encoding. It can efficiently work payload by payload without blocking IO.
Module provides LZ77 compression algorithm but lets the client to define his algorithm as long as he/she uses shared queue provided in this module.
Lz77 does a compression such as it searches a repeated pattern and emits a Copy code (see Queue.cmd) which tells us to copy a previous pattern. For instance, this is an equivalence between a list of Queue.cmds and a string.
  let cmds = [ `Literal 'a'; `Copy (1, 3) ]
  let results = "aaaa"The goal of Lz77 is to produce such list from a string to help then a format such as DEFLATE to compress inputs.
Def does an huffman compression. From a list of Queue.cmd, it can calculate frequencies (see literals and distances) and generate a smaller representation of the given alphabet. Such compression is available via the Def.kind.Fixed or the Def.kind.Dynamic block. The Def.kind.Flat block does a copy of any literals into the output.
NOTE: It's illegal to emit a `Copy Queue.cmd and try to serialize it with a Def.kind.Flat block. Queue.eob is required for Def.kind.Fixed and Def.kind.Dynamic (to delimit the end of the block) and ignored by the Def.kind.Flat block.
de wants to be self-contained. By this constraint, it provides convenience values to be used by others (like zl). The client should not use these functions even if they are available. Others libraries like Bigstringaf serve the same purpose of a much better way.
The type for bigstring.
bigstring_create len returns a uninitialized bigstring of length len.
bigstring_length t is the length of the bigstring t, in bytes.
The type for windows.
make_window allocates a new buffer which represents a window. It used by decoder and LZ77 compressor to keep tracking older inputs and:
Decoder of RFC1951 DEFLATE codec. de provides a Inf.decoder to decode DEFLATE input and inflate it.
DEFLATE encoder needs a compressed input which can be transmited by a shared queue filled by compression algorithm. B is used between N and a compression algorithm like L. It provides a small representation of commands (see Queue.cmd) emitted by compression algorithm.
N encoder interprets Queue.cmd as fast as it can. Shared queue can be a bottleneck about the whole compression process. Indeed, it limits encoder on how many bytes it can produce. We recommend to make a queue as large as output buffer.
DYNAMIC DEFLATE block needs frequencies of code emitted by compression algorithm. literals and distances exist to keep frequencies while compression process.
The type of frequencies of literals (including lengths).
The type of frequencies of distances.
make_literals allocates a new literals where frequencies of symbols (expect End Of Block) are set to 0.
make_distances allocates a new distances where frequencies of distance symboles are set to 0.
succ_literals literals chr increases frequency of chr.
succ_length literals l increases frequency of l code. l must be upper than 2 and lower than 259 according DEFLATE codec. Otherwise, it raises an Invalid_argument.
succ_distance distance d increases frequency of d code. d must be upper than 0 and lower than 32769 according DEFLATE codec. Otherwise, it raises an Invalid_argument.
Distribution provides LZ77 compression algorithm which can be used with N. However, the client must know others algorithms exist. This algorithm is used by zz to implement ZLIB layer.
de provides useful but complex API. This sub-module provides an easier way to compress/uncompress DEFLATE codec. Even if the client still can give some details, we recommend to use Inf and Def if you want a precise control about memory consumption.
/ *