Struct index_ext::tag::Prefix

source ·
pub struct Prefix<Tag> { /* private fields */ }
Expand description

The length of a particular slice (or a number of slices).

The encapsulated length field is guaranteed to be at most the length of each of the slices with the exact same tag. In other words, all indices strictly smaller than this number are safe.

This allows this instance to construct indices that are validated to be able to soundly access the slices without required any particular slice instance. In particular, the construct might happen by a numerical algorithm independent of the slices and across method bounds where the compiler’s optimizer and inline pass is no longer aware of the connection and would otherwise insert another check when the slice is indexed later.

Implementations§

source§

impl<T: Tag> Prefix<T>

source

pub fn with_tag<NewT>(self, less: TagLessEq<T, NewT>) -> Prefix<NewT>

Interpret this with the tag of a set of potentially longer slices.

The proof of inequality was performed in any of the possible constructors that allow the instance of TagLessEq to exist in the first place.

source

pub fn get(self) -> usize

Returns the stored length.

source

pub fn index(self, idx: usize) -> Option<Idx<usize, T>>

Construct an index to a single element.

This method return Some when the index is smaller than the length.

source

pub fn range(self, from: usize, to: usize) -> Option<Idx<Range<usize>, T>>

Construct an index to a range of element.

This method return Some when the indices are ordered and to does not exceed the length.

source

pub fn range_from(self, from: usize) -> Option<Idx<RangeFrom<usize>, T>>

Construct an index to a range from an element.

This method return Some when from does not exceed the length.

source

pub fn range_from_self(self) -> Idx<RangeFrom<usize>, T>

Construct an index to a range starting at this length.

This method might return an index for an empty range.

source

pub fn range_to(self, to: usize) -> Option<Idx<RangeTo<usize>, T>>

Construct an index to a range up to an element.

This method return Some when to does not exceed the length.

source

pub fn range_to_self(self) -> Idx<RangeTo<usize>, T>

Construct an index to a range up, exclusive, to this length.

This method might return an index for an empty range.

source

pub fn range_between(self, other: Self) -> Idx<Range<usize>, T>

Construct an index referring to the unordered range from one element to another.

This method might return an empty range. The order of arguments does not matter.

source

pub fn range_full(self) -> Idx<RangeFull, T>

Construct an index to all elements.

This method exists mostly for completeness sake. There is no bounds check when accessing a complete slice with ...

source

pub fn saturating_sub(self, sub: usize) -> Self

Create a smaller length.

source

pub fn truncate(self, min: usize) -> Self

Bound the length from above.

Trait Implementations§

source§

impl<Tag: Clone> Clone for Prefix<Tag>

source§

fn clone(&self) -> Prefix<Tag>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<T: Tag> From<NonZeroLen<T>> for Prefix<T>

source§

fn from(from: NonZeroLen<T>) -> Self

Converts to this type from the input type.
source§

impl<Tag: Copy> Copy for Prefix<Tag>

Auto Trait Implementations§

§

impl<Tag> RefUnwindSafe for Prefix<Tag>
where Tag: RefUnwindSafe,

§

impl<Tag> Send for Prefix<Tag>
where Tag: Send,

§

impl<Tag> Sync for Prefix<Tag>
where Tag: Sync,

§

impl<Tag> Unpin for Prefix<Tag>
where Tag: Unpin,

§

impl<Tag> UnwindSafe for Prefix<Tag>
where Tag: UnwindSafe,

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.

source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

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

§

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>,

§

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.