pub struct HopSlotMap<K: Key, V> { /* private fields */ }SlotMap or DenseSlotMap instead, the HopSlotMap is no longer maintained and will be removed in 2.0.Expand description
Hop slot map, storage with stable unique keys.
See crate documentation for more details.
Implementationsยง
Sourceยงimpl<V> HopSlotMap<DefaultKey, V>
impl<V> HopSlotMap<DefaultKey, V>
Sourcepub fn with_capacity(capacity: usize) -> Self
pub fn with_capacity(capacity: usize) -> Self
Creates an empty HopSlotMap with the given capacity.
The slot map will not reallocate until it holds at least capacity
elements.
ยงExamples
let mut sm: HopSlotMap<_, i32> = HopSlotMap::with_capacity(10);Sourceยงimpl<K: Key, V> HopSlotMap<K, V>
impl<K: Key, V> HopSlotMap<K, V>
Sourcepub fn with_key() -> Self
pub fn with_key() -> Self
Constructs a new, empty HopSlotMap with a custom key type.
ยงExamples
new_key_type! {
struct PositionKey;
}
let mut positions: HopSlotMap<PositionKey, i32> = HopSlotMap::with_key();Sourcepub fn with_capacity_and_key(capacity: usize) -> Self
pub fn with_capacity_and_key(capacity: usize) -> Self
Creates an empty HopSlotMap with the given capacity and a custom key
type.
The slot map will not reallocate until it holds at least capacity
elements.
ยงExamples
new_key_type! {
struct MessageKey;
}
let mut messages = HopSlotMap::with_capacity_and_key(3);
let welcome: MessageKey = messages.insert("Welcome");
let good_day = messages.insert("Good day");
let hello = messages.insert("Hello");Sourcepub fn len(&self) -> usize
pub fn len(&self) -> usize
Returns the number of elements in the slot map.
ยงExamples
let mut sm = HopSlotMap::with_capacity(10);
sm.insert("len() counts actual elements, not capacity");
let key = sm.insert("removed elements don't count either");
sm.remove(key);
assert_eq!(sm.len(), 1);Sourcepub fn is_empty(&self) -> bool
pub fn is_empty(&self) -> bool
Returns if the slot map is empty.
ยงExamples
let mut sm = HopSlotMap::new();
let key = sm.insert("dummy");
assert_eq!(sm.is_empty(), false);
sm.remove(key);
assert_eq!(sm.is_empty(), true);Sourcepub fn capacity(&self) -> usize
pub fn capacity(&self) -> usize
Returns the number of elements the HopSlotMap can hold without
reallocating.
ยงExamples
let sm: HopSlotMap<_, f64> = HopSlotMap::with_capacity(10);
assert_eq!(sm.capacity(), 10);Sourcepub fn reserve(&mut self, additional: usize)
pub fn reserve(&mut self, additional: usize)
Reserves capacity for at least additional more elements to be inserted
in the HopSlotMap. The collection may reserve more space to
avoid frequent reallocations.
ยงPanics
Panics if the new allocation size overflows usize.
ยงExamples
let mut sm = HopSlotMap::new();
sm.insert("foo");
sm.reserve(32);
assert!(sm.capacity() >= 33);Sourcepub fn try_reserve(&mut self, additional: usize) -> Result<(), TryReserveError>
pub fn try_reserve(&mut self, additional: usize) -> Result<(), TryReserveError>
Tries to reserve capacity for at least additional more elements to be
inserted in the HopSlotMap. The collection may reserve more space to
avoid frequent reallocations.
ยงExamples
let mut sm = HopSlotMap::new();
sm.insert("foo");
sm.try_reserve(32).unwrap();
assert!(sm.capacity() >= 33);Sourcepub fn contains_key(&self, key: K) -> bool
pub fn contains_key(&self, key: K) -> bool
Sourcepub fn insert_with_key<F>(&mut self, f: F) -> Kwhere
F: FnOnce(K) -> V,
pub fn insert_with_key<F>(&mut self, f: F) -> Kwhere
F: FnOnce(K) -> V,
Inserts a value given by f into the slot map. The key where the
value will be stored is passed into f. This is useful to store values
that contain their own key.
ยงPanics
Panics if the number of elements in the slot map equals 232 - 2.
ยงExamples
let mut sm = HopSlotMap::new();
let key = sm.insert_with_key(|k| (k, 20));
assert_eq!(sm[key], (key, 20));Sourcepub fn try_insert_with_key<F, E>(&mut self, f: F) -> Result<K, E>
pub fn try_insert_with_key<F, E>(&mut self, f: F) -> Result<K, E>
Inserts a value given by f into the slot map. The key where the
value will be stored is passed into f. This is useful to store values
that contain their own key.
If f returns Err, this method returns the error. The slotmap is untouched.
ยงPanics
Panics if the number of elements in the slot map equals 232 - 2.
ยงExamples
let mut sm = HopSlotMap::new();
let key = sm.try_insert_with_key::<_, ()>(|k| Ok((k, 20))).unwrap();
assert_eq!(sm[key], (key, 20));
sm.try_insert_with_key::<_, ()>(|k| Err(())).unwrap_err();Sourcepub fn remove(&mut self, key: K) -> Option<V>
pub fn remove(&mut self, key: K) -> Option<V>
Removes a key from the slot map, returning the value at the key if the key was not previously removed.
ยงExamples
let mut sm = HopSlotMap::new();
let key = sm.insert(42);
assert_eq!(sm.remove(key), Some(42));
assert_eq!(sm.remove(key), None);Sourcepub fn retain<F>(&mut self, f: F)
pub fn retain<F>(&mut self, f: F)
Retains only the elements specified by the predicate.
In other words, remove all key-value pairs (k, v) such that
f(k, &mut v) returns false. This method invalidates any removed keys.
ยงExamples
let mut sm = HopSlotMap::new();
let k1 = sm.insert(0);
let k2 = sm.insert(1);
let k3 = sm.insert(2);
sm.retain(|key, val| key == k1 || *val == 1);
assert!(sm.contains_key(k1));
assert!(sm.contains_key(k2));
assert!(!sm.contains_key(k3));
assert_eq!(2, sm.len());Sourcepub fn clear(&mut self)
pub fn clear(&mut self)
Clears the slot map. Keeps the allocated memory for reuse.
ยงExamples
let mut sm = HopSlotMap::new();
for i in 0..10 {
sm.insert(i);
}
assert_eq!(sm.len(), 10);
sm.clear();
assert_eq!(sm.len(), 0);Sourcepub fn drain(&mut self) -> Drain<'_, K, V> โ
pub fn drain(&mut self) -> Drain<'_, K, V> โ
Clears the slot map, returning all key-value pairs in an arbitrary order as an iterator. Keeps the allocated memory for reuse.
When the iterator is dropped all elements in the slot map are removed,
even if the iterator was not fully consumed. If the iterator is not
dropped (using e.g. std::mem::forget), only the elements that were
iterated over are removed.
ยงExamples
let mut sm = HopSlotMap::new();
let k = sm.insert(0);
let v: Vec<_> = sm.drain().collect();
assert_eq!(sm.len(), 0);
assert_eq!(v, vec![(k, 0)]);Sourcepub fn get(&self, key: K) -> Option<&V>
pub fn get(&self, key: K) -> Option<&V>
Returns a reference to the value corresponding to the key.
ยงExamples
let mut sm = HopSlotMap::new();
let key = sm.insert("bar");
assert_eq!(sm.get(key), Some(&"bar"));
sm.remove(key);
assert_eq!(sm.get(key), None);Sourcepub unsafe fn get_unchecked(&self, key: K) -> &V
pub unsafe fn get_unchecked(&self, key: K) -> &V
Returns a reference to the value corresponding to the key without version or bounds checking.
ยงSafety
This should only be used if contains_key(key) is true. Otherwise it is
dangerous undefined behavior.
ยงExamples
let mut sm = HopSlotMap::new();
let key = sm.insert("bar");
assert_eq!(unsafe { sm.get_unchecked(key) }, &"bar");
sm.remove(key);
// sm.get_unchecked(key) is now dangerous!Sourcepub fn get_mut(&mut self, key: K) -> Option<&mut V>
pub fn get_mut(&mut self, key: K) -> Option<&mut V>
Returns a mutable reference to the value corresponding to the key.
ยงExamples
let mut sm = HopSlotMap::new();
let key = sm.insert(3.5);
if let Some(x) = sm.get_mut(key) {
*x += 3.0;
}
assert_eq!(sm[key], 6.5);Sourcepub unsafe fn get_unchecked_mut(&mut self, key: K) -> &mut V
pub unsafe fn get_unchecked_mut(&mut self, key: K) -> &mut V
Returns a mutable reference to the value corresponding to the key without version or bounds checking.
ยงSafety
This should only be used if contains_key(key) is true. Otherwise it is
dangerous undefined behavior.
ยงExamples
let mut sm = HopSlotMap::new();
let key = sm.insert("foo");
unsafe { *sm.get_unchecked_mut(key) = "bar" };
assert_eq!(sm[key], "bar");
sm.remove(key);
// sm.get_unchecked_mut(key) is now dangerous!Sourcepub fn get_disjoint_mut<const N: usize>(
&mut self,
keys: [K; N],
) -> Option<[&mut V; N]>
pub fn get_disjoint_mut<const N: usize>( &mut self, keys: [K; N], ) -> Option<[&mut V; N]>
Returns mutable references to the values corresponding to the given
keys. All keys must be valid and disjoint, otherwise None is
returned.
Requires at least stable Rust version 1.51.
ยงExamples
let mut sm = HopSlotMap::new();
let ka = sm.insert("butter");
let kb = sm.insert("apples");
let kc = sm.insert("charlie");
sm.remove(kc); // Make key c invalid.
assert_eq!(sm.get_disjoint_mut([ka, kb, kc]), None); // Has invalid key.
assert_eq!(sm.get_disjoint_mut([ka, ka]), None); // Not disjoint.
let [a, b] = sm.get_disjoint_mut([ka, kb]).unwrap();
std::mem::swap(a, b);
assert_eq!(sm[ka], "apples");
assert_eq!(sm[kb], "butter");Sourcepub unsafe fn get_disjoint_unchecked_mut<const N: usize>(
&mut self,
keys: [K; N],
) -> [&mut V; N]
pub unsafe fn get_disjoint_unchecked_mut<const N: usize>( &mut self, keys: [K; N], ) -> [&mut V; N]
Returns mutable references to the values corresponding to the given keys. All keys must be valid and disjoint.
Requires at least stable Rust version 1.51.
ยงSafety
This should only be used if contains_key(key) is true for every given
key and no two keys are equal. Otherwise it is potentially unsafe.
ยงExamples
let mut sm = HopSlotMap::new();
let ka = sm.insert("butter");
let kb = sm.insert("apples");
let [a, b] = unsafe { sm.get_disjoint_unchecked_mut([ka, kb]) };
std::mem::swap(a, b);
assert_eq!(sm[ka], "apples");
assert_eq!(sm[kb], "butter");Sourcepub fn iter(&self) -> Iter<'_, K, V> โ
pub fn iter(&self) -> Iter<'_, K, V> โ
An iterator visiting all key-value pairs in an arbitrary order. The
iterator element type is (K, &'a V).
ยงExamples
let mut sm = HopSlotMap::new();
let k0 = sm.insert(0);
let k1 = sm.insert(1);
let k2 = sm.insert(2);
for (k, v) in sm.iter() {
println!("key: {:?}, val: {}", k, v);
}Sourcepub fn iter_mut(&mut self) -> IterMut<'_, K, V> โ
pub fn iter_mut(&mut self) -> IterMut<'_, K, V> โ
An iterator visiting all key-value pairs in an arbitrary order, with
mutable references to the values. The iterator element type is
(K, &'a mut V).
ยงExamples
let mut sm = HopSlotMap::new();
let k0 = sm.insert(10);
let k1 = sm.insert(20);
let k2 = sm.insert(30);
for (k, v) in sm.iter_mut() {
if k != k1 {
*v *= -1;
}
}
assert_eq!(sm[k0], -10);
assert_eq!(sm[k1], 20);
assert_eq!(sm[k2], -30);Sourcepub fn keys(&self) -> Keys<'_, K, V> โ
pub fn keys(&self) -> Keys<'_, K, V> โ
An iterator visiting all keys in an arbitrary order. The iterator
element type is K.
ยงExamples
let mut sm = HopSlotMap::new();
let k0 = sm.insert(10);
let k1 = sm.insert(20);
let k2 = sm.insert(30);
let keys: HashSet<_> = sm.keys().collect();
let check: HashSet<_> = vec![k0, k1, k2].into_iter().collect();
assert_eq!(keys, check);Sourcepub fn values(&self) -> Values<'_, K, V> โ
pub fn values(&self) -> Values<'_, K, V> โ
An iterator visiting all values in an arbitrary order. The iterator
element type is &'a V.
ยงExamples
let mut sm = HopSlotMap::new();
let k0 = sm.insert(10);
let k1 = sm.insert(20);
let k2 = sm.insert(30);
let values: HashSet<_> = sm.values().collect();
let check: HashSet<_> = vec![&10, &20, &30].into_iter().collect();
assert_eq!(values, check);Sourcepub fn values_mut(&mut self) -> ValuesMut<'_, K, V> โ
pub fn values_mut(&mut self) -> ValuesMut<'_, K, V> โ
An iterator visiting all values mutably in an arbitrary order. The
iterator element type is &'a mut V.
ยงExamples
let mut sm = HopSlotMap::new();
sm.insert(1);
sm.insert(2);
sm.insert(3);
sm.values_mut().for_each(|n| { *n *= 3 });
let values: HashSet<_> = sm.into_iter().map(|(_k, v)| v).collect();
let check: HashSet<_> = vec![3, 6, 9].into_iter().collect();
assert_eq!(values, check);