Codicon is a crate containing two simple traits (Encoder
and Decoder
) that
express relationships between a native Rust type and its possible encodings.
We often need to express that a type can be encoded or decoded. We also need a way to express the type of the encoding or decoding as well as parameters that may be used for that encoding or decoding. This tiny crate solves this problem.
Run this command:
$ cargo add codicon
Let's say we want u8
to be able to be encoded in a (made up) format Foo
which simply writes the byte without modification. We can express this
encoding as follows:
```rust use std::io::{Result, Write}; use std::slice;
use codicon::Encoder;
struct Foo;
impl Encoder
let mut buf = [0u8; 1]; 7u8.encode(&mut buf.asmut(), Foo).unwrap(); asserteq!(buf[0], 7u8); ```
Note that we used a unit struct because the Foo
encoding doesn't take any
options. But if you wanted to specify encoding options, you could just make
a type with parameters.
Decoding works the same as encoding:
```rust use std::io::{Result, Read}; use std::slice;
use codicon::Decoder;
struct Foo;
impl Decoder
let buf = [7u8; 1]; asserteq!(u8::decode(&mut buf.asref(), Foo).unwrap(), 7u8); ```