use std::collections::hash_map::Entry;
use std::collections::{HashMap, HashSet};
use std::hash::Hash;
use std::ops::Index;
#[derive(Clone, Debug, Default)]
pub struct StableSet<T>(HashSet<T>);
impl<T> StableSet<T> {
pub(crate) fn new() -> Self {
StableSet(HashSet::new())
}
}
impl<T: Hash + Eq> StableSet<T> {
pub fn insert(&mut self, val: T) -> bool {
self.0.insert(val)
}
pub fn contains(&self, val: &T) -> bool {
self.0.contains(val)
}
}
#[derive(Clone, Debug)]
pub struct StableMap<K, V>(HashMap<K, V>);
impl<K, V> StableMap<K, V> {
pub(crate) fn new() -> Self {
StableMap(HashMap::new())
}
pub(crate) fn len(&self) -> usize {
self.0.len()
}
}
impl<K, V> Default for StableMap<K, V> {
fn default() -> Self {
StableMap(HashMap::new())
}
}
impl<K: Hash + Eq, V> StableMap<K, V> {
pub(crate) fn insert(&mut self, k: K, v: V) -> Option<V> {
self.0.insert(k, v)
}
pub(crate) fn contains_key(&self, k: &K) -> bool {
self.0.contains_key(k)
}
pub(crate) fn get(&self, k: &K) -> Option<&V> {
self.0.get(k)
}
pub(crate) fn entry(&mut self, k: K) -> Entry<K, V> {
self.0.entry(k)
}
}
impl<K: Hash + Eq, V> Index<&K> for StableMap<K, V> {
type Output = V;
fn index(&self, index: &K) -> &Self::Output {
self.0.index(index)
}
}