OccupiedEntry

Struct OccupiedEntry 

Source
pub struct OccupiedEntry<'a, 's, A: Allocator, K: PartialOrd + Debug, V, B: ArrayLength>
where U2: Mul<B>, Prod<U2, B>: ArrayLength, U1: Add<Prod<U2, B>>, Sum<U1, Prod<U2, B>>: ArrayLength,
{ /* private fields */ }
Expand description

A view into an occupied entry in a CompressedBTreeMap. It is part of the Entry enum.

Implementations§

Source§

impl<'a, 's, A: Allocator, K: PartialOrd + Debug, V, B: ArrayLength> OccupiedEntry<'a, 's, A, K, V, B>
where U2: Mul<B>, Prod<U2, B>: ArrayLength, U1: Add<Prod<U2, B>>, Sum<U1, Prod<U2, B>>: ArrayLength,

Source

pub fn key(&self) -> &K

Gets a reference to the key in the entry.

Source

pub fn key_below(&self) -> Option<&K>

Returns a reference to the key that is immediately below (predecessor of) this occupied entry’s key in the tree’s sorted order. Returns None if this entry is the minimum key.

Source

pub fn key_above(&self) -> Option<&K>

Returns a reference to the key that is immediately above (successor of) this occupied entry’s key in the tree’s sorted order. Returns None if this entry is the maximum key.

Source

pub fn get(&self) -> &V

Gets a reference to the value in the entry.

Source

pub fn get_mut(&mut self) -> &mut V

Gets a mutable reference to the value in the entry.

Source

pub fn into_mut(self) -> &'s mut V

Converts the entry into a mutable reference to its value.

Source

pub fn insert(&mut self, value: V) -> V

Sets the value of the entry with the OccupiedEntry’s key, and returns the entry’s old value.

Source

pub fn remove(self) -> V

Takes the value of the entry out of the map, and returns it.

Source

pub fn remove_entry(self) -> (K, V)

Takes the key-value pair out of the map, and returns it.

Auto Trait Implementations§

§

impl<'a, 's, A, K, V, B> Freeze for OccupiedEntry<'a, 's, A, K, V, B>
where <UInt<UTerm, B1> as Add<<UInt<UInt<UTerm, B1>, B0> as Mul<B>>::Output>>::Output: Sized, <UInt<UInt<UTerm, B1>, B0> as Mul<B>>::Output: Sized,

§

impl<'a, 's, A, K, V, B> !RefUnwindSafe for OccupiedEntry<'a, 's, A, K, V, B>

§

impl<'a, 's, A, K, V, B> !Send for OccupiedEntry<'a, 's, A, K, V, B>

§

impl<'a, 's, A, K, V, B> !Sync for OccupiedEntry<'a, 's, A, K, V, B>

§

impl<'a, 's, A, K, V, B> Unpin for OccupiedEntry<'a, 's, A, K, V, B>
where <UInt<UTerm, B1> as Add<<UInt<UInt<UTerm, B1>, B0> as Mul<B>>::Output>>::Output: Sized, <UInt<UInt<UTerm, B1>, B0> as Mul<B>>::Output: Sized,

§

impl<'a, 's, A, K, V, B> !UnwindSafe for OccupiedEntry<'a, 's, A, K, V, B>

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> Same for T

Source§

type Output = T

Should always be Self
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.