memory-cache-rs

Crates.iomemory-cache-rs
lib.rsmemory-cache-rs
version0.2.0
sourcesrc
created_at2020-01-28 11:41:08.71648
updated_at2020-02-05 06:36:31.407324
descriptionSimple local in-memory cache for Rust
homepagehttps://github.com/aikidos/memory-cache-rs
repositoryhttps://github.com/aikidos/memory-cache-rs
max_upload_size
id202741
size18,456
(aikidos)

documentation

https://docs.rs/memory-cache-rs/

README

memory-cache-rs

Simple local in-memory cache for Rust.

  1. Example
  2. Memoization
  3. Breaking Changes
  4. Licence

Example

use std::time::Duration;
use memory_cache::MemoryCache;

let mut cache = MemoryCache::new();

let key: &'static str = "key";
let value: &'static str = "Hello, World!";

// `None` - if the value must be kept forever.
let lifetime = Some(Duration::from_secs(30));

cache.insert(key, value, lifetime);

assert_eq!(cache.get(&key), Some(&value));

Memoization

use once_cell::sync::Lazy;
use std::sync::Mutex;
use memory_cache::{MemoryCache, cached};

cached! {
    fn factorial(x: u128) -> u128 = {
        if x <= 1 {
            1
        } else {
            x * factorial(x - 1)
        }
    }
}

assert_eq!(factorial(21), 51090942171709440000);

Breaking Changes:

0.2.0:

Constructors:

- MemoryCache::new(full_scan_frequency: Duration) -> Self
+ MemoryCache::new() -> Self
+ MemoryCache::with_full_scan(full_scan_frequency: Duration) -> Self

Renamed Methods:

To look like a HashMap.

MemoryCache<A, B> {

-   fn has_key(&self, key: &A) -> bool
+   fn contains_key(&self, key: &A) -> bool

-   fn set(&mut self, key: A, value: B, duration: Option<Duration>) -> Option<B>
+   fn insert(&mut self, key: A, value: B, lifetime: Option<Duration>) -> Option<B>

-   fn get_or_set<F>(&mut self, key: A, factory: F, duration: Option<Duration>) -> &B
+   fn get_or_insert<F>(&mut self, key: A, factory: F, lifetime: Option<Duration>) -> &B

}

Changed types of parameters/results:

MemoryCache<A, B> {

-   fn get_full_scan_frequency(&self) -> &Duration
+   fn get_full_scan_frequency(&self) -> Option<Duration>

}

Licence

MIT

Commit count: 23

cargo fmt