[−][src]Struct lazycell::LazyCell
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.
Methods
impl<T> LazyCell<T>
[src]
impl<T> LazyCell<T>
pub fn new() -> LazyCell<T>
[src]
pub fn new() -> LazyCell<T>
Creates a new, empty, LazyCell
.
pub fn fill(&self, value: T) -> Result<(), T>
[src]
pub fn fill(&self, value: T) -> Result<(), T>
Put a value into this cell.
This function will return Err(value)
is the cell is already full.
pub fn replace(&mut self, value: T) -> Option<T>
[src]
pub fn replace(&mut self, value: T) -> Option<T>
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]
pub fn filled(&self) -> bool
Test whether this cell has been previously filled.
pub fn borrow(&self) -> Option<&T>
[src]
pub fn borrow(&self) -> Option<&T>
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]
pub fn borrow_mut(&mut self) -> Option<&mut T>
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]
pub fn borrow_with<F: FnOnce() -> T>(&self, f: F) -> &T
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]
pub fn borrow_mut_with<F: FnOnce() -> T>(&mut self, f: F) -> &mut T
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]
pub fn try_borrow_with<E, F>(&self, f: F) -> Result<&T, E> where
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]
pub fn try_borrow_mut_with<E, F>(&mut self, f: F) -> Result<&mut T, E> where
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]
pub fn into_inner(self) -> Option<T>
Consumes this LazyCell
, returning the underlying value.
impl<T: Copy> LazyCell<T>
[src]
impl<T: Copy> LazyCell<T>
pub fn get(&self) -> Option<T>
[src]
pub fn get(&self) -> Option<T>
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: Debug> Debug for LazyCell<T>
[src]
impl<T: Debug> Debug for LazyCell<T>
fn fmt(&self, f: &mut Formatter) -> Result
[src]
fn fmt(&self, f: &mut Formatter) -> Result
Formats the value using the given formatter. Read more
impl<T: Default> Default for LazyCell<T>
[src]
impl<T: Default> Default for LazyCell<T>
Auto Trait Implementations
Blanket Implementations
impl<T> From for T
[src]
impl<T> From for T
impl<T, U> TryFrom for T where
T: From<U>,
[src]
impl<T, U> TryFrom for T where
T: From<U>,
type Error = !
try_from
)The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
try_from
)Performs the conversion.
impl<T, U> TryInto for T where
U: TryFrom<T>,
[src]
impl<T, U> TryInto for T where
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
try_from
)The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
try_from
)Performs the conversion.
impl<T, U> Into for T where
U: From<T>,
[src]
impl<T, U> Into for T where
U: From<T>,
impl<T> Borrow for T where
T: ?Sized,
[src]
impl<T> Borrow for T where
T: ?Sized,
impl<T> BorrowMut for T where
T: ?Sized,
[src]
impl<T> BorrowMut for T where
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T
[src]
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
impl<T> Any for T where
T: 'static + ?Sized,
[src]
impl<T> Any for T where
T: 'static + ?Sized,
fn get_type_id(&self) -> TypeId
[src]
fn get_type_id(&self) -> TypeId
🔬 This is a nightly-only experimental API. (get_type_id
)
this method will likely be replaced by an associated static
Gets the TypeId
of self
. Read more