pub struct CacheMiss<'k, Key: ?Sized, Scope, Input, Output, H = DefaultHashBuilder> { /* private fields */ }
Expand description
The result of a failed attempt to retrieve a value from the cache.
Initialize a full CacheEntry
for storage with CacheMiss::init
.
use dyn_cache::local::LocalCache;
let mut cache = LocalCache::default();
let (scope, arg) = (&'a', &1);
let miss = cache.get(scope, arg).expect_err("first access will always be a miss");
Implementations§
Source§impl<'k, Key: ?Sized, Scope, Input, Output, H> CacheMiss<'k, Key, Scope, Input, Output, H>
impl<'k, Key: ?Sized, Scope, Input, Output, H> CacheMiss<'k, Key, Scope, Input, Output, H>
Sourcepub fn init<R>(
self,
query: impl FnOnce(&Input) -> (Output, R),
) -> (CacheEntry<'k, Key, Scope, Input, Output, H>, R)
pub fn init<R>( self, query: impl FnOnce(&Input) -> (Output, R), ) -> (CacheEntry<'k, Key, Scope, Input, Output, H>, R)
Prepare the cache miss to be populated by running query(arg)
,
returning a separate value. The value returned (R
) is typically
derived in some way from the stored Output
.
let (entry, result): (_, Vec<usize>) = miss.init(|&n| {
let v: Vec<usize> = vec![n; n];
(v.clone(), v)
});
cache.store(entry);
assert_eq!(result, vec![1usize]);
Trait Implementations§
Source§impl<'k, Key: Clone + ?Sized, Scope: Clone, Input: Clone, Output: Clone, H: Clone> Clone for CacheMiss<'k, Key, Scope, Input, Output, H>
impl<'k, Key: Clone + ?Sized, Scope: Clone, Input: Clone, Output: Clone, H: Clone> Clone for CacheMiss<'k, Key, Scope, Input, Output, H>
Source§impl<'k, Key: PartialEq + ?Sized, Scope: PartialEq, Input: PartialEq, Output: PartialEq, H: PartialEq> PartialEq for CacheMiss<'k, Key, Scope, Input, Output, H>
impl<'k, Key: PartialEq + ?Sized, Scope: PartialEq, Input: PartialEq, Output: PartialEq, H: PartialEq> PartialEq for CacheMiss<'k, Key, Scope, Input, Output, H>
impl<'k, Key: Eq + ?Sized, Scope: Eq, Input: Eq, Output: Eq, H: Eq> Eq for CacheMiss<'k, Key, Scope, Input, Output, H>
impl<'k, Key: ?Sized, Scope, Input, Output, H> StructuralPartialEq for CacheMiss<'k, Key, Scope, Input, Output, H>
Auto Trait Implementations§
impl<'k, Key, Scope, Input, Output, H> Freeze for CacheMiss<'k, Key, Scope, Input, Output, H>
impl<'k, Key, Scope, Input, Output, H = RandomState> !RefUnwindSafe for CacheMiss<'k, Key, Scope, Input, Output, H>
impl<'k, Key, Scope, Input, Output, H> Send for CacheMiss<'k, Key, Scope, Input, Output, H>
impl<'k, Key, Scope, Input, Output, H> Sync for CacheMiss<'k, Key, Scope, Input, Output, H>
impl<'k, Key, Scope, Input, Output, H> Unpin for CacheMiss<'k, Key, Scope, Input, Output, H>
impl<'k, Key, Scope, Input, Output, H = RandomState> !UnwindSafe for CacheMiss<'k, Key, Scope, Input, Output, H>
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Convert
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Convert
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Convert
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Convert
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.