#[repr(transparent)]pub struct MathCell<T>(_);
Expand description
A transparent wrapper of Cell<T>
which is identical in every way, except
it will implement arithmetic operators as well.
The purpose of MathCell
is to be used from .cell_view().
The MathCell
derefs to Cell
, so all the cell’s methods are available.
Implementations
Methods from Deref<Target = Cell<T>>
1.17.0 · sourcepub fn swap(&self, other: &Cell<T>)
pub fn swap(&self, other: &Cell<T>)
Swaps the values of two Cell
s.
Difference with std::mem::swap
is that this function doesn’t require &mut
reference.
Examples
use std::cell::Cell;
let c1 = Cell::new(5i32);
let c2 = Cell::new(10i32);
c1.swap(&c2);
assert_eq!(10, c1.get());
assert_eq!(5, c2.get());
1.0.0 · sourcepub fn get(&self) -> T
pub fn get(&self) -> T
Returns a copy of the contained value.
Examples
use std::cell::Cell;
let c = Cell::new(5);
let five = c.get();
sourcepub fn update<F>(&self, f: F) -> T where
F: FnOnce(T) -> T,
🔬 This is a nightly-only experimental API. (cell_update
)
pub fn update<F>(&self, f: F) -> T where
F: FnOnce(T) -> T,
cell_update
)Updates the contained value using a function and returns the new value.
Examples
#![feature(cell_update)]
use std::cell::Cell;
let c = Cell::new(5);
let new = c.update(|x| x + 1);
assert_eq!(new, 6);
assert_eq!(c.get(), 6);
1.12.0 · sourcepub fn as_ptr(&self) -> *mut T
pub fn as_ptr(&self) -> *mut T
Returns a raw pointer to the underlying data in this cell.
Examples
use std::cell::Cell;
let c = Cell::new(5);
let ptr = c.as_ptr();
1.11.0 · sourcepub fn get_mut(&mut self) -> &mut T
pub fn get_mut(&mut self) -> &mut T
Returns a mutable reference to the underlying data.
This call borrows Cell
mutably (at compile-time) which guarantees
that we possess the only reference.
However be cautious: this method expects self
to be mutable, which is
generally not the case when using a Cell
. If you require interior
mutability by reference, consider using RefCell
which provides
run-time checked mutable borrows through its borrow_mut
method.
Examples
use std::cell::Cell;
let mut c = Cell::new(5);
*c.get_mut() += 1;
assert_eq!(c.get(), 6);
1.37.0 · sourcepub fn as_slice_of_cells(&self) -> &[Cell<T>]
pub fn as_slice_of_cells(&self) -> &[Cell<T>]
Returns a &[Cell<T>]
from a &Cell<[T]>
Examples
use std::cell::Cell;
let slice: &mut [i32] = &mut [1, 2, 3];
let cell_slice: &Cell<[i32]> = Cell::from_mut(slice);
let slice_cell: &[Cell<i32>] = cell_slice.as_slice_of_cells();
assert_eq!(slice_cell.len(), 3);
sourcepub fn as_array_of_cells(&self) -> &[Cell<T>; N]
🔬 This is a nightly-only experimental API. (as_array_of_cells
)
pub fn as_array_of_cells(&self) -> &[Cell<T>; N]
as_array_of_cells
)Returns a &[Cell<T>; N]
from a &Cell<[T; N]>
Examples
#![feature(as_array_of_cells)]
use std::cell::Cell;
let mut array: [i32; 3] = [1, 2, 3];
let cell_array: &Cell<[i32; 3]> = Cell::from_mut(&mut array);
let array_cell: &[Cell<i32>; 3] = cell_array.as_array_of_cells();
Trait Implementations
sourceimpl<'a, T> AssignElem<T> for &'a MathCell<T>
impl<'a, T> AssignElem<T> for &'a MathCell<T>
Assignable element, simply self.set(input)
.
sourcefn assign_elem(self, input: T)
fn assign_elem(self, input: T)
Assign the value input
to the element that self represents.
sourceimpl<T> Ord for MathCell<T> where
T: Copy + Ord,
impl<T> Ord for MathCell<T> where
T: Copy + Ord,
sourceimpl<T> PartialOrd<MathCell<T>> for MathCell<T> where
T: Copy + PartialOrd<T>,
impl<T> PartialOrd<MathCell<T>> for MathCell<T> where
T: Copy + PartialOrd<T>,
sourcefn partial_cmp(&self, rhs: &MathCell<T>) -> Option<Ordering>
fn partial_cmp(&self, rhs: &MathCell<T>) -> Option<Ordering>
This method returns an ordering between self
and other
values if one exists. Read more
sourcefn lt(&self, rhs: &MathCell<T>) -> bool
fn lt(&self, rhs: &MathCell<T>) -> bool
This method tests less than (for self
and other
) and is used by the <
operator. Read more
sourcefn le(&self, rhs: &MathCell<T>) -> bool
fn le(&self, rhs: &MathCell<T>) -> bool
This method tests less than or equal to (for self
and other
) and is used by the <=
operator. Read more
impl<T> Eq for MathCell<T> where
T: Copy + Eq,
Auto Trait Implementations
impl<T> !RefUnwindSafe for MathCell<T>
impl<T> Send for MathCell<T> where
T: Send,
impl<T> !Sync for MathCell<T>
impl<T> Unpin for MathCell<T> where
T: Unpin,
impl<T> UnwindSafe for MathCell<T> where
T: UnwindSafe,
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> ToOwned for T where
T: Clone,
impl<T> ToOwned for T where
T: Clone,
type Owned = T
type Owned = T
The resulting type after obtaining ownership.
sourcefn clone_into(&self, target: &mut T)
fn clone_into(&self, target: &mut T)
toowned_clone_into
)Uses borrowed data to replace owned data, usually by cloning. Read more