pub struct SerdeLite<C>(/* private fields */);Expand description
A wrapper codec that relies on serde_lite. With this, you can wrap serde based codecs that
also work with serde-lite like the [JsonSerdeCodec] or the [MsgpackSerdeCodec].
Only available with the serde_lite feature enabled plus the feature you need for the
wrapped codec.
§Example
use codee::{Encoder, Decoder, SerdeLite, string::JsonSerdeCodec, binary::MsgpackSerdeCodec};
use serde_lite::{Deserialize, Serialize};
#[derive(Clone, Debug, PartialEq, Serialize, Deserialize)]
struct Test {
s: String,
i: i32,
}
let t = Test {
s: String::from("party time 🎉"),
i: 42,
};
let enc = SerdeLite::<JsonSerdeCodec>::encode(&t).unwrap();
let dec: Test = SerdeLite::<JsonSerdeCodec>::decode(&enc).unwrap();
let enc = SerdeLite::<MsgpackSerdeCodec>::encode(&t).unwrap();
let dec: Test = SerdeLite::<MsgpackSerdeCodec>::decode(&enc).unwrap();
assert_eq!(dec, t);Trait Implementations§
Auto Trait Implementations§
impl<C> Freeze for SerdeLite<C>where
C: Freeze,
impl<C> RefUnwindSafe for SerdeLite<C>where
C: RefUnwindSafe,
impl<C> Send for SerdeLite<C>where
C: Send,
impl<C> Sync for SerdeLite<C>where
C: Sync,
impl<C> Unpin for SerdeLite<C>where
C: Unpin,
impl<C> UnwindSafe for SerdeLite<C>where
C: UnwindSafe,
Blanket Implementations§
source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
source§impl<F, W, T, D> Deserialize<With<T, W>, D> for F
impl<F, W, T, D> Deserialize<With<T, W>, D> for F
source§impl<T, D> HybridDecoder<T, [u8]> for D
impl<T, D> HybridDecoder<T, [u8]> for D
type Error = <D as Decoder<T>>::Error
fn decode_bin( val: &[u8], ) -> Result<T, HybridCoderError<<D as HybridDecoder<T, [u8]>>::Error>>
fn decode_str(_val: &str) -> Result<T, HybridCoderError<Self::Error>>
source§impl<T, D> HybridDecoder<T, str> for D
impl<T, D> HybridDecoder<T, str> for D
type Error = <D as Decoder<T>>::Error
fn decode_str( val: &str, ) -> Result<T, HybridCoderError<<D as HybridDecoder<T, str>>::Error>>
fn decode_bin(_val: &[u8]) -> Result<T, HybridCoderError<Self::Error>>
source§impl<T, E> HybridEncoder<T, String> for E
impl<T, E> HybridEncoder<T, String> for E
type Error = <E as Encoder<T>>::Error
fn encode_str( val: &T, ) -> Result<String, HybridCoderError<<E as HybridEncoder<T, String>>::Error>>
fn encode_bin(_val: &T) -> Result<Vec<u8>, HybridCoderError<Self::Error>>
source§impl<T, E> HybridEncoder<T, Vec<u8>> for E
impl<T, E> HybridEncoder<T, Vec<u8>> for E
type Error = <E as Encoder<T>>::Error
fn encode_bin( val: &T, ) -> Result<Vec<u8>, HybridCoderError<<E as HybridEncoder<T, Vec<u8>>>::Error>>
fn encode_str(_val: &T) -> Result<String, HybridCoderError<Self::Error>>
source§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Gets the layout of the type.