2023-05-15 20:48:59 +03:00
|
|
|
use quick_cache::{DefaultHashBuilder, UnitWeighter, Weighter};
|
|
|
|
use std::{
|
|
|
|
future::Future,
|
|
|
|
hash::{BuildHasher, Hash},
|
2023-05-18 23:34:22 +03:00
|
|
|
sync::Arc,
|
2023-05-15 20:48:59 +03:00
|
|
|
time::Duration,
|
|
|
|
};
|
|
|
|
|
|
|
|
use crate::{KQCacheWithTTL, PlaceholderGuardWithTTL};
|
|
|
|
|
2023-05-18 23:34:22 +03:00
|
|
|
pub struct CacheWithTTL<Key, Val, We = UnitWeighter, B = DefaultHashBuilder>(
|
|
|
|
KQCacheWithTTL<Key, (), Val, We, B>,
|
|
|
|
);
|
2023-05-15 20:48:59 +03:00
|
|
|
|
|
|
|
impl<Key: Eq + Hash + Clone + Send + Sync + 'static, Val: Clone + Send + Sync + 'static>
|
|
|
|
CacheWithTTL<Key, Val, UnitWeighter, DefaultHashBuilder>
|
|
|
|
{
|
2023-05-18 23:34:22 +03:00
|
|
|
pub async fn new_with_capacity(capacity: usize, ttl: Duration) -> Self {
|
2023-05-15 20:48:59 +03:00
|
|
|
Self::new(
|
2023-05-18 23:34:22 +03:00
|
|
|
capacity,
|
|
|
|
capacity as u64,
|
2023-05-15 20:48:59 +03:00
|
|
|
UnitWeighter,
|
|
|
|
DefaultHashBuilder::default(),
|
|
|
|
ttl,
|
|
|
|
)
|
|
|
|
.await
|
|
|
|
}
|
2023-05-18 23:34:22 +03:00
|
|
|
|
|
|
|
pub async fn arc_with_capacity(capacity: usize, ttl: Duration) -> Arc<Self> {
|
|
|
|
let x = Self::new_with_capacity(capacity, ttl).await;
|
|
|
|
|
|
|
|
Arc::new(x)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<
|
|
|
|
Key: Eq + Hash + Clone + Send + Sync + 'static,
|
|
|
|
Val: Clone + Send + Sync + 'static,
|
|
|
|
We: Weighter<Key, (), Val> + Clone + Send + Sync + 'static,
|
|
|
|
B: BuildHasher + Clone + Default + Send + Sync + 'static,
|
|
|
|
> CacheWithTTL<Key, Val, We, B>
|
|
|
|
{
|
|
|
|
pub async fn new_with_weights(
|
|
|
|
estimated_items_capacity: usize,
|
|
|
|
weight_capacity: u64,
|
|
|
|
weighter: We,
|
|
|
|
ttl: Duration,
|
|
|
|
) -> Self {
|
|
|
|
let inner = KQCacheWithTTL::new(
|
|
|
|
estimated_items_capacity,
|
|
|
|
weight_capacity,
|
|
|
|
weighter,
|
|
|
|
B::default(),
|
|
|
|
ttl,
|
|
|
|
)
|
|
|
|
.await;
|
|
|
|
|
|
|
|
Self(inner)
|
|
|
|
}
|
2023-05-15 20:48:59 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
impl<
|
|
|
|
Key: Eq + Hash + Clone + Send + Sync + 'static,
|
|
|
|
Val: Clone + Send + Sync + 'static,
|
|
|
|
We: Weighter<Key, (), Val> + Clone + Send + Sync + 'static,
|
|
|
|
B: BuildHasher + Clone + Send + Sync + 'static,
|
|
|
|
> CacheWithTTL<Key, Val, We, B>
|
|
|
|
{
|
|
|
|
pub async fn new(
|
|
|
|
estimated_items_capacity: usize,
|
|
|
|
weight_capacity: u64,
|
|
|
|
weighter: We,
|
|
|
|
hash_builder: B,
|
|
|
|
ttl: Duration,
|
|
|
|
) -> Self {
|
|
|
|
let inner = KQCacheWithTTL::new(
|
|
|
|
estimated_items_capacity,
|
|
|
|
weight_capacity,
|
|
|
|
weighter,
|
|
|
|
hash_builder,
|
|
|
|
ttl,
|
|
|
|
)
|
|
|
|
.await;
|
|
|
|
|
|
|
|
Self(inner)
|
|
|
|
}
|
|
|
|
|
2023-05-18 23:34:22 +03:00
|
|
|
#[inline]
|
|
|
|
pub fn get(&self, key: &Key) -> Option<Val> {
|
|
|
|
self.0.get(key, &())
|
|
|
|
}
|
|
|
|
|
2023-05-15 20:48:59 +03:00
|
|
|
#[inline]
|
|
|
|
pub async fn get_or_insert_async<E, Fut>(&self, key: &Key, f: Fut) -> Result<Val, E>
|
|
|
|
where
|
|
|
|
Fut: Future<Output = Result<Val, E>>,
|
|
|
|
{
|
|
|
|
self.0.get_or_insert_async(key, &(), f).await
|
|
|
|
}
|
|
|
|
|
|
|
|
#[inline]
|
|
|
|
pub async fn get_value_or_guard_async(
|
|
|
|
&self,
|
|
|
|
key: Key,
|
|
|
|
) -> Result<Val, PlaceholderGuardWithTTL<'_, Key, (), Val, We, B>> {
|
|
|
|
self.0.get_value_or_guard_async(key, ()).await
|
|
|
|
}
|
|
|
|
|
|
|
|
#[inline]
|
|
|
|
pub fn insert(&self, key: Key, val: Val) {
|
|
|
|
self.0.insert(key, (), val)
|
|
|
|
}
|
|
|
|
|
|
|
|
#[inline]
|
|
|
|
pub fn remove(&self, key: &Key) -> bool {
|
|
|
|
self.0.remove(key, &())
|
|
|
|
}
|
|
|
|
}
|