Struct cairo_lang_utils::ordered_hash_map::OrderedHashMap
source · pub struct OrderedHashMap<Key: Hash + Eq, Value>(_);
Implementations§
source§impl<Key: Hash + Eq, Value> OrderedHashMap<Key, Value>
impl<Key: Hash + Eq, Value> OrderedHashMap<Key, Value>
sourcepub fn get<Q: ?Sized + Hash + Equivalent<Key>>(&self, key: &Q) -> Option<&Value>
pub fn get<Q: ?Sized + Hash + Equivalent<Key>>(&self, key: &Q) -> Option<&Value>
Returns a reference to the value stored for key, if it is present, else None.
Computes in O(1) time (average).
sourcepub fn get_mut<Q: ?Sized + Hash + Equivalent<Key>>(
&mut self,
key: &Q
) -> Option<&mut Value>
pub fn get_mut<Q: ?Sized + Hash + Equivalent<Key>>( &mut self, key: &Q ) -> Option<&mut Value>
Returns a mutable reference to the value stored for key, if it is present, else None.
Computes in O(1) time (average).
sourcepub fn entry(&mut self, key: Key) -> Entry<'_, Key, Value>
pub fn entry(&mut self, key: Key) -> Entry<'_, Key, Value>
Gets the given key’s corresponding entry in the map for insertion and/or in-place manipulation.
Computes in O(1) time (amortized average).
sourcepub fn iter(&self) -> Iter<'_, Key, Value>
pub fn iter(&self) -> Iter<'_, Key, Value>
Returns an iterator over the key-value pairs of the map, in their order.
sourcepub fn iter_mut(&mut self) -> IterMut<'_, Key, Value>
pub fn iter_mut(&mut self) -> IterMut<'_, Key, Value>
Returns a mutable iterator over the key-value pairs of the map, in their order.
sourcepub fn keys(&self) -> Keys<'_, Key, Value>
pub fn keys(&self) -> Keys<'_, Key, Value>
Returns an iterator over the keys of the map, in their order.
sourcepub fn into_keys(self) -> IntoKeys<Key, Value>
pub fn into_keys(self) -> IntoKeys<Key, Value>
Returns a consuming iterator over the keys of the map, in their order.
sourcepub fn values(&self) -> Values<'_, Key, Value>
pub fn values(&self) -> Values<'_, Key, Value>
Returns an iterator over the values of the map, in their order.
sourcepub fn insert(&mut self, key: Key, value: Value) -> Option<Value>
pub fn insert(&mut self, key: Key, value: Value) -> Option<Value>
Insert a key-value pair in the map.
If an equivalent key already exists in the map: the key remains and retains in its place in the order, its corresponding value is updated with value and the older value is returned inside Some(_).
If no equivalent key existed in the map: the new key-value pair is inserted, last in order, and None is returned.
Computes in O(1) time (amortized average).
See also entry if you you want to insert or modify or if you need to get the index of the corresponding key-value pair.
sourcepub fn extend<I: IntoIterator<Item = (Key, Value)>>(&mut self, iter: I)
pub fn extend<I: IntoIterator<Item = (Key, Value)>>(&mut self, iter: I)
Extends the map with the content of the given iterator.
sourcepub fn contains_key<Q: ?Sized + Hash + Equivalent<Key>>(&self, key: &Q) -> bool
pub fn contains_key<Q: ?Sized + Hash + Equivalent<Key>>(&self, key: &Q) -> bool
Returns true if an equivalent to key exists in the map.
sourcepub fn shift_remove<Q: ?Sized + Hash + Equivalent<Key>>(
&mut self,
key: &Q
) -> Option<Value>
pub fn shift_remove<Q: ?Sized + Hash + Equivalent<Key>>( &mut self, key: &Q ) -> Option<Value>
Removes the entry for the given key, preserving the order of entries.
Returns the value associated with the key (if present).
sourcepub fn swap_remove<Q: ?Sized + Hash + Equivalent<Key>>(
&mut self,
key: &Q
) -> Option<Value>
pub fn swap_remove<Q: ?Sized + Hash + Equivalent<Key>>( &mut self, key: &Q ) -> Option<Value>
Removes the entry for the given key by swapping it with the last element. Thus the order of elements is not preserved, but the resulting order is still deterministic.
Returns the value associated with the key (if present).
Trait Implementations§
source§impl<Key: Clone + Hash + Eq, Value: Clone> Clone for OrderedHashMap<Key, Value>
impl<Key: Clone + Hash + Eq, Value: Clone> Clone for OrderedHashMap<Key, Value>
source§fn clone(&self) -> OrderedHashMap<Key, Value>
fn clone(&self) -> OrderedHashMap<Key, Value>
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl<'de, Key, Value> Deserialize<'de> for OrderedHashMap<Key, Value>where
Key: Deserialize<'de> + Hash + Eq,
Value: Deserialize<'de>,
impl<'de, Key, Value> Deserialize<'de> for OrderedHashMap<Key, Value>where Key: Deserialize<'de> + Hash + Eq, Value: Deserialize<'de>,
source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where __D: Deserializer<'de>,
source§impl<Key: Hash + Eq, Value, const N: usize> From<[(Key, Value); N]> for OrderedHashMap<Key, Value>
impl<Key: Hash + Eq, Value, const N: usize> From<[(Key, Value); N]> for OrderedHashMap<Key, Value>
source§fn from(init_map: [(Key, Value); N]) -> Self
fn from(init_map: [(Key, Value); N]) -> Self
source§impl<Key: Hash + Eq, Value> FromIterator<(Key, Value)> for OrderedHashMap<Key, Value>
impl<Key: Hash + Eq, Value> FromIterator<(Key, Value)> for OrderedHashMap<Key, Value>
source§fn from_iter<T: IntoIterator<Item = (Key, Value)>>(iter: T) -> Self
fn from_iter<T: IntoIterator<Item = (Key, Value)>>(iter: T) -> Self
source§impl<Key: Hash + Eq, IndexType: Into<Key>, Value> Index<IndexType> for OrderedHashMap<Key, Value>
impl<Key: Hash + Eq, IndexType: Into<Key>, Value> Index<IndexType> for OrderedHashMap<Key, Value>
source§impl<Key: Hash + Eq, IndexType: Into<Key>, Value> IndexMut<IndexType> for OrderedHashMap<Key, Value>
impl<Key: Hash + Eq, IndexType: Into<Key>, Value> IndexMut<IndexType> for OrderedHashMap<Key, Value>
source§fn index_mut(&mut self, index: IndexType) -> &mut Value
fn index_mut(&mut self, index: IndexType) -> &mut Value
container[index]
) operation. Read moresource§impl<Key: Hash + Eq, Value> IntoIterator for OrderedHashMap<Key, Value>
impl<Key: Hash + Eq, Value> IntoIterator for OrderedHashMap<Key, Value>
source§impl<Key: Hash + Eq, Value: Eq> PartialEq<OrderedHashMap<Key, Value>> for OrderedHashMap<Key, Value>
impl<Key: Hash + Eq, Value: Eq> PartialEq<OrderedHashMap<Key, Value>> for OrderedHashMap<Key, Value>
source§impl<Key, Value> Serialize for OrderedHashMap<Key, Value>where
Key: Serialize + Hash + Eq,
Value: Serialize,
impl<Key, Value> Serialize for OrderedHashMap<Key, Value>where Key: Serialize + Hash + Eq, Value: Serialize,
impl<Key: Hash + Eq, Value: Eq> Eq for OrderedHashMap<Key, Value>
Auto Trait Implementations§
impl<Key, Value> RefUnwindSafe for OrderedHashMap<Key, Value>where Key: RefUnwindSafe, Value: RefUnwindSafe,
impl<Key, Value> Send for OrderedHashMap<Key, Value>where Key: Send, Value: Send,
impl<Key, Value> Sync for OrderedHashMap<Key, Value>where Key: Sync, Value: Sync,
impl<Key, Value> Unpin for OrderedHashMap<Key, Value>where Key: Unpin, Value: Unpin,
impl<Key, Value> UnwindSafe for OrderedHashMap<Key, Value>where Key: UnwindSafe, Value: 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<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.§impl<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
§impl<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.