#codec #serialization #deserialize #data-encoding #utilities

codee

Easy and flexible way of encoding and decoding data into either strings or bytes

5 unstable releases

new 0.3.0 Jan 10, 2025
0.2.0 Aug 23, 2024
0.1.2 Jul 8, 2024
0.1.1 Jul 7, 2024
0.1.0 Jul 7, 2024

#867 in Encoding

Download history 2775/week @ 2024-09-21 3673/week @ 2024-09-28 3947/week @ 2024-10-05 3852/week @ 2024-10-12 3839/week @ 2024-10-19 3492/week @ 2024-10-26 5160/week @ 2024-11-02 3669/week @ 2024-11-09 3233/week @ 2024-11-16 3789/week @ 2024-11-23 5845/week @ 2024-11-30 5420/week @ 2024-12-07 6207/week @ 2024-12-14 4632/week @ 2024-12-21 4639/week @ 2024-12-28 6521/week @ 2025-01-04

22,810 downloads per month
Used in 59 crates (6 directly)

MIT/Apache

38KB
621 lines

Codee

Crates.io Docs MIT/Apache 2.0 Build Status

Easy and flexible way of encoding and decoding data into either strings or bytes.

This crate provides generic traits for Encoders and Decoders as well as several implementations for commonly used (de)serializer crates.

This makes it easily possible to abstract away the serialization and deserialization independent of the concrete crate used. You can write a function like this:

use codee::{CodecError, Decoder, Encoder};

fn store_value<T, Codec>(value: T) -> Result<(), CodecError<<Codec as Encoder<T>>::Error, <Codec as Decoder<T>>::Error>>
where
    Codec: Encoder<T, Encoded = String> + Decoder<T, Encoded = str>,
{
    let encoded = Codec::encode(&value).map_err(CodecError::Encode)?;
    let decoded = Codec::decode(&encoded).map_err(CodecError::Decode)?;

    Ok(())
}

// Then we can use it like this:

use codee::string::{JsonSerdeCodec, FromToStringCodec};

#[derive(serde::Serialize, serde::Deserialize)]
struct MyStruct {
    field: usize,
}

store_value::<i32, FromToStringCodec>(42);
store_value::<MyStruct, JsonSerdeCodec>(MyStruct { field: 42 });

Dependencies

~0.2–1.6MB
~34K SLoC