pub struct Ref<'b, T>where T: 'b + ?Sized,{ /* private fields */ }
Wraps a borrowed reference to a value in a RefCell box. A wrapper type for an immutably borrowed value from a RefCell<T>.
RefCell
RefCell<T>
See the module-level documentation for more.
Copies a Ref.
Ref
The RefCell is already immutably borrowed, so this cannot fail.
This is an associated function that needs to be used as Ref::clone(...). A Clone implementation or a method would interfere with the widespread use of r.borrow().clone() to clone the contents of a RefCell.
Ref::clone(...)
Clone
r.borrow().clone()
Makes a new Ref for a component of the borrowed data.
This is an associated function that needs to be used as Ref::map(...). A method would interfere with methods of the same name on the contents of a RefCell used through Deref.
Ref::map(...)
Deref
use std::cell::{RefCell, Ref}; let c = RefCell::new((5, 'b')); let b1: Ref<'_, (u32, char)> = c.borrow(); let b2: Ref<'_, u32> = Ref::map(b1, |t| &t.0); assert_eq!(*b2, 5)
Makes a new Ref for an optional component of the borrowed data. The original guard is returned as an Err(..) if the closure returns None.
Err(..)
None
This is an associated function that needs to be used as Ref::filter_map(...). A method would interfere with methods of the same name on the contents of a RefCell used through Deref.
Ref::filter_map(...)
use std::cell::{RefCell, Ref}; let c = RefCell::new(vec![1, 2, 3]); let b1: Ref<'_, Vec<u32>> = c.borrow(); let b2: Result<Ref<'_, u32>, _> = Ref::filter_map(b1, |v| v.get(1)); assert_eq!(*b2.unwrap(), 2);
refcell_try_map
Tries to makes a new Ref for a component of the borrowed data. On failure, the original guard is returned alongside with the error returned by the closure.
This is an associated function that needs to be used as Ref::try_map(...). A method would interfere with methods of the same name on the contents of a RefCell used through Deref.
Ref::try_map(...)
#![feature(refcell_try_map)] use std::cell::{RefCell, Ref}; use std::str::{from_utf8, Utf8Error}; let c = RefCell::new(vec![0xF0, 0x9F, 0xA6 ,0x80]); let b1: Ref<'_, Vec<u8>> = c.borrow(); let b2: Result<Ref<'_, str>, _> = Ref::try_map(b1, |v| from_utf8(v)); assert_eq!(&*b2.unwrap(), "🦀"); let c = RefCell::new(vec![0xF0, 0x9F, 0xA6]); let b1: Ref<'_, Vec<u8>> = c.borrow(); let b2: Result<_, (Ref<'_, Vec<u8>>, Utf8Error)> = Ref::try_map(b1, |v| from_utf8(v)); let (b3, e) = b2.unwrap_err(); assert_eq!(*b3, vec![0xF0, 0x9F, 0xA6]); assert_eq!(e.valid_up_to(), 0);
Splits a Ref into multiple Refs for different components of the borrowed data.
This is an associated function that needs to be used as Ref::map_split(...). A method would interfere with methods of the same name on the contents of a RefCell used through Deref.
Ref::map_split(...)
use std::cell::{Ref, RefCell}; let cell = RefCell::new([1, 2, 3, 4]); let borrow = cell.borrow(); let (begin, end) = Ref::map_split(borrow, |slice| slice.split_at(2)); assert_eq!(*begin, [1, 2]); assert_eq!(*end, [3, 4]);
Converts into a reference to the underlying data.
The underlying RefCell can never be mutably borrowed from again and will always appear already immutably borrowed. It is not a good idea to leak more than a constant number of references. The RefCell can be immutably borrowed again if only a smaller number of leaks have occurred in total.
This is an associated function that needs to be used as Ref::leak(...). A method would interfere with methods of the same name on the contents of a RefCell used through Deref.
Ref::leak(...)
#![feature(cell_leak)] use std::cell::{RefCell, Ref}; let cell = RefCell::new(0); let value = Ref::leak(cell.borrow()); assert_eq!(*value, 0); assert!(cell.try_borrow().is_ok()); assert!(cell.try_borrow_mut().is_err());
TypeId
self
Returns the argument unchanged.
Calls U::from(self).
U::from(self)
That is, this conversion is whatever the implementation of From<T> for U chooses to do.
From<T> for U
arbitrary_self_types
String