Crates.io | serbzip-core |
lib.rs | serbzip-core |
version | 0.10.0 |
source | src |
created_at | 2022-08-14 23:17:55.73692 |
updated_at | 2022-08-15 02:57:07.501637 |
description | A quasi-lossless Balkanoidal meta-lingual compressor. |
homepage | |
repository | https://github.com/ekoutanov/serbzip |
max_upload_size | |
id | 645601 |
size | 75,026 |
serbzip-core
The library package for serb.zip.
cargo add serbzip-core
We'll use the Balkanoid codec for this example.
The sample code assumes we have ../dict.blk
and ../test_data/antigonish.txt
to play with.
use std::fs::File;
use std::io;
use std::io::BufReader;
use serbzip_core::codecs::balkanoid::{Balkanoid, Dict};
use serbzip_core::codecs::Codec;
fn main() -> Result<(), Box<dyn std::error::Error>> {
// this codec needs a dictionary to work from
let mut dict_reader = BufReader::new(File::open("../dict.blk")?);
let dict = Dict::read_from_binary_image(&mut dict_reader)?;
let codec = Balkanoid::new(&dict);
// compress a line and check the output
let input_line = "Ah, distinctly I remember it was in the bleak December";
let compressed_line = codec.compress_line(input_line);
assert_eq!(compressed_line, "H, dstnctly I rmmbr t ws n th blk Dcmbr");
// expand the line; check that it matches the original
let expanded_line = codec.expand_line(&compressed_line)?;
assert_eq!(input_line, expanded_line);
// codecs also have helper methods for parsing I/O streams
let mut input_reader = BufReader::new(File::open("../test_data/antigonish.txt")?);
let mut output_writer = io::Cursor::new(Vec::new());
codec.compress(&mut input_reader, &mut output_writer)?;
let compressed_document = String::from_utf8(output_writer.into_inner())?;
assert_ne!("", compressed_document);
Ok(())
}