Crates.io | pantry |
lib.rs | pantry |
version | 1.0.2 |
source | src |
created_at | 2020-10-28 19:17:48.420208 |
updated_at | 2020-12-08 20:53:20.974048 |
description | Temporary storage for reusing values that may decay |
homepage | |
repository | https://github.com/rhymu8354/Pantry.git |
max_upload_size | |
id | 306430 |
size | 29,440 |
The Pantry
is useful for temporarily storing for later use values that
might "decay" (become unusable) over time, such as:
More information can be found in the crate documentation.
Create a Pantry
value and use its store
function to store values for later
use. A key is provided along with the value, so that the value can be
retrieved later using the same key. A worker thread is spawned which monitors
the values and automatically drops any which have "decayed". Values must
implement the Perishable
trait, whose perished
function asynchronously
completes once the value has decayed.
Use the fetch
asynchronous function on the Pantry
with a key to retrieve a
value previously stored using that key. A value is only returned if it was
stored using the same key and has not decayed since it was stored.
Multiple values may have the same key, with the caveat that the values stored under a given key may not be returned in the same order in which they were stored.
This crate uses a custom configuration for rustfmt
which relies on unstable
features. Attempting cargo fmt
on the stable toolchain may fail. Use cargo +nightly fmt
to format the code.
Licensed under the MIT license.