Struct OccupiedEntry

Source
pub struct OccupiedEntry<'a, K, V> { /* private fields */ }
Expand description

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

Implementations§

Source§

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

Source

pub fn key(&self) -> &K

Gets a reference to the key in the entry.

§Examples
use vecmap::VecMap;

let mut map: VecMap<&str, u32> = VecMap::new();
map.entry("poneyland").or_insert(12);
assert_eq!(map.entry("poneyland").key(), &"poneyland");
Source

pub fn index(&self) -> usize

Gets the index of the entry.

§Examples
use vecmap::VecMap;

let mut map: VecMap<&str, u32> = VecMap::new();
map.entry("poneyland").or_insert(12);
assert_eq!(map.entry("poneyland").index(), 0);
Source

pub fn into_key(self) -> K

Take ownership of the key.

§Examples
use vecmap::VecMap;
use vecmap::map::Entry;

let mut map: VecMap<&str, u32> = VecMap::new();
map.insert("foo", 1);

if let Entry::Occupied(v) = map.entry("foo") {
    v.into_key();
}
Source

pub fn get(&self) -> &V

Gets a reference to the value in the entry.

§Examples
use vecmap::VecMap;
use vecmap::map::Entry;

let mut map: VecMap<&str, u32> = VecMap::new();
map.entry("poneyland").or_insert(12);

if let Entry::Occupied(o) = map.entry("poneyland") {
    assert_eq!(o.get(), &12);
}
Source

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

Gets a mutable reference to the value in the entry.

If you need a reference to the OccupiedEntry which may outlive the destruction of the Entry value, see into_mut.

§Examples
use vecmap::VecMap;
use vecmap::map::Entry;

let mut map: VecMap<&str, u32> = VecMap::new();
map.entry("poneyland").or_insert(12);

assert_eq!(map["poneyland"], 12);
if let Entry::Occupied(mut o) = map.entry("poneyland") {
    *o.get_mut() += 10;
    assert_eq!(*o.get(), 22);

    // We can use the same Entry multiple times.
    *o.get_mut() += 2;
}

assert_eq!(map["poneyland"], 24);
Source

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

Converts the OccupiedEntry into a mutable reference to the value in the entry with a lifetime bound to the map itself.

If you need multiple references to the OccupiedEntry, see get_mut.

§Examples
use vecmap::VecMap;
use vecmap::map::Entry;

let mut map: VecMap<&str, u32> = VecMap::new();
map.entry("poneyland").or_insert(12);

assert_eq!(map["poneyland"], 12);
if let Entry::Occupied(o) = map.entry("poneyland") {
    *o.into_mut() += 10;
}

assert_eq!(map["poneyland"], 22);
Source

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

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

§Examples
use vecmap::VecMap;
use vecmap::map::Entry;

let mut map: VecMap<&str, u32> = VecMap::new();
map.entry("poneyland").or_insert(12);

if let Entry::Occupied(mut o) = map.entry("poneyland") {
    assert_eq!(o.insert(15), 12);
}

assert_eq!(map["poneyland"], 15);
Source

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

Removes and return the key-value pair stored in the map for this entry.

Like Vec::swap_remove, the pair is removed by swapping it with the last element of the map and popping it off. This perturbs the position of what used to be the last element!

§Examples
use vecmap::VecMap;
use vecmap::map::Entry;

let mut map: VecMap<&str, u32> = VecMap::new();
map.entry("poneyland").or_insert(12);
map.entry("foo").or_insert(13);
map.entry("bar").or_insert(14);

if let Entry::Occupied(o) = map.entry("poneyland") {
    // We delete the entry from the map.
    o.swap_remove_entry();
}

assert_eq!(map.contains_key("poneyland"), false);
assert_eq!(map.get_index_of("foo"), Some(1));
assert_eq!(map.get_index_of("bar"), Some(0));
Source

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

Removes and return the key-value pair stored in the map for this entry.

Like Vec::remove, the pair is removed by shifting all of the elements that follow it, preserving their relative order. This perturbs the index of all of those elements!

§Examples
use vecmap::VecMap;
use vecmap::map::Entry;

let mut map: VecMap<&str, u32> = VecMap::new();
map.entry("poneyland").or_insert(12);
map.entry("foo").or_insert(13);
map.entry("bar").or_insert(14);

if let Entry::Occupied(o) = map.entry("poneyland") {
    // We delete the entry from the map.
    o.remove_entry();
}

assert_eq!(map.contains_key("poneyland"), false);
assert_eq!(map.get_index_of("foo"), Some(0));
assert_eq!(map.get_index_of("bar"), Some(1));
Source

pub fn swap_remove(self) -> V

Removes the key-value pair stored in the map for this entry, and return the value.

Like Vec::swap_remove, the pair is removed by swapping it with the last element of the map and popping it off. This perturbs the position of what used to be the last element!

§Examples
use vecmap::VecMap;
use vecmap::map::Entry;

let mut map: VecMap<&str, u32> = VecMap::new();
map.entry("poneyland").or_insert(12);
map.entry("foo").or_insert(13);
map.entry("bar").or_insert(14);

if let Entry::Occupied(o) = map.entry("poneyland") {
    assert_eq!(o.swap_remove(), 12);
}

assert_eq!(map.contains_key("poneyland"), false);
assert_eq!(map.get_index_of("foo"), Some(1));
assert_eq!(map.get_index_of("bar"), Some(0));
Source

pub fn remove(self) -> V

Removes the key-value pair stored in the map for this entry, and return the value.

Like Vec::remove, the pair is removed by shifting all of the elements that follow it, preserving their relative order. This perturbs the index of all of those elements!

§Examples
use vecmap::VecMap;
use vecmap::map::Entry;

let mut map: VecMap<&str, u32> = VecMap::new();
map.entry("poneyland").or_insert(12);
map.entry("foo").or_insert(13);
map.entry("bar").or_insert(14);

if let Entry::Occupied(o) = map.entry("poneyland") {
    assert_eq!(o.remove(), 12);
}

assert_eq!(map.contains_key("poneyland"), false);
assert_eq!(map.get_index_of("foo"), Some(0));
assert_eq!(map.get_index_of("bar"), Some(1));

Trait Implementations§

Source§

impl<'a, K: Debug, V: 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>
where K: Freeze,

§

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

§

impl<'a, K, V> Send for OccupiedEntry<'a, K, V>
where K: Send, V: Send,

§

impl<'a, K, V> Sync for OccupiedEntry<'a, K, V>
where K: Sync, V: Sync,

§

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

§

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.