pub struct Lock;Expand description
A wrapper that locks a lock and serializes the value immutably.
This wrapper can panic under very specific circumstances when:
serialize_withis called and succeeds in locking the value to serialize it.- Another thread locks the value and panics, poisoning the lock
resolve_withis called and gets a poisoned value.
Unfortunately, it’s not possible to work around this issue internally. Users must ensure this doesn’t happen on their own through manual synchronization or guaranteeing that panics do not occur while holding locks.
§Example
use std::sync::Mutex;
use rkyv::{with::Lock, Archive};
#[derive(Archive)]
struct Example {
#[rkyv(with = Lock)]
a: Mutex<i32>,
}Trait Implementations§
Source§impl<F, T, D> DeserializeWith<F, Mutex<T>, D> for Lock
impl<F, T, D> DeserializeWith<F, Mutex<T>, D> for Lock
Source§impl<F, T, D> DeserializeWith<F, RwLock<T>, D> for Lock
impl<F, T, D> DeserializeWith<F, RwLock<T>, D> for Lock
Source§impl<F, S> SerializeWith<Mutex<F>, S> for Lock
impl<F, S> SerializeWith<Mutex<F>, S> for Lock
Auto Trait Implementations§
impl Freeze for Lock
impl RefUnwindSafe for Lock
impl Send for Lock
impl Sync for Lock
impl Unpin for Lock
impl UnsafeUnpin for Lock
impl UnwindSafe for Lock
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.