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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
#![deny(missing_docs)]
extern crate libc;
mod ll;
mod stream;
pub mod block;
pub mod dict;
pub use stream::encoder::{AutoFinishEncoder, Encoder};
pub use stream::decoder::Decoder;
use std::io;
use std::ffi::CStr;
pub fn decode_all(data: &[u8]) -> io::Result<Vec<u8>> {
let mut result = Vec::new();
let mut decoder = try!(Decoder::new(data));
try!(io::copy(&mut decoder, &mut result));
Ok(result)
}
pub fn encode_all(data: &[u8], level: i32) -> io::Result<Vec<u8>> {
let result = Vec::<u8>::new();
let mut encoder = try!(Encoder::new(result, level));
let mut input = data;
try!(io::copy(&mut input, &mut encoder));
encoder.finish()
}
fn parse_code(code: libc::size_t) -> Result<usize, io::Error> {
unsafe {
if ll::ZSTD_isError(code) == 0 {
Ok(code as usize)
} else {
let msg = CStr::from_ptr(ll::ZSTD_getErrorName(code));
let error = io::Error::new(io::ErrorKind::Other,
msg.to_str().unwrap().to_string());
Err(error)
}
}
}
#[cfg(test)]
fn test_cycle<I1: ?Sized, O1, I2: ?Sized, O2, F, G>(value: &I1, f: F, g: G)
where F: FnOnce(&I1) -> O1,
G: FnOnce(&I2) -> O2,
I1: PartialEq + std::fmt::Debug,
O1: std::ops::Deref<Target = I2>,
O2: std::ops::Deref<Target = I1>
{
let mid = f(value);
let end = g(mid.deref());
assert_eq!(value, end.deref());
}
#[cfg(test)]
fn test_cycle_unwrap<I1: ?Sized, O1, I2: ?Sized, O2, E1, E2, F, G>(value: &I1,
f: F, g: G)
where F: FnOnce(&I1) -> Result<O1, E1>,
G: FnOnce(&I2) -> Result<O2, E2>,
I1: PartialEq + std::fmt::Debug,
O1: std::ops::Deref<Target = I2>,
O2: std::ops::Deref<Target = I1>,
E1: std::fmt::Debug,
E2: std::fmt::Debug,
{
test_cycle(value, |data| f(data).unwrap(), |data| g(data).unwrap());
}
#[cfg(test)]
mod tests {
use {decode_all, encode_all};
fn test_full_cycle(input: &[u8], level: i32) {
::test_cycle_unwrap(input, |data| encode_all(data, level), decode_all);
}
#[test]
fn test_ll_source() {
let data = include_bytes!("ll.rs");
for level in 1..5 {
test_full_cycle(data, level);
}
}
}