Struct Strategy
pub struct Strategy<T, E>where
T: ?Sized,{ /* private fields */ }
Available on crate feature
dep_rkyv
only.Expand description
Equips a type with a Fallible
implementation that chooses E
as its error
type.
§Example
use rancor::{Failure, Fallible, Strategy};
trait Print<E = <Self as Fallible>::Error> {
fn print(&self, message: &str) -> Result<(), E>;
}
impl<T: Print<E> + ?Sized, E> Print<E> for Strategy<T, E> {
fn print(&self, message: &str) -> Result<(), E> {
T::print(self, message)
}
}
struct StdOut;
impl<E> Print<E> for StdOut {
fn print(&self, message: &str) -> Result<(), E> {
println!("{message}");
Ok(())
}
}
Strategy::<_, Failure>::wrap(&mut StdOut)
.print("hello world")
.unwrap();
Implementations§
§impl<T, E> Strategy<T, E>where
T: ?Sized,
impl<T, E> Strategy<T, E>where
T: ?Sized,
pub fn wrap(inner: &mut T) -> &mut Strategy<T, E>
pub fn wrap(inner: &mut T) -> &mut Strategy<T, E>
Wraps the given mutable reference, returning a mutable reference to a
Strategy
.
§Example
use core::ops::Deref;
use rancor::{Failure, Strategy};
fn test() {
struct Inner {
value: u64,
}
let mut inner = Inner { value: 10 };
let inner_value_ptr = &inner.value as *const u64;
let strategy: &mut Strategy<Inner, Failure> =
Strategy::wrap(&mut inner);
let strategy_value_ptr = (&strategy.deref().value) as *const u64;
assert_eq!(inner_value_ptr, strategy_value_ptr);
// Strategy wraps a type but does not change its memory layout.
}
test();
Trait Implementations§
§impl<T, E> ArchiveContext<E> for Strategy<T, E>where
T: ArchiveContext<E> + ?Sized,
impl<T, E> ArchiveContext<E> for Strategy<T, E>where
T: ArchiveContext<E> + ?Sized,
§fn check_subtree_ptr(
&mut self,
ptr: *const u8,
layout: &Layout,
) -> Result<(), E> ⓘ
fn check_subtree_ptr( &mut self, ptr: *const u8, layout: &Layout, ) -> Result<(), E> ⓘ
Checks that the given data address and layout is located completely
within the subtree range.
§impl<T, E> Pooling<E> for Strategy<T, E>where
T: Pooling<E>,
impl<T, E> Pooling<E> for Strategy<T, E>where
T: Pooling<E>,
§fn start_pooling(&mut self, address: usize) -> PoolingState
fn start_pooling(&mut self, address: usize) -> PoolingState
Starts pooling the value associated with the given address.
§impl<T, E> Positional for Strategy<T, E>where
T: Positional + ?Sized,
impl<T, E> Positional for Strategy<T, E>where
T: Positional + ?Sized,
§impl<T, E> Sharing<E> for Strategy<T, E>
impl<T, E> Sharing<E> for Strategy<T, E>
§fn start_sharing(&mut self, address: usize) -> SharingState
fn start_sharing(&mut self, address: usize) -> SharingState
Starts sharing the value associated with the given address.
Auto Trait Implementations§
impl<T, E> Freeze for Strategy<T, E>
impl<T, E> RefUnwindSafe for Strategy<T, E>
impl<T, E> Send for Strategy<T, E>
impl<T, E> Sync for Strategy<T, E>
impl<T, E> Unpin for Strategy<T, E>
impl<T, E> UnwindSafe for Strategy<T, E>
Blanket Implementations§
§impl<C, E> ArchiveContextExt<E> for C
impl<C, E> ArchiveContextExt<E> for C
§fn in_subtree_raw<R>(
&mut self,
ptr: *const u8,
layout: Layout,
f: impl FnOnce(&mut C) -> Result<R, E>,
) -> Result<R, E> ⓘ
fn in_subtree_raw<R>( &mut self, ptr: *const u8, layout: Layout, f: impl FnOnce(&mut C) -> Result<R, E>, ) -> Result<R, E> ⓘ
Checks that the given pointer and layout are within the current subtree
range of the context, then pushes a new subtree range onto the validator
for it and calls the given function.
§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
§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> ByteSized for T
impl<T> ByteSized for T
Source§const BYTE_ALIGN: usize = _
const BYTE_ALIGN: usize = _
The alignment of this type in bytes.
Source§fn byte_align(&self) -> usize ⓘ
fn byte_align(&self) -> usize ⓘ
Returns the alignment of this type in bytes.
Source§fn ptr_size_ratio(&self) -> [usize; 2]
fn ptr_size_ratio(&self) -> [usize; 2]
Source§impl<T, R> Chain<R> for Twhere
T: ?Sized,
impl<T, R> Chain<R> for Twhere
T: ?Sized,
Source§impl<T> ExtAny for T
impl<T> ExtAny for T
Source§fn as_any_mut(&mut self) -> &mut dyn Anywhere
Self: Sized,
fn as_any_mut(&mut self) -> &mut dyn Anywhere
Self: Sized,
Source§impl<T> ExtMem for Twhere
T: ?Sized,
impl<T> ExtMem for Twhere
T: ?Sized,
Source§const NEEDS_DROP: bool = _
const NEEDS_DROP: bool = _
Know whether dropping values of this type matters, in compile-time.
Source§fn mem_align_of_val(&self) -> usize ⓘ
fn mem_align_of_val(&self) -> usize ⓘ
Returns the alignment of the pointed-to value in bytes. Read more
Source§fn mem_size_of_val(&self) -> usize ⓘ
fn mem_size_of_val(&self) -> usize ⓘ
Returns the size of the pointed-to value in bytes. Read more
Source§fn mem_needs_drop(&self) -> bool
fn mem_needs_drop(&self) -> bool
Returns
true
if dropping values of this type matters. Read moreSource§fn mem_forget(self)where
Self: Sized,
fn mem_forget(self)where
Self: Sized,
Forgets about
self
without running its destructor. Read moreSource§fn mem_replace(&mut self, other: Self) -> Selfwhere
Self: Sized,
fn mem_replace(&mut self, other: Self) -> Selfwhere
Self: Sized,
Source§unsafe fn mem_zeroed<T>() -> T
unsafe fn mem_zeroed<T>() -> T
Available on crate feature
unsafe_layout
only.Returns the value of type
T
represented by the all-zero byte-pattern. Read moreSource§unsafe fn mem_transmute_copy<Src, Dst>(src: &Src) -> Dst
unsafe fn mem_transmute_copy<Src, Dst>(src: &Src) -> Dst
Available on crate feature
unsafe_layout
only.Returns the value of type
T
represented by the all-zero byte-pattern. Read moreSource§fn mem_as_bytes(&self) -> &[u8] ⓘ
fn mem_as_bytes(&self) -> &[u8] ⓘ
Available on crate feature
unsafe_slice
only.§impl<S> FromSample<S> for S
impl<S> FromSample<S> for S
fn from_sample_(s: S) -> S
Source§impl<T> Hook for T
impl<T> Hook for T
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
§fn in_current_span(self) -> Instrumented<Self> ⓘ
fn in_current_span(self) -> Instrumented<Self> ⓘ
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more§impl<F, T> IntoSample<T> for Fwhere
T: FromSample<F>,
impl<F, T> IntoSample<T> for Fwhere
T: FromSample<F>,
fn into_sample(self) -> T
§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
§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.
§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
§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
§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.§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T, E> PoolingExt<E> for T
impl<T, E> PoolingExt<E> for T
Checks whether the given reference has been deserialized and either uses
the existing shared pointer to it, or deserializes it and converts
it to a shared pointer with
to_shared
.§impl<S, E> SharingExt<E> for S
impl<S, E> SharingExt<E> for S
Serializes the given shared value and returns its position. If the value
has already been serialized then it returns the position of the
previously added value. Read more
§impl<T, U> ToSample<U> for Twhere
U: FromSample<T>,
impl<T, U> ToSample<U> for Twhere
U: FromSample<T>,
fn to_sample_(self) -> U
§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> ⓘ
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> ⓘ
§fn with_current_subscriber(self) -> WithDispatch<Self> ⓘ
fn with_current_subscriber(self) -> WithDispatch<Self> ⓘ
§impl<T, E> WriterExt<E> for T
impl<T, E> WriterExt<E> for T
§fn align(&mut self, align: usize) -> Result<usize, E> ⓘ
fn align(&mut self, align: usize) -> Result<usize, E> ⓘ
Aligns the position of the serializer to the given alignment.
§fn align_for<T>(&mut self) -> Result<usize, E> ⓘ
fn align_for<T>(&mut self) -> Result<usize, E> ⓘ
Aligns the position of the serializer to be suitable to write the given
type.
§unsafe fn resolve_aligned<T>(
&mut self,
value: &T,
resolver: <T as Archive>::Resolver,
) -> Result<usize, E> ⓘ
unsafe fn resolve_aligned<T>( &mut self, value: &T, resolver: <T as Archive>::Resolver, ) -> Result<usize, E> ⓘ
Resolves the given value with its resolver and writes the archived type. Read more
§unsafe fn resolve_unsized_aligned<T>(
&mut self,
value: &T,
to: usize,
) -> Result<usize, E> ⓘwhere
T: ArchiveUnsized + ?Sized,
unsafe fn resolve_unsized_aligned<T>(
&mut self,
value: &T,
to: usize,
) -> Result<usize, E> ⓘwhere
T: ArchiveUnsized + ?Sized,
Resolves the given reference with its resolver and writes the archived
reference. Read more