Struct fn_cache::BTreeCache

source ·
pub struct BTreeCache<'f, I, O>where
    I: Ord,{ /* private fields */ }
Expand description

A cache for a function which uses a BTreeMap.

The cache takes ownership of all inputs, but only passes a reference to the function, allowing it to store the input in the cache without any copies or clones.

The requirements for a BTreeMap must be met, specifically the keys must implement Ord

Implementations§

source§

impl<'f, I, O> BTreeCache<'f, I, O>where I: Ord,

source

pub fn new<F>(f: F) -> Selfwhere F: Fn(&I) -> O + 'f + Send + Sync,

Create a cache for the provided function. If the function stores references, the cache can only live as long as those references.

source

pub fn recursive<F>(f: F) -> Selfwhere F: Fn(&mut Self, &I) -> O + 'f + Send + Sync,

Create a cache for the provided recursive function. If the function stores references, the cache can only live as long as those references.

source

pub fn clear(&mut self)

Clears the cache, removing all key-value pairs. Keeps the allocated memory for reuse.

source

pub fn len(&self) -> usize

Returns the number of elements in the cache.

source

pub fn remove(&mut self, input: &I) -> Option<O>

Removes the input from the cache, returning any value if the input was previously in the cache.

Trait Implementations§

source§

impl<'f, I, O> FnCache<I, O> for BTreeCache<'f, I, O>where I: Ord,

source§

fn get(&mut self, input: I) -> &O

Retrieve a value stored in the cache. If the value does not yet exist in the cache, the function is called, and the result is added to the cache before returning it.
source§

impl<'f, I, O> FnCacheMany<I, O> for BTreeCache<'f, I, O>where I: Ord + Clone,

source§

fn get_many<const N: usize>(&mut self, inputs: [I; N]) -> [&O; N]

Retrieve multiple values stored in the cache. If any of the values do not yet exist, the function is called, and the result is added to the cache before returning them. Read more

Auto Trait Implementations§

§

impl<'f, I, O> !RefUnwindSafe for BTreeCache<'f, I, O>

§

impl<'f, I, O> Send for BTreeCache<'f, I, O>where I: Send, O: Send,

§

impl<'f, I, O> Sync for BTreeCache<'f, I, O>where I: Sync, O: Sync,

§

impl<'f, I, O> Unpin for BTreeCache<'f, I, O>

§

impl<'f, I, O> !UnwindSafe for BTreeCache<'f, I, O>

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.