[−][src]Struct owning_ref::OwningRef
An owning reference.
This wraps an owner O and a reference &T pointing
at something reachable from O::Target while keeping
the ability to move self around.
The owner is usually a pointer that points at some base type.
For more details and examples, see the module and method docs.
Methods
impl<O, T: ?Sized> OwningRef<O, T>[src]
impl<O, T: ?Sized> OwningRef<O, T>pub fn new(o: O) -> Self where
O: StableAddress,
O: Deref<Target = T>, [src]
pub fn new(o: O) -> Self where
O: StableAddress,
O: Deref<Target = T>, Creates a new owning reference from a owner initialized to the direct dereference of it.
Example
extern crate owning_ref; use owning_ref::OwningRef; fn main() { let owning_ref = OwningRef::new(Box::new(42)); assert_eq!(*owning_ref, 42); }
pub unsafe fn new_assert_stable_address(o: O) -> Self where
O: Deref<Target = T>, [src]
pub unsafe fn new_assert_stable_address(o: O) -> Self where
O: Deref<Target = T>, Like new, but doesn’t require O to implement the StableAddress trait.
Instead, the caller is responsible to make the same promises as implementing the trait.
This is useful for cases where coherence rules prevents implementing the trait without adding a dependency to this crate in a third-party library.
pub fn map<F, U: ?Sized>(self, f: F) -> OwningRef<O, U> where
O: StableAddress,
F: FnOnce(&T) -> &U, [src]
pub fn map<F, U: ?Sized>(self, f: F) -> OwningRef<O, U> where
O: StableAddress,
F: FnOnce(&T) -> &U, Converts self into a new owning reference that points at something reachable
from the previous one.
This can be a reference to a field of U, something reachable from a field of
U, or even something unrelated with a 'static lifetime.
Example
extern crate owning_ref; use owning_ref::OwningRef; fn main() { let owning_ref = OwningRef::new(Box::new([1, 2, 3, 4])); // create a owning reference that points at the // third element of the array. let owning_ref = owning_ref.map(|array| &array[2]); assert_eq!(*owning_ref, 3); }
pub fn try_map<F, U: ?Sized, E>(self, f: F) -> Result<OwningRef<O, U>, E> where
O: StableAddress,
F: FnOnce(&T) -> Result<&U, E>, [src]
pub fn try_map<F, U: ?Sized, E>(self, f: F) -> Result<OwningRef<O, U>, E> where
O: StableAddress,
F: FnOnce(&T) -> Result<&U, E>, Tries to convert self into a new owning reference that points
at something reachable from the previous one.
This can be a reference to a field of U, something reachable from a field of
U, or even something unrelated with a 'static lifetime.
Example
extern crate owning_ref; use owning_ref::OwningRef; fn main() { let owning_ref = OwningRef::new(Box::new([1, 2, 3, 4])); // create a owning reference that points at the // third element of the array. let owning_ref = owning_ref.try_map(|array| { if array[2] == 3 { Ok(&array[2]) } else { Err(()) } }); assert_eq!(*owning_ref.unwrap(), 3); }
pub unsafe fn map_owner<F, P>(self, f: F) -> OwningRef<P, T> where
O: StableAddress,
P: StableAddress,
F: FnOnce(O) -> P, [src]
pub unsafe fn map_owner<F, P>(self, f: F) -> OwningRef<P, T> where
O: StableAddress,
P: StableAddress,
F: FnOnce(O) -> P, Converts self into a new owning reference with a different owner type.
The new owner type needs to still contain the original owner in some way so that the reference into it remains valid. This function is marked unsafe because the user needs to manually uphold this guarantee.
pub fn map_owner_box(self) -> OwningRef<Box<O>, T>[src]
pub fn map_owner_box(self) -> OwningRef<Box<O>, T>Converts self into a new owning reference where the owner is wrapped
in an additional Box<O>.
This can be used to safely erase the owner of any OwningRef<O, T>
to a OwningRef<Box<Erased>, T>.
pub fn erase_owner<'a>(self) -> OwningRef<O::Erased, T> where
O: IntoErased<'a>, [src]
pub fn erase_owner<'a>(self) -> OwningRef<O::Erased, T> where
O: IntoErased<'a>, Erases the concrete base type of the owner with a trait object.
This allows mixing of owned references with different owner base types.
Example
extern crate owning_ref; use owning_ref::{OwningRef, Erased}; fn main() { // NB: Using the concrete types here for explicitnes. // For less verbose code type aliases like `BoxRef` are provided. let owning_ref_a: OwningRef<Box<[i32; 4]>, [i32; 4]> = OwningRef::new(Box::new([1, 2, 3, 4])); let owning_ref_b: OwningRef<Box<Vec<(i32, bool)>>, Vec<(i32, bool)>> = OwningRef::new(Box::new(vec![(0, false), (1, true)])); let owning_ref_a: OwningRef<Box<[i32; 4]>, i32> = owning_ref_a.map(|a| &a[0]); let owning_ref_b: OwningRef<Box<Vec<(i32, bool)>>, i32> = owning_ref_b.map(|a| &a[1].0); let owning_refs: [OwningRef<Box<Erased>, i32>; 2] = [owning_ref_a.erase_owner(), owning_ref_b.erase_owner()]; assert_eq!(*owning_refs[0], 1); assert_eq!(*owning_refs[1], 1); }
pub fn as_owner(&self) -> &O[src]
pub fn as_owner(&self) -> &OA reference to the underlying owner.
pub fn into_owner(self) -> O[src]
pub fn into_owner(self) -> ODiscards the reference and retrieves the owner.
Trait Implementations
impl<O, T: ?Sized> Clone for OwningRef<O, T> where
O: CloneStableAddress, [src]
impl<O, T: ?Sized> Clone for OwningRef<O, T> where
O: CloneStableAddress, fn clone(&self) -> Self[src]
fn clone(&self) -> SelfReturns a copy of the value. Read more
fn clone_from(&mut self, source: &Self)1.0.0[src]
fn clone_from(&mut self, source: &Self)Performs copy-assignment from source. Read more
impl<O, T: ?Sized> From<O> for OwningRef<O, T> where
O: StableAddress,
O: Deref<Target = T>, [src]
impl<O, T: ?Sized> From<O> for OwningRef<O, T> where
O: StableAddress,
O: Deref<Target = T>, impl<O, T: ?Sized> From<OwningRefMut<O, T>> for OwningRef<O, T> where
O: StableAddress,
O: DerefMut<Target = T>, [src]
impl<O, T: ?Sized> From<OwningRefMut<O, T>> for OwningRef<O, T> where
O: StableAddress,
O: DerefMut<Target = T>, fn from(other: OwningRefMut<O, T>) -> Self[src]
fn from(other: OwningRefMut<O, T>) -> SelfPerforms the conversion.
impl<O, T: ?Sized> Sync for OwningRef<O, T> where
O: Sync,
&'a T: Sync, [src]
impl<O, T: ?Sized> Sync for OwningRef<O, T> where
O: Sync,
&'a T: Sync, impl<O, T: ?Sized> Eq for OwningRef<O, T> where
T: Eq, [src]
impl<O, T: ?Sized> Eq for OwningRef<O, T> where
T: Eq, impl<O, T: ?Sized> AsRef<T> for OwningRef<O, T>[src]
impl<O, T: ?Sized> AsRef<T> for OwningRef<O, T>impl<O, T: ?Sized> PartialOrd<OwningRef<O, T>> for OwningRef<O, T> where
T: PartialOrd, [src]
impl<O, T: ?Sized> PartialOrd<OwningRef<O, T>> for OwningRef<O, T> where
T: PartialOrd, fn partial_cmp(&self, other: &Self) -> Option<Ordering>[src]
fn partial_cmp(&self, other: &Self) -> Option<Ordering>This method returns an ordering between self and other values if one exists. Read more
#[must_use]
fn lt(&self, other: &Rhs) -> bool1.0.0[src]
#[must_use]
fn lt(&self, other: &Rhs) -> boolThis method tests less than (for self and other) and is used by the < operator. Read more
#[must_use]
fn le(&self, other: &Rhs) -> bool1.0.0[src]
#[must_use]
fn le(&self, other: &Rhs) -> boolThis method tests less than or equal to (for self and other) and is used by the <= operator. Read more
#[must_use]
fn gt(&self, other: &Rhs) -> bool1.0.0[src]
#[must_use]
fn gt(&self, other: &Rhs) -> boolThis method tests greater than (for self and other) and is used by the > operator. Read more
#[must_use]
fn ge(&self, other: &Rhs) -> bool1.0.0[src]
#[must_use]
fn ge(&self, other: &Rhs) -> boolThis method tests greater than or equal to (for self and other) and is used by the >= operator. Read more
impl<O, T: ?Sized> PartialEq<OwningRef<O, T>> for OwningRef<O, T> where
T: PartialEq, [src]
impl<O, T: ?Sized> PartialEq<OwningRef<O, T>> for OwningRef<O, T> where
T: PartialEq, fn eq(&self, other: &Self) -> bool[src]
fn eq(&self, other: &Self) -> boolThis method tests for self and other values to be equal, and is used by ==. Read more
#[must_use]
fn ne(&self, other: &Rhs) -> bool1.0.0[src]
#[must_use]
fn ne(&self, other: &Rhs) -> boolThis method tests for !=.
impl<O, T: ?Sized> Send for OwningRef<O, T> where
O: Send,
&'a T: Send, [src]
impl<O, T: ?Sized> Send for OwningRef<O, T> where
O: Send,
&'a T: Send, impl<O, T: ?Sized> Ord for OwningRef<O, T> where
T: Ord, [src]
impl<O, T: ?Sized> Ord for OwningRef<O, T> where
T: Ord, fn cmp(&self, other: &Self) -> Ordering[src]
fn cmp(&self, other: &Self) -> OrderingThis method returns an Ordering between self and other. Read more
fn max(self, other: Self) -> Self1.21.0[src]
fn max(self, other: Self) -> SelfCompares and returns the maximum of two values. Read more
fn min(self, other: Self) -> Self1.21.0[src]
fn min(self, other: Self) -> SelfCompares and returns the minimum of two values. Read more
impl<O, T: ?Sized> Hash for OwningRef<O, T> where
T: Hash, [src]
impl<O, T: ?Sized> Hash for OwningRef<O, T> where
T: Hash, fn hash<H: Hasher>(&self, state: &mut H)[src]
fn hash<H: Hasher>(&self, state: &mut H)Feeds this value into the given [Hasher]. Read more
fn hash_slice<H>(data: &[Self], state: &mut H) where
H: Hasher, 1.3.0[src]
fn hash_slice<H>(data: &[Self], state: &mut H) where
H: Hasher, Feeds a slice of this type into the given [Hasher]. Read more
impl<O, T: ?Sized> Debug for OwningRef<O, T> where
O: Debug,
T: Debug, [src]
impl<O, T: ?Sized> Debug for OwningRef<O, T> where
O: Debug,
T: Debug, fn fmt(&self, f: &mut Formatter) -> Result<(), Error>[src]
fn fmt(&self, f: &mut Formatter) -> Result<(), Error>Formats the value using the given formatter. Read more
impl<O, T: ?Sized> Deref for OwningRef<O, T>[src]
impl<O, T: ?Sized> Deref for OwningRef<O, T>type Target = T
The resulting type after dereferencing.
fn deref(&self) -> &T[src]
fn deref(&self) -> &TDereferences the value.
impl<O, T: ?Sized> Borrow<T> for OwningRef<O, T>[src]
impl<O, T: ?Sized> Borrow<T> for OwningRef<O, T>impl<O, T: ?Sized> StableDeref for OwningRef<O, T>[src]
impl<O, T: ?Sized> StableDeref for OwningRef<O, T>impl<O, T: ?Sized> CloneStableDeref for OwningRef<O, T> where
O: CloneStableAddress, [src]
impl<O, T: ?Sized> CloneStableDeref for OwningRef<O, T> where
O: CloneStableAddress, Blanket Implementations
impl<T> Erased for T[src]
impl<T> Erased for Timpl<T> From for T[src]
impl<T> From for Timpl<T, U> Into for T where
U: From<T>, [src]
impl<T, U> Into for T where
U: From<T>, impl<T> ToOwned for T where
T: Clone, [src]
impl<T> ToOwned for T where
T: Clone, type Owned = T
fn to_owned(&self) -> T[src]
fn to_owned(&self) -> TCreates owned data from borrowed data, usually by cloning. Read more
fn clone_into(&self, target: &mut T)[src]
fn clone_into(&self, target: &mut T)🔬 This is a nightly-only experimental API. (toowned_clone_into)
recently added
Uses borrowed data to replace owned data, usually by cloning. Read more
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> 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 TMutably borrows from an owned value. Read more
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> 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