Struct lazycell::LazyCell [−][src]
pub struct LazyCell<T> { /* fields omitted */ }
A lazily filled Cell
, with mutable contents.
A LazyCell
is completely frozen once filled, unless you have &mut
access to it, in which case LazyCell::borrow_mut
may be used to mutate the
contents.
Implementations
impl<T> LazyCell<T>
[src][−]
pub fn new() -> LazyCell<T>
[src][−]
Creates a new, empty, LazyCell
.
pub fn fill(&self, value: T) -> Result<(), T>
[src][−]
Put a value into this cell.
This function will return Err(value)
if the cell is already full.
pub fn replace(&mut self, value: T) -> Option<T>
[src][−]
Put a value into this cell.
Note that this function is infallible but requires &mut self
. By
requiring &mut self
we’re guaranteed that no active borrows to this
cell can exist so we can always fill in the value. This may not always
be usable, however, as &mut self
may not be possible to borrow.
Return value
This function returns the previous value, if any.
pub fn filled(&self) -> bool
[src][−]
Test whether this cell has been previously filled.
pub fn borrow(&self) -> Option<&T>
[src][−]
Borrows the contents of this lazy cell for the duration of the cell itself.
This function will return Some
if the cell has been previously
initialized, and None
if it has not yet been initialized.
pub fn borrow_mut(&mut self) -> Option<&mut T>
[src][−]
Borrows the contents of this lazy cell mutably for the duration of the cell itself.
This function will return Some
if the cell has been previously
initialized, and None
if it has not yet been initialized.
pub fn borrow_with<F: FnOnce() -> T>(&self, f: F) -> &T
[src][−]
Borrows the contents of this lazy cell for the duration of the cell itself.
If the cell has not yet been filled, the cell is first filled using the function provided.
Panics
Panics if the cell becomes filled as a side effect of f
.
pub fn borrow_mut_with<F: FnOnce() -> T>(&mut self, f: F) -> &mut T
[src][−]
Borrows the contents of this LazyCell
mutably for the duration of the
cell itself.
If the cell has not yet been filled, the cell is first filled using the function provided.
Panics
Panics if the cell becomes filled as a side effect of f
.
pub fn try_borrow_with<E, F>(&self, f: F) -> Result<&T, E> where
F: FnOnce() -> Result<T, E>,
[src][−]
F: FnOnce() -> Result<T, E>,
Same as borrow_with
, but allows the initializing function to fail.
Panics
Panics if the cell becomes filled as a side effect of f
.
pub fn try_borrow_mut_with<E, F>(&mut self, f: F) -> Result<&mut T, E> where
F: FnOnce() -> Result<T, E>,
[src][−]
F: FnOnce() -> Result<T, E>,
Same as borrow_mut_with
, but allows the initializing function to fail.
Panics
Panics if the cell becomes filled as a side effect of f
.
pub fn into_inner(self) -> Option<T>
[src][−]
Consumes this LazyCell
, returning the underlying value.
impl<T: Copy> LazyCell<T>
[src][−]
pub fn get(&self) -> Option<T>
[src][−]
Returns a copy of the contents of the lazy cell.
This function will return Some
if the cell has been previously initialized,
and None
if it has not yet been initialized.
Trait Implementations
impl<T: Clone> Clone for LazyCell<T>
[src][+]
impl<T: Debug> Debug for LazyCell<T>
[src][+]
impl<T> Default for LazyCell<T>
[src][+]
Auto Trait Implementations
impl<T> Send for LazyCell<T> where
T: Send,
T: Send,
impl<T> !Sync for LazyCell<T>
impl<T> Unpin for LazyCell<T> where
T: Unpin,
T: Unpin,
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src][+]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src][+]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src][+]
T: ?Sized,
impl<T> From<T> for T
[src][+]
impl<T, U> Into<U> for T where
U: From<T>,
[src][+]
U: From<T>,
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src][+]
U: Into<T>,
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src][+]
U: TryFrom<T>,