Struct gc::GcCellRef [−][src]
pub struct GcCellRef<'a, T: ?Sized + 'static> { /* fields omitted */ }
A wrapper type for an immutably borrowed value from a GcCell<T>
.
Implementations
impl<'a, T: ?Sized> GcCellRef<'a, T>
[src]
impl<'a, T: ?Sized> GcCellRef<'a, T>
[src]pub fn clone(orig: &GcCellRef<'a, T>) -> GcCellRef<'a, T>
[src]
pub fn clone(orig: &GcCellRef<'a, T>) -> GcCellRef<'a, T>
[src]Copies a GcCellRef
.
The GcCell
is already immutably borrowed, so this cannot fail.
This is an associated function that needs to be used as
GcCellRef::clone(...)
. A Clone
implementation or a method
would interfere with the use of c.borrow().clone()
to clone
the contents of a GcCell
.
pub fn map<U, F>(orig: Self, f: F) -> GcCellRef<'a, U> where
U: ?Sized,
F: FnOnce(&T) -> &U,
[src]
pub fn map<U, F>(orig: Self, f: F) -> GcCellRef<'a, U> where
U: ?Sized,
F: FnOnce(&T) -> &U,
[src]Makes a new GcCellRef
from a component of the borrowed data.
The GcCell
is already immutably borrowed, so this cannot fail.
This is an associated function that needs to be used as GcCellRef::map(...)
.
A method would interfere with methods of the same name on the contents
of a GcCellRef
used through Deref
.
Examples
use gc::{GcCell, GcCellRef}; let c = GcCell::new((5, 'b')); let b1: GcCellRef<(u32, char)> = c.borrow(); let b2: GcCellRef<u32> = GcCellRef::map(b1, |t| &t.0); //assert_eq!(b2, 5);
pub fn map_split<U, V, F>(
orig: Self,
f: F
) -> (GcCellRef<'a, U>, GcCellRef<'a, V>) where
U: ?Sized,
V: ?Sized,
F: FnOnce(&T) -> (&U, &V),
[src]
pub fn map_split<U, V, F>(
orig: Self,
f: F
) -> (GcCellRef<'a, U>, GcCellRef<'a, V>) where
U: ?Sized,
V: ?Sized,
F: FnOnce(&T) -> (&U, &V),
[src]Splits a GcCellRef
into multiple GcCellRef
s for different components of the borrowed data.
The GcCell
is already immutably borrowed, so this cannot fail.
This is an associated function that needs to be used as GcCellRef::map_split(…).
A method would interfere with methods of the same name on the contents of a GcCellRef
used through Deref
.
Examples
use gc::{GcCell, GcCellRef}; let cell = GcCell::new((1, 'c')); let borrow = cell.borrow(); let (first, second) = GcCellRef::map_split(borrow, |x| (&x.0, &x.1)); assert_eq!(*first, 1); assert_eq!(*second, 'c');
Trait Implementations
Auto Trait Implementations
impl<'a, T> !RefUnwindSafe for GcCellRef<'a, T>
impl<'a, T> !Send for GcCellRef<'a, T>
impl<'a, T> !Sync for GcCellRef<'a, T>
impl<'a, T: ?Sized> Unpin for GcCellRef<'a, T>
impl<'a, T> !UnwindSafe for GcCellRef<'a, T>
Blanket Implementations
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]pub fn borrow_mut(&mut self) -> &mut T
[src]
pub fn borrow_mut(&mut self) -> &mut T
[src]Mutably borrows from an owned value. Read more