Sha256: 21bc1a7d8593c11e93577f1f17163705dbbadf752a007fae4401a4150ec9e473
Contents?: true
Size: 866 Bytes
Versions: 7
Compression:
Stored size: 866 Bytes
Contents
use core::cell::UnsafeCell; pub struct LazyCell<T> { contents: UnsafeCell<Option<T>>, } impl<T> LazyCell<T> { pub fn new() -> LazyCell<T> { LazyCell { contents: UnsafeCell::new(None), } } pub fn borrow_with(&self, closure: impl FnOnce() -> T) -> &T { // First check if we're already initialized... let ptr = self.contents.get(); if let Some(val) = unsafe { &*ptr } { return val; } // Note that while we're executing `closure` our `borrow_with` may // be called recursively. This means we need to check again after // the closure has executed. For that we use the `get_or_insert` // method which will only perform mutation if we aren't already // `Some`. let val = closure(); unsafe { (*ptr).get_or_insert(val) } } }
Version data entries
7 entries across 7 versions & 1 rubygems