1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
//! # LZW decoder and encoder
//!
//! This crates provides a `LzwEncoder` and `LzwDecoder`. The code words are written from
//! and to bit streams where it is possible to write either the most or least significant
//! bit first. The maximum possible code size is 16 bits. Both types rely on RAII to
//! produced correct results.
//!
//! The de- and encoder expect the LZW stream to start with a clear code and end with an
//! end code which are defined as follows:
//!
//! * `CLEAR_CODE == 1 << min_code_size`
//! * `END_CODE == CLEAR_CODE + 1`
//!
//! Examplary use of the encoder:
//!
//! use lzw::{LsbWriter, Encoder};
//! let size = 8;
//! let data = b"TOBEORNOTTOBEORTOBEORNOT";
//! let mut compressed = vec![];
//! {
//! let mut enc = Encoder::new(LsbWriter::new(&mut compressed), size).unwrap();
//! enc.encode_bytes(data).unwrap();
//! }
pub use ;
pub use ;