pub struct NicheInto<N: ?Sized>(/* private fields */);Expand description
A wrapper that niches based on a generic Niching.
A common type combination is Option<Box<T>>. By niching None into the
null pointer, the archived version can save some space on-disk.
§Example
use core::mem::size_of;
use rkyv::{
niche::niching::{NaN, Null},
with::NicheInto,
Archive, Archived,
};
#[derive(Archive)]
struct BasicExample {
maybe_box: Option<Box<str>>,
maybe_non_nan: Option<f32>,
}
#[derive(Archive)]
struct NichedExample {
#[rkyv(with = NicheInto<Null>)]
maybe_box: Option<Box<str>>,
#[rkyv(with = NicheInto<NaN>)]
maybe_non_nan: Option<f32>,
}
assert!(
size_of::<Archived<BasicExample>>()
> size_of::<Archived<NichedExample>>()
);Trait Implementations§
Source§impl<T, N> ArchiveWith<Option<T>> for NicheInto<N>
impl<T, N> ArchiveWith<Option<T>> for NicheInto<N>
Source§impl<T, N, D> DeserializeWith<NichedOption<<T as Archive>::Archived, N>, Option<T>, D> for NicheInto<N>
impl<T, N, D> DeserializeWith<NichedOption<<T as Archive>::Archived, N>, Option<T>, D> for NicheInto<N>
Source§fn deserialize_with(
field: &NichedOption<T::Archived, N>,
deserializer: &mut D,
) -> Result<Option<T>, D::Error>
fn deserialize_with( field: &NichedOption<T::Archived, N>, deserializer: &mut D, ) -> Result<Option<T>, D::Error>
Deserializes the field type
F using the given deserializer.Source§impl<T, N, S> SerializeWith<Option<T>, S> for NicheInto<N>
impl<T, N, S> SerializeWith<Option<T>, S> for NicheInto<N>
Auto Trait Implementations§
impl<N> Freeze for NicheInto<N>where
N: ?Sized,
impl<N> RefUnwindSafe for NicheInto<N>where
N: RefUnwindSafe + ?Sized,
impl<N> Send for NicheInto<N>
impl<N> Sync for NicheInto<N>
impl<N> Unpin for NicheInto<N>
impl<N> UnsafeUnpin for NicheInto<N>where
N: ?Sized,
impl<N> UnwindSafe for NicheInto<N>where
N: UnwindSafe + ?Sized,
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.