pub struct Base64<C>(/* private fields */);Expand description
Wraps a binary codec and make it a string codec by representing the binary data as a base64 string.
Only available with the base64 feature enabled.
Example:
#[derive(Serialize, Deserialize, PartialEq, Debug)]
struct MyState {
chicken_count: u32,
egg_count: u32,
farm_name: String,
}
let original_value = MyState {
chicken_count: 10,
egg_count: 20,
farm_name: "My Farm".to_owned(),
};
let encoded: String = Base64::<MsgpackSerdeCodec>::encode(&original_value).unwrap();
let decoded: MyState = Base64::<MsgpackSerdeCodec>::decode(&encoded).unwrap();
assert_eq!(decoded, original_value);Trait Implementations§
Auto Trait Implementations§
impl<C> Freeze for Base64<C>where
C: Freeze,
impl<C> RefUnwindSafe for Base64<C>where
C: RefUnwindSafe,
impl<C> Send for Base64<C>where
C: Send,
impl<C> Sync for Base64<C>where
C: Sync,
impl<C> Unpin for Base64<C>where
C: Unpin,
impl<C> UnwindSafe for Base64<C>where
C: UnwindSafe,
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§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<T, D> HybridDecoder<T, str> for D
impl<T, D> HybridDecoder<T, str> for D
type Error = <D as Decoder<T>>::Error
fn is_binary_decoder() -> bool
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 is_binary_encoder() -> bool
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> 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>
Returns the layout of the type.
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Returns whether the given value has been niched. Read more
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
Writes data to
out indicating that a T is niched.