pub struct InlineScanMap<K, V, const SZ: usize> { /* private fields */ }Expand description
A general-purpose map implemented using linear scanning.
§Type Parameters
K: The key type.V: The value type.SZ: The number of entries in the map.
Implementations§
Source§impl<K, V, const SZ: usize> InlineScanMap<K, V, SZ>
impl<K, V, const SZ: usize> InlineScanMap<K, V, SZ>
Sourcepub fn new(entries: Vec<(K, V)>) -> Selfwhere
K: Eq,
pub fn new(entries: Vec<(K, V)>) -> Selfwhere
K: Eq,
Creates a frozen map.
§Panics
Panics if the number of entries in the array differs from the size of the map as specified by the SZ generic argument.
Sourcepub fn get<Q>(&self, key: &Q) -> Option<&V>where
Q: ?Sized + Equivalent<K>,
pub fn get<Q>(&self, key: &Q) -> Option<&V>where
Q: ?Sized + Equivalent<K>,
Returns a reference to the value corresponding to the key.
The key may be any borrowed form of the map’s key type.
Sourcepub fn get_mut<Q>(&mut self, key: &Q) -> Option<&mut V>where
Q: ?Sized + Equivalent<K>,
pub fn get_mut<Q>(&mut self, key: &Q) -> Option<&mut V>where
Q: ?Sized + Equivalent<K>,
Returns a mutable reference to the value corresponding to the key.
The key may be any borrowed form of the map’s key type.
Sourcepub fn get_key_value<Q>(&self, key: &Q) -> Option<(&K, &V)>where
Q: ?Sized + Equivalent<K>,
pub fn get_key_value<Q>(&self, key: &Q) -> Option<(&K, &V)>where
Q: ?Sized + Equivalent<K>,
Returns the key-value pair corresponding to the supplied key.
This is potentially useful:
-
for key types where non-identical keys can be considered equal;
-
for getting the &K stored key value from a borrowed &Q lookup key; or
-
for getting a reference to a key with the same lifetime as the collection.
-
The supplied key may be any borrowed form of the map’s key type, but Hash and Eq on the borrowed form must match those for the key type.
Sourcepub fn contains_key<Q>(&self, key: &Q) -> boolwhere
Q: ?Sized + Equivalent<K>,
pub fn contains_key<Q>(&self, key: &Q) -> boolwhere
Q: ?Sized + Equivalent<K>,
Returns true if the map contains a value for the specified key.
The key may be any borrowed form of the map’s key type.
Sourcepub fn get_disjoint_mut<Q, const N: usize>(
&mut self,
keys: [&Q; N],
) -> [Option<&mut V>; N]
pub fn get_disjoint_mut<Q, const N: usize>( &mut self, keys: [&Q; N], ) -> [Option<&mut V>; N]
Gets multiple mutable values from the map.
§Panics
Panics if the same key is specified multiple times.
Sourcepub unsafe fn get_disjoint_unchecked_mut<Q, const N: usize>(
&mut self,
keys: [&Q; N],
) -> [Option<&mut V>; N]where
Q: ?Sized + Equivalent<K>,
pub unsafe fn get_disjoint_unchecked_mut<Q, const N: usize>(
&mut self,
keys: [&Q; N],
) -> [Option<&mut V>; N]where
Q: ?Sized + Equivalent<K>,
Gets multiple mutable values from the map.
§Safety
Calling this method with overlapping keys is undefined behavior even if the resulting references are not used.
Sourcepub fn iter_mut(&mut self) -> IterMut<'_, K, V> ⓘ
pub fn iter_mut(&mut self) -> IterMut<'_, K, V> ⓘ
An iterator producing mutable references to all entries in arbitrary order.
Sourcepub fn into_keys(self) -> IntoKeys<K, V> ⓘ
pub fn into_keys(self) -> IntoKeys<K, V> ⓘ
A consuming iterator visiting all keys in arbitrary order.
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 arbitrary order.
Sourcepub fn into_values(self) -> IntoValues<K, V> ⓘ
pub fn into_values(self) -> IntoValues<K, V> ⓘ
A consuming iterator visiting all values in arbitrary order.
Trait Implementations§
Source§impl<K: Clone, V: Clone, const SZ: usize> Clone for InlineScanMap<K, V, SZ>
impl<K: Clone, V: Clone, const SZ: usize> Clone for InlineScanMap<K, V, SZ>
Source§fn clone(&self) -> InlineScanMap<K, V, SZ>
fn clone(&self) -> InlineScanMap<K, V, SZ>
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl<K, V, const SZ: usize> Debug for InlineScanMap<K, V, SZ>
impl<K, V, const SZ: usize> Debug for InlineScanMap<K, V, SZ>
Source§impl<Q, K, V, const SZ: usize> Index<&Q> for InlineScanMap<K, V, SZ>where
Q: ?Sized + Equivalent<K>,
impl<Q, K, V, const SZ: usize> Index<&Q> for InlineScanMap<K, V, SZ>where
Q: ?Sized + Equivalent<K>,
Source§impl<'a, K, V, const SZ: usize> IntoIterator for &'a InlineScanMap<K, V, SZ>
impl<'a, K, V, const SZ: usize> IntoIterator for &'a InlineScanMap<K, V, SZ>
Source§impl<'a, K, V, const SZ: usize> IntoIterator for &'a mut InlineScanMap<K, V, SZ>
impl<'a, K, V, const SZ: usize> IntoIterator for &'a mut InlineScanMap<K, V, SZ>
Source§impl<K, V, const SZ: usize> IntoIterator for InlineScanMap<K, V, SZ>
impl<K, V, const SZ: usize> IntoIterator for InlineScanMap<K, V, SZ>
Source§impl<K, V, const SZ: usize> Len for InlineScanMap<K, V, SZ>
impl<K, V, const SZ: usize> Len for InlineScanMap<K, V, SZ>
Source§impl<K, V, Q, const SZ: usize> MapExtras<K, V, Q> for InlineScanMap<K, V, SZ>where
Q: ?Sized + Equivalent<K>,
impl<K, V, Q, const SZ: usize> MapExtras<K, V, Q> for InlineScanMap<K, V, SZ>where
Q: ?Sized + Equivalent<K>,
Source§impl<K, V, const SZ: usize> MapIteration<K, V> for InlineScanMap<K, V, SZ>
impl<K, V, const SZ: usize> MapIteration<K, V> for InlineScanMap<K, V, SZ>
Source§type Iterator<'a> = Iter<'a, K, V>
where
K: 'a,
V: 'a
type Iterator<'a> = Iter<'a, K, V> where K: 'a, V: 'a
Self::iter.Source§type KeyIterator<'a> = Keys<'a, K, V>
where
K: 'a,
V: 'a
type KeyIterator<'a> = Keys<'a, K, V> where K: 'a, V: 'a
Self::keys.Source§type ValueIterator<'a> = Values<'a, K, V>
where
K: 'a,
V: 'a
type ValueIterator<'a> = Values<'a, K, V> where K: 'a, V: 'a
Self::values.Source§type MutIterator<'a> = IterMut<'a, K, V>
where
K: 'a,
V: 'a
type MutIterator<'a> = IterMut<'a, K, V> where K: 'a, V: 'a
Self::iter_mut.Source§type ValueMutIterator<'a> = ValuesMut<'a, K, V>
where
K: 'a,
V: 'a
type ValueMutIterator<'a> = ValuesMut<'a, K, V> where K: 'a, V: 'a
Self::values_mut.Source§type IntoKeyIterator = IntoKeys<K, V>
type IntoKeyIterator = IntoKeys<K, V>
Self::into_keys.Source§type IntoValueIterator = IntoValues<K, V>
type IntoValueIterator = IntoValues<K, V>
Self::into_values.Source§fn iter_mut(&mut self) -> Self::MutIterator<'_>
fn iter_mut(&mut self) -> Self::MutIterator<'_>
Source§fn keys(&self) -> Self::KeyIterator<'_>
fn keys(&self) -> Self::KeyIterator<'_>
Source§fn into_keys(self) -> Self::IntoKeyIterator
fn into_keys(self) -> Self::IntoKeyIterator
Source§fn values(&self) -> Self::ValueIterator<'_>
fn values(&self) -> Self::ValueIterator<'_>
Source§fn values_mut(&mut self) -> Self::ValueMutIterator<'_>
fn values_mut(&mut self) -> Self::ValueMutIterator<'_>
Source§fn into_values(self) -> Self::IntoValueIterator
fn into_values(self) -> Self::IntoValueIterator
Source§impl<K, V, Q, const SZ: usize> MapQuery<Q, V> for InlineScanMap<K, V, SZ>where
Q: ?Sized + Equivalent<K>,
impl<K, V, Q, const SZ: usize> MapQuery<Q, V> for InlineScanMap<K, V, SZ>where
Q: ?Sized + Equivalent<K>,
Source§impl<K, V, MT, const N: usize> PartialEq<MT> for InlineScanMap<K, V, N>
impl<K, V, MT, const N: usize> PartialEq<MT> for InlineScanMap<K, V, N>
Source§impl<K, V, const SZ: usize> Serialize for InlineScanMap<K, V, SZ>
Available on crate feature serde only.
impl<K, V, const SZ: usize> Serialize for InlineScanMap<K, V, SZ>
serde only.impl<K, V, const N: usize> Eq for InlineScanMap<K, V, N>
impl<K, V, Q, const SZ: usize> Map<K, V, Q> for InlineScanMap<K, V, SZ>where
Q: ?Sized + Equivalent<K>,
Auto Trait Implementations§
impl<K, V, const SZ: usize> Freeze for InlineScanMap<K, V, SZ>
impl<K, V, const SZ: usize> RefUnwindSafe for InlineScanMap<K, V, SZ>where
K: RefUnwindSafe,
V: RefUnwindSafe,
impl<K, V, const SZ: usize> Send for InlineScanMap<K, V, SZ>
impl<K, V, const SZ: usize> Sync for InlineScanMap<K, V, SZ>
impl<K, V, const SZ: usize> Unpin for InlineScanMap<K, V, SZ>
impl<K, V, const SZ: usize> UnsafeUnpin for InlineScanMap<K, V, SZ>where
K: UnsafeUnpin,
V: UnsafeUnpin,
impl<K, V, const SZ: usize> UnwindSafe for InlineScanMap<K, V, SZ>where
K: UnwindSafe,
V: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key and return true if they are equal.