surpass::layout

Struct SliceCache

Source
pub struct SliceCache { /* private fields */ }
Expand description

A cache of non-overlapping mutable sub-slices of that enforces lifetimes dynamically.

This type is useful when you have to give up on the mutable reference to a slice but need a way to cache mutable sub-slices deriving from it.

§Examples

let mut array = [1, 2, 3];

let mut cache = SliceCache::new(3, |span| {
    let (left, right) = span.split_at(1);
    Box::new([left, right])
});

for slice in cache.access(&mut array).unwrap().iter_mut() {
    for val in slice.iter_mut() {
        *val += 1;
    }
}

assert_eq!(array, [2, 3, 4]);

Implementations§

Source§

impl SliceCache

Source

pub fn new<F>(len: usize, f: F) -> Self
where F: Fn(Span<'_>) -> Box<[Span<'_>]> + 'static,

Creates a new slice cache by storing sub-spans created from a root passed to the closure f. len is the minimum slice length that can then be passed to access.

§Examples
let mut cache = SliceCache::new(3, |span| {
    let (left, right) = span.split_at(1);
    // All returned sub-spans stem from the span passed above.
    Box::new([left, right])
});
Source

pub fn access<'c, 's, T>( &'c mut self, slice: &'s mut [T], ) -> Option<Ref<'c, [Slice<'s, T>]>>

Accesses the slice by returning all the sub-slices equivalent to the previously created spans in the closure passed to new.

If the slice does not have a length at least as large as the one passed to new, this function returns None.

Note: this method should not be called concurrently with any other access calls since it will wait for the previously returned Ref to be dropped.

§Examples
let mut array = [1, 2, 3];

let mut cache = SliceCache::new(3, |span| {
    let (left, right) = span.split_at(1);
    Box::new([left, right])
});

let mut copy = array;
let skipped_one = cache.access(&mut array).unwrap();

assert_eq!(&*skipped_one[1], &copy[1..]);

Trait Implementations§

Source§

impl Debug for SliceCache

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.