use epserde::{deser::DeserType, prelude::*, ser::SerType};
#[derive(Epserde, Debug, PartialEq, Eq, Default, Clone)]
struct Data<A> {
a: A,
}
type Type = Data<Vec<String>>;
fn main() -> Result<(), Box<dyn std::error::Error>> {
println!("Serializable type: {}", core::any::type_name::<Type>());
println!(
"Associated serialization type: {}",
core::any::type_name::<SerType<Type>>()
);
println!();
let data = Type {
a: vec!["A".to_owned(), "B".to_owned(), "C".to_owned()],
};
let mut cursor = <AlignedCursor<Aligned16>>::new();
#[cfg(feature = "schema")]
{
let schema = unsafe { data.serialize_with_schema(&mut cursor)? };
println!("{}", schema.debug(cursor.as_bytes()));
println!();
}
#[cfg(not(feature = "schema"))]
let _bytes_written = unsafe { data.serialize(&mut cursor)? };
cursor.set_position(0);
let full = unsafe { Type::deserialize_full(&mut cursor)? };
println!(
"Full-copy deserialization: returns the deserializable type {}",
core::any::type_name::<Type>(),
);
println!("Value: {:x?}", full);
println!();
let eps = unsafe { Type::deserialize_eps(cursor.as_bytes())? };
println!(
"ε-copy deserialization: returns the associated deserialization type {}",
core::any::type_name::<DeserType<'_, Type>>(),
);
println!("Value: {:x?}", eps);
#[cfg(not(feature = "schema"))]
println!("\nPlease compile with the \"schema\" feature to see the schema output");
Ok(())
}