hdlc Build Status

hdlc

Rust implementation of a High-level Data Link Control (HDLC) library with support of the IEEE standard.

Usage

Add hdlc to Cargo.toml toml [dependencies] hdlc = "^0.2.0" or toml [dependencies.hdlc] git = "https://github.com/CLomanno/hdlc"

Add this to crate root rust extern crate hdlc;

Encode packet

```rust extern crate hdlc; use hdlc::{SpecialChars, encode};

// Set up your vector of bytes and generate your Special Characters let msg: Vec = vec![0x01, 0x50, 0x00, 0x00, 0x00, 0x05, 0x80, 0x09]; let cmp: Vec = vec![0x7E, 0x01, 0x50, 0x00, 0x00, 0x00, 0x05, 0x80, 0x09, 0x7E];

// Encode your message let result = encode(&msg, SpecialChars::default());

assert!(result.isok()); asserteq!(result.unwrap(), cmp); ```

Custom Special Characters

```rust extern crate hdlc; use hdlc::{SpecialChars, encode};

// Set up your vector of bytes and generate your Special Characters let msg: Vec = vec![0x01, 0x7E, 0x70, 0x50, 0x00, 0x05, 0x80, 0x09]; let cmp: Vec = vec![0x71, 0x01, 0x7E, 0x70, 0x50, 0x50, 0x00, 0x05, 0x80, 0x09, 0x71]; let chars = SpecialChars::new(0x71, 0x70, 0x51, 0x50);

let result = encode(&msg, chars);

// Encode your message let result = encode(&msg, chars);

assert!(result.isok()); asserteq!(result.unwrap(), cmp) ```

Decode packet

```rust extern crate hdlc; use hdlc::{SpecialChars, decode};

// Set up your vector of bytes and generate your Special Characters let msg: Vec = vec![ chars.fend, 0x01, 0x50, 0x00, 0x00, 0x00, 0x05, 0x80, 0x09, chars.fend, ]; let cmp: Vec = vec![0x01, 0x50, 0x00, 0x00, 0x00, 0x05, 0x80, 0x09];

// Decode your message let result = decode(&msg, chars);

assert!(result.isok()); asserteq!(result.unwrap(), cmp); ```

Benchmark

Bencher is currently not available in Rust stable releases.

cargo bench with 2.2 GHz Intel Core i7 results ~430MB/s throughput. ``` cargo bench Running target\release\deps\bench-8475e9ff4a76b8c6.exe

running 4 tests test benchdecodemegabyte ... bench: 2,068,254 ns/iter (+/- 159,469) test benchdecodespecialchars2megabytes ... bench: 5,586,588 ns/iter (+/- 119,725) test benchencodemegabyte ... bench: 2,415,257 ns/iter (+/- 219,049) test benchencodespecialchars_megabyte ... bench: 5,715,299 ns/iter (+/- 400,649)

test result: ok. 0 passed; 0 failed; 0 ignored; 4 measured; 0 filtered out ```

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.