use super::ReadGuard;
use crate::{inner::Inner, values::Values};
use std::borrow::Borrow;
use std::collections::hash_map::RandomState;
use std::hash::{BuildHasher, Hash};
use std::mem::ManuallyDrop;
#[derive(Debug)]
pub struct MapReadRef<'rh, K, V, M = (), S = RandomState>
where
K: Hash + Eq,
V: Eq + Hash,
S: BuildHasher,
{
pub(super) guard: ReadGuard<'rh, Inner<K, ManuallyDrop<V>, M, S>>,
}
impl<'rh, K, V, M, S> MapReadRef<'rh, K, V, M, S>
where
K: Hash + Eq,
V: Eq + Hash,
S: BuildHasher,
{
pub fn iter(&self) -> ReadGuardIter<'_, K, V, S> {
ReadGuardIter {
iter: Some(self.guard.data.iter()),
}
}
pub fn len(&self) -> usize {
self.guard.data.len()
}
pub fn is_empty(&self) -> bool {
self.guard.data.is_empty()
}
pub fn meta(&self) -> &M {
&self.guard.meta
}
pub fn get<'a, Q: ?Sized>(&'a self, key: &'_ Q) -> Option<&'a Values<V, S>>
where
K: Borrow<Q>,
Q: Hash + Eq,
{
self.guard.data.get(key).map(Values::user_friendly)
}
pub fn get_one<'a, Q: ?Sized>(&'a self, key: &'_ Q) -> Option<&'a V>
where
K: Borrow<Q>,
Q: Hash + Eq,
{
self.guard
.data
.get(key)
.and_then(|values| values.user_friendly().get_one())
}
pub fn contains_key<Q: ?Sized>(&self, key: &Q) -> bool
where
K: Borrow<Q>,
Q: Hash + Eq,
{
self.guard.data.contains_key(key)
}
pub fn contains_value<Q: ?Sized, W: ?Sized>(&self, key: &Q, value: &W) -> bool
where
K: Borrow<Q>,
V: Borrow<W>,
Q: Hash + Eq,
W: Hash + Eq,
{
self.guard
.data
.get(key)
.map_or(false, |values| values.user_friendly().contains(value))
}
}
impl<'rh, K, Q, V, M, S> std::ops::Index<&'_ Q> for MapReadRef<'rh, K, V, M, S>
where
K: Eq + Hash + Borrow<Q>,
V: Eq + Hash,
Q: Eq + Hash + ?Sized,
S: BuildHasher,
{
type Output = Values<V, S>;
fn index(&self, key: &Q) -> &Self::Output {
self.get(key).unwrap()
}
}
impl<'rg, 'rh, K, V, M, S> IntoIterator for &'rg MapReadRef<'rh, K, V, M, S>
where
K: Eq + Hash,
V: Eq + Hash,
S: BuildHasher,
{
type Item = (&'rg K, &'rg Values<V, S>);
type IntoIter = ReadGuardIter<'rg, K, V, S>;
fn into_iter(self) -> Self::IntoIter {
self.iter()
}
}
#[derive(Debug)]
pub struct ReadGuardIter<'rg, K, V, S>
where
K: Eq + Hash,
V: Eq + Hash,
S: BuildHasher,
{
iter: Option<
<&'rg crate::inner::MapImpl<K, Values<ManuallyDrop<V>, S>, S> as IntoIterator>::IntoIter,
>,
}
impl<'rg, K, V, S> Iterator for ReadGuardIter<'rg, K, V, S>
where
K: Eq + Hash,
V: Eq + Hash,
S: BuildHasher,
{
type Item = (&'rg K, &'rg Values<V, S>);
fn next(&mut self) -> Option<Self::Item> {
self.iter
.as_mut()
.and_then(|iter| iter.next().map(|(k, v)| (k, v.user_friendly())))
}
}