pub struct BiMap<K: PartialEq + Clone, V: PartialEq + Clone> { /* private fields */ }Expand description
A bidirectional map where both keys and values are unique.
Provides O(n) forward and reverse lookup, useful for managing bijections between names and indices in the elaboration context.
Implementations§
Source§impl<K: PartialEq + Clone, V: PartialEq + Clone> BiMap<K, V>
impl<K: PartialEq + Clone, V: PartialEq + Clone> BiMap<K, V>
Sourcepub fn insert(&mut self, key: K, value: V)
pub fn insert(&mut self, key: K, value: V)
Insert a (key, value) pair, evicting any existing entries that conflict.
Sourcepub fn get_by_key(&self, key: &K) -> Option<&V>
pub fn get_by_key(&self, key: &K) -> Option<&V>
Forward lookup: key → value.
Sourcepub fn get_by_val(&self, val: &V) -> Option<&K>
pub fn get_by_val(&self, val: &V) -> Option<&K>
Reverse lookup: value → key.
Sourcepub fn remove_by_key(&mut self, key: &K) -> Option<V>
pub fn remove_by_key(&mut self, key: &K) -> Option<V>
Remove by key.
Sourcepub fn remove_by_val(&mut self, val: &V) -> Option<K>
pub fn remove_by_val(&mut self, val: &V) -> Option<K>
Remove by value.
Sourcepub fn contains_key(&self, key: &K) -> bool
pub fn contains_key(&self, key: &K) -> bool
Check if the key exists.
Sourcepub fn contains_val(&self, val: &V) -> bool
pub fn contains_val(&self, val: &V) -> bool
Check if the value exists.
Trait Implementations§
Source§impl<K: PartialEq + PartialEq + Clone, V: PartialEq + PartialEq + Clone> PartialEq for BiMap<K, V>
impl<K: PartialEq + PartialEq + Clone, V: PartialEq + PartialEq + Clone> PartialEq for BiMap<K, V>
impl<K: PartialEq + Clone, V: PartialEq + Clone> StructuralPartialEq for BiMap<K, V>
Auto Trait Implementations§
impl<K, V> Freeze for BiMap<K, V>
impl<K, V> RefUnwindSafe for BiMap<K, V>where
K: RefUnwindSafe,
V: RefUnwindSafe,
impl<K, V> Send for BiMap<K, V>
impl<K, V> Sync for BiMap<K, V>
impl<K, V> Unpin for BiMap<K, V>
impl<K, V> UnsafeUnpin for BiMap<K, V>
impl<K, V> UnwindSafe for BiMap<K, V>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
Mutably borrows from an owned value. Read more