pub struct MapNiche<W: ?Sized, N: ?Sized = DefaultNiche> { /* private fields */ }
Expand description
A wrapper that first applies another wrapper W
to the value inside an
Option
and then niches the result based on the Niching
N
.
§Example
use rkyv::{
with::{AsBox, MapNiche},
Archive, Serialize,
};
#[derive(Archive, Serialize)]
struct BasicExample {
option: Option<HugeType>,
}
#[derive(Archive, Serialize)]
struct NichedExample {
#[rkyv(with = MapNiche<AsBox>)]
option: Option<HugeType>,
}
#[derive(Archive, Serialize)]
struct HugeType([u8; 1024]);
let basic_value = BasicExample { option: None };
let basic_bytes = rkyv::to_bytes(&basic_value)?;
assert_eq!(basic_bytes.len(), 1 + 1024);
let niched_value = NichedExample { option: None };
let niched_bytes = rkyv::to_bytes(&niched_value)?;
assert_eq!(niched_bytes.len(), 4); // size_of::<ArchivedBox<_>>()
Trait Implementations§
Source§impl<T, W, N> ArchiveWith<Option<T>> for MapNiche<W, N>
impl<T, W, N> ArchiveWith<Option<T>> for MapNiche<W, N>
Source§type Archived = NichedOption<<W as ArchiveWith<T>>::Archived, N>
type Archived = NichedOption<<W as ArchiveWith<T>>::Archived, N>
The archived type of
Self
with F
.Source§impl<T, W, N, D> DeserializeWith<NichedOption<<W as ArchiveWith<T>>::Archived, N>, Option<T>, D> for MapNiche<W, N>where
W: ArchiveWith<T> + DeserializeWith<<W as ArchiveWith<T>>::Archived, T, D>,
N: Niching<<W as ArchiveWith<T>>::Archived> + ?Sized,
D: Fallible + ?Sized,
impl<T, W, N, D> DeserializeWith<NichedOption<<W as ArchiveWith<T>>::Archived, N>, Option<T>, D> for MapNiche<W, N>where
W: ArchiveWith<T> + DeserializeWith<<W as ArchiveWith<T>>::Archived, T, D>,
N: Niching<<W as ArchiveWith<T>>::Archived> + ?Sized,
D: Fallible + ?Sized,
Source§fn deserialize_with(
field: &NichedOption<<W as ArchiveWith<T>>::Archived, N>,
deserializer: &mut D,
) -> Result<Option<T>, D::Error>
fn deserialize_with( field: &NichedOption<<W as ArchiveWith<T>>::Archived, N>, deserializer: &mut D, ) -> Result<Option<T>, D::Error>
Deserializes the field type
F
using the given deserializer.Source§impl<T, W, N, S> SerializeWith<Option<T>, S> for MapNiche<W, N>where
W: SerializeWith<T, S> + ?Sized,
N: Niching<<W as ArchiveWith<T>>::Archived> + ?Sized,
S: Fallible + ?Sized,
impl<T, W, N, S> SerializeWith<Option<T>, S> for MapNiche<W, N>where
W: SerializeWith<T, S> + ?Sized,
N: Niching<<W as ArchiveWith<T>>::Archived> + ?Sized,
S: Fallible + ?Sized,
Auto Trait Implementations§
impl<W, N> Freeze for MapNiche<W, N>
impl<W, N> RefUnwindSafe for MapNiche<W, N>
impl<W, N> Send for MapNiche<W, N>
impl<W, N> Sync for MapNiche<W, N>
impl<W, N> Unpin for MapNiche<W, N>
impl<W, N> UnwindSafe for MapNiche<W, N>
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> 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.