use std::borrow::Borrow;
use std::collections::HashMap;
use std::hash::Hash;
pub trait Map<K, V> {
fn len(&self) -> usize;
#[inline]
fn is_empty(&self) -> bool {
self.len() == 0
}
fn clear(&mut self);
#[inline]
fn contains_key<Q: ?Sized>(&self, k: &Q) -> bool
where
K: Hash + Eq + Borrow<Q>,
Q: Hash + Eq,
{
self.get(k).is_some()
}
fn get<Q: ?Sized>(&self, k: &Q) -> Option<&V>
where
K: Hash + Eq + Borrow<Q>,
Q: Hash + Eq;
fn get_mut<Q: ?Sized>(&mut self, k: &Q) -> Option<&mut V>
where
K: Hash + Eq + Borrow<Q>,
Q: Hash + Eq;
fn insert<T: Into<V>>(&mut self, k: K, v: T) -> Result<(), (K, T)>
where
K: Hash + Eq;
#[inline]
fn remove<Q: ?Sized>(&mut self, k: &Q) -> Option<V>
where
K: Hash + Eq + Borrow<Q>,
Q: Hash + Eq,
{
self.remove_entry(k).map(|(_, v)| v)
}
fn remove_entry<Q: ?Sized>(&mut self, k: &Q) -> Option<(K, V)>
where
K: Hash + Eq + Borrow<Q>,
Q: Hash + Eq;
}
impl<K, V> Map<K, V> for HashMap<K, V> {
#[inline]
fn len(&self) -> usize {
self.len()
}
#[inline]
fn clear(&mut self) {
self.clear()
}
#[inline]
fn get<Q: ?Sized>(&self, k: &Q) -> Option<&V>
where
K: Hash + Eq + Borrow<Q>,
Q: Hash + Eq,
{
self.get(k)
}
#[inline]
fn get_mut<Q: ?Sized>(&mut self, k: &Q) -> Option<&mut V>
where
K: Hash + Eq + Borrow<Q>,
Q: Hash + Eq,
{
self.get_mut(k)
}
#[inline]
#[allow(clippy::map_entry)]
fn insert<T: Into<V>>(&mut self, k: K, v: T) -> Result<(), (K, T)>
where
K: Hash + Eq,
{
if self.contains_key(&k) {
Err((k, v))
} else {
self.insert(k, v.into());
Ok(())
}
}
#[inline]
fn remove_entry<Q: ?Sized>(&mut self, k: &Q) -> Option<(K, V)>
where
K: Hash + Eq + Borrow<Q>,
Q: Hash + Eq,
{
self.remove_entry(k)
}
}