Interior mutability, write-once and borrowable as plain &T
This library provides interior mutability that can be borrowed
as plain immutable references &T
in exchange for the write-once,
read-many restriction.
Unlike std::cell::Cell
or std::cell::RefCell
, a plain immutable
reference &T
can be taken from MutOnce<T>
. Once an immutable
reference is taken, the value can never be mutated (even after all
references are dropped).
The use cases include caching getter and delayed evaluation.
Usage
Run "cargo doc" in the source directory to generate the API reference. It is also available online at https://docs.rs/mutate_once.
An example follows:
struct Container {
expensive: MutOnce<String>,
}
impl Container {
fn expensive(&self) -> &str {
if !self.expensive.is_fixed() {
let mut ref_mut = self.expensive.get_mut();
*ref_mut += "expensive";
// Drop `ref_mut` before calling `get_ref`.
}
// A plain reference can be returned to the caller
// unlike `Cell` or `RefCell`.
self.expensive.get_ref()
}
}
let container = Container { expensive: MutOnce::new(String::new()) };
assert_eq!(container.expensive(), "expensive");