Skip to main content

OccupiedEntry

Struct OccupiedEntry 

Source
pub struct OccupiedEntry<'a, K: Ord + Clone + Sized, V: Sized> { /* private fields */ }
Available on crate feature btree only.
Expand description

Entry for an existing key-value pair in the tree

Implementations§

Source§

impl<'a, K: Ord + Clone + Sized, V: Sized> OccupiedEntry<'a, K, V>

Source

pub fn key(&self) -> &K

Get a reference to the key

Source

pub fn remove(self) -> V

Remove the key-value pair from the tree and return the value

Source

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

Remove the key-value pair from the tree and return the key and value

Source

pub fn get(&self) -> &V

Get a reference to the value

Source

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

Get a mutable reference to the value

Source

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

Convert the OccupiedEntry into a mutable reference bounded by the tree’s lifetime

Source

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

replace a value into the tree and return the old value

Source

pub fn peak_backward(&self) -> Option<(&'a K, &'a V)>

Peak previous OccupiedEntry

Source

pub fn peak_forward(&self) -> Option<(&'a K, &'a V)>

Peak the next OccupiedEntry

Source

pub fn move_backward(self) -> Result<Self, Self>

Move to previous OccupiedEntry

When reaching the front, return the original entry in Err()

Source

pub fn move_forward(self) -> Result<Self, Self>

Move to next OccupiedEntry

When reaching the end, return the original entry in Err()

Source

pub fn alter_key(&mut self, k: K) -> Result<(), ()>

Try to alter the key of this entry

On successful returns Ok() ; If key is not in strict order among the neighbors, return Err() .

Trait Implementations§

Source§

impl<'a, K: Ord + Clone + Sized + Debug, V: Sized + Debug> Debug for OccupiedEntry<'a, K, V>

Source§

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

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<'a, K, V> Freeze for OccupiedEntry<'a, K, V>

§

impl<'a, K, V> RefUnwindSafe for OccupiedEntry<'a, K, V>

§

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

§

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

§

impl<'a, K, V> Unpin for OccupiedEntry<'a, K, V>

§

impl<'a, K, V> UnsafeUnpin for OccupiedEntry<'a, K, V>

§

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

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