abi_stable::sabi_trait

Struct RObject

Source
#[repr(C)]
pub struct RObject<'lt, P, I, V>
where P: GetPointerKind,
{ /* private fields */ }
Expand description

RObject implements ffi-safe trait objects, for a minimal selection of traits.

The main use of RObject<_> is as the default backend for #[sabi_trait] generated trait objects.

§Construction

RObject<_> is how #[sabi_trait]-based ffi-safe trait objects are implemented, and there’s no way to construct it separate from those.

§Trait object

RObject<'borrow, Pointer<()>, Interface, VTable> can be used as a trait object for any combination of the traits listed below:

§Deconstruction

RObject<_> can be unwrapped into a concrete type, within the same dynamic library/executable that constructed it, using these (fallible) conversion methods:

RObject can only be converted back if the trait object was constructed to allow it.

Implementations§

Source§

impl<'lt, P, I, V> RObject<'lt, P, I, V>
where P: AsPtr<PtrTarget = ()>,

Source

pub unsafe fn with_vtable<OrigPtr>( ptr: OrigPtr, vtable: PrefixRef<V>, ) -> RObject<'lt, P, I, V>
where OrigPtr: CanTransmuteElement<(), TransmutedPtr = P>, OrigPtr::PtrTarget: Sized + 'lt, P: AsPtr<PtrTarget = ()>,

Constructs an RObject from a pointer and an extra vtable.

This is mostly intended to be called by #[sabi_trait] generated trait objects.

§Safety

These are the requirements for the caller:

  • P must be a pointer to the type that the vtable functions take as the first parameter.

  • The vtable must not come from a reborrowed RObject (created using RObject::reborrow or RObject::reborrow_mut).

  • The vtable must be the SomeVTableName of a struct declared with #[derive(StableAbi)] #[sabi(kind(Prefix(prefix_ref= SomeVTableName)))].

  • The vtable must have RObjectVtable_Ref as its first declared field

Source§

impl<'borr, 'a, I, V> RObject<'borr, RRef<'a, ()>, I, V>

Source

pub const unsafe fn with_vtable_const<T, Downcasting>( ptr: &'a T, vtable: PrefixRef<V>, ) -> Self
where T: 'borr,

This function allows constructing an RObject in a constant/static.

This is mostly intended for #[sabi_trait]-generated trait objects

§Safety

This has the same safety requirements as RObject::with_vtable

§Example

Because this is intended for #[sabi_trait] generated trait objects, this demonstrates how to construct one in a constant.

use abi_stable::sabi_trait::{
    doc_examples::ConstExample_CTO,
    prelude::TD_Opaque,
};

const EXAMPLE0: ConstExample_CTO<'static, 'static> =
    ConstExample_CTO::from_const(&0usize, TD_Opaque);
Source§

impl<'lt, P, I, V> RObject<'lt, P, I, V>
where P: GetPointerKind,

Source

pub fn downcast_into<T>(self) -> Result<P::TransmutedPtr, UneraseError<Self>>
where T: 'static, P: AsPtr<PtrTarget = ()> + CanTransmuteElement<T>,

Attempts to unerase this trait object into the pointer it was constructed with.

§Errors

This will return an error in any of these conditions:

  • It is called in a dynamic library/binary outside the one from which this RObject was constructed.

  • The trait object wrapping this RObject was constructed with a TD_CanDowncast argument.

  • T is not the concrete type this RObject<_> was constructed with.

§Example
use abi_stable::{
    sabi_trait::doc_examples::Doer_TO, std_types::RBox,
    type_level::downcasting::TD_CanDowncast,
};

let to = || Doer_TO::from_value(5usize, TD_CanDowncast);

// `to.obj` is an RObject
assert_eq!(
    to().obj.downcast_into::<usize>().ok(),
    Some(RBox::new(5usize))
);
assert_eq!(to().obj.downcast_into::<u8>().ok(), None);
Source

pub fn downcast_as<T>(&self) -> Result<&T, UneraseError<&Self>>
where T: 'static, P: AsPtr<PtrTarget = ()> + CanTransmuteElement<T>,

Attempts to unerase this trait object into a reference of the value was constructed with.

§Errors

This will return an error in any of these conditions:

  • It is called in a dynamic library/binary outside the one from which this RObject was constructed.

  • The trait object wrapping this RObject was constructed with a TD_CanDowncast argument.

  • T is not the concrete type this RObject<_> was constructed with.

§Example
use abi_stable::{
    sabi_trait::doc_examples::Doer_TO, std_types::RArc,
    type_level::downcasting::TD_CanDowncast, RMut, RRef,
};

{
    let to: Doer_TO<'_, RArc<()>> =
        Doer_TO::from_ptr(RArc::new(8usize), TD_CanDowncast);

    // `to.obj` is an RObject
    assert_eq!(to.obj.downcast_as::<usize>().ok(), Some(&8usize));
    assert_eq!(to.obj.downcast_as::<u8>().ok(), None);
}
{
    // `#[sabi_trait]` trait objects constructed from `&`
    // use `RRef<'_, ()>` instead of `&'_ ()`
    // since `&T` can't soundly be transmuted back and forth into `&()`
    let to: Doer_TO<'_, RRef<'_, ()>> = Doer_TO::from_ptr(&13usize, TD_CanDowncast);

    assert_eq!(to.obj.downcast_as::<usize>().ok(), Some(&13usize));
    assert_eq!(to.obj.downcast_as::<u8>().ok(), None);
}
{
    let mmut = &mut 21usize;
    // `#[sabi_trait]` trait objects constructed from `&mut`
    // use `RMut<'_, ()>` instead of `&'_ mut ()`
    // since `&mut T` can't soundly be transmuted back and forth into `&mut ()`
    let to: Doer_TO<'_, RMut<'_, ()>> = Doer_TO::from_ptr(mmut, TD_CanDowncast);

    assert_eq!(to.obj.downcast_as::<usize>().ok(), Some(&21usize));
    assert_eq!(to.obj.downcast_as::<u8>().ok(), None);
}
Source

pub fn downcast_as_mut<T>(&mut self) -> Result<&mut T, UneraseError<&mut Self>>
where T: 'static, P: AsMutPtr<PtrTarget = ()> + CanTransmuteElement<T>,

Attempts to unerase this trait object into a mutable reference of the value was constructed with.

§Errors

This will return an error in any of these conditions:

  • It is called in a dynamic library/binary outside the one from which this RObject was constructed.

  • The trait object wrapping this RObject was constructed with a TD_CanDowncast argument.

  • T is not the concrete type this RObject<_> was constructed with.

§Example
use abi_stable::{
    sabi_trait::doc_examples::Doer_TO, std_types::RBox,
    type_level::downcasting::TD_CanDowncast, RMut, RRef,
};

{
    let mut to: Doer_TO<'_, RBox<()>> =
        Doer_TO::from_value(34usize, TD_CanDowncast);

    // `to.obj` is an RObject
    assert_eq!(to.obj.downcast_as_mut::<usize>().ok(), Some(&mut 34usize));
    assert_eq!(to.obj.downcast_as_mut::<u8>().ok(), None);
}
{
    let mmut = &mut 55usize;
    // `#[sabi_trait]` trait objects constructed from `&mut`
    // use `RMut<'_, ()>` instead of `&'_ mut ()`
    // since `&mut T` can't soundly be transmuted back and forth into `&mut ()`
    let mut to: Doer_TO<'_, RMut<'_, ()>> = Doer_TO::from_ptr(mmut, TD_CanDowncast);

    assert_eq!(to.obj.downcast_as_mut::<usize>().ok(), Some(&mut 55usize));
    assert_eq!(to.obj.downcast_as_mut::<u8>().ok(), None);
}
Source

pub unsafe fn unchecked_downcast_into<T>(self) -> P::TransmutedPtr
where P: AsPtr<PtrTarget = ()> + CanTransmuteElement<T>,

Unwraps the RObject<_> into a pointer to T, without checking whether T is the type that the RObject was constructed with.

§Safety

You must check that T is the type that RObject was constructed with through other means.

§Example
use abi_stable::{
    sabi_trait::doc_examples::Doer_TO, std_types::RBox,
    type_level::downcasting::TD_Opaque,
};

let to = || Doer_TO::from_value(5usize, TD_Opaque);

unsafe {
    // `to.obj` is an RObject
    assert_eq!(
        to().obj.unchecked_downcast_into::<usize>(),
        RBox::new(5usize)
    );
}
Source

pub unsafe fn unchecked_downcast_as<T>(&self) -> &T
where P: AsPtr<PtrTarget = ()>,

Unwraps the RObject<_> into a reference to T, without checking whether T is the type that the RObject was constructed with.

§Safety

You must check that T is the type that RObject was constructed with through other means.

§Example
use abi_stable::{
    sabi_trait::doc_examples::Doer_TO, std_types::RArc,
    type_level::downcasting::TD_Opaque, RMut, RRef,
};

{
    let to: Doer_TO<'_, RArc<()>> = Doer_TO::from_ptr(RArc::new(8usize), TD_Opaque);

    unsafe {
        // `to.obj` is an RObject
        assert_eq!(to.obj.unchecked_downcast_as::<usize>(), &8usize);
    }
}
{
    // `#[sabi_trait]` trait objects constructed from `&`
    // use `RRef<'_, ()>` instead of `&'_ ()`
    // since `&T` can't soundly be transmuted back and forth into `&()`
    let to: Doer_TO<'_, RRef<'_, ()>> = Doer_TO::from_ptr(&13usize, TD_Opaque);

    unsafe {
        assert_eq!(to.obj.unchecked_downcast_as::<usize>(), &13usize);
    }
}
{
    let mmut = &mut 21usize;
    // `#[sabi_trait]` trait objects constructed from `&mut`
    // use `RMut<'_, ()>` instead of `&'_ mut ()`
    // since `&mut T` can't soundly be transmuted back and forth into `&mut ()`
    let to: Doer_TO<'_, RMut<'_, ()>> = Doer_TO::from_ptr(mmut, TD_Opaque);

    unsafe {
        assert_eq!(to.obj.unchecked_downcast_as::<usize>(), &21usize);
    }
}
Source

pub unsafe fn unchecked_downcast_as_mut<T>(&mut self) -> &mut T
where P: AsMutPtr<PtrTarget = ()>,

Unwraps the RObject<_> into a mutable reference to T, without checking whether T is the type that the RObject was constructed with.

§Safety

You must check that T is the type that RObject was constructed with through other means.

§Example
use abi_stable::{
    sabi_trait::doc_examples::Doer_TO, std_types::RBox,
    type_level::downcasting::TD_Opaque, RMut, RRef,
};

{
    let mut to: Doer_TO<'_, RBox<()>> = Doer_TO::from_value(34usize, TD_Opaque);

    unsafe {
        // `to.obj` is an RObject
        assert_eq!(to.obj.unchecked_downcast_as_mut::<usize>(), &mut 34usize);
    }
}
{
    let mmut = &mut 55usize;
    // `#[sabi_trait]` trait objects constructed from `&mut`
    // use `RMut<'_, ()>` instead of `&'_ mut ()`
    // since `&mut T` can't soundly be transmuted back and forth into `&mut ()`
    let mut to: Doer_TO<'_, RMut<'_, ()>> = Doer_TO::from_ptr(mmut, TD_Opaque);

    unsafe {
        assert_eq!(to.obj.unchecked_downcast_as_mut::<usize>(), &mut 55usize);
    }
}
Source§

impl<'lt, P, I, V> RObject<'lt, P, I, V>

Source

pub fn reborrow<'re>(&'re self) -> RObject<'lt, RRef<'re, ()>, I, V>
where P: AsPtr<PtrTarget = ()>, PrivStruct: ReborrowBounds<I::Send, I::Sync>,

Creates a shared reborrow of this RObject.

This is only callable if RObject is either Send + Sync or !Send + !Sync.

§Example
use abi_stable::{
    sabi_trait::doc_examples::Doer_TO, std_types::RBox,
    type_level::downcasting::TD_Opaque, RMut, RRef,
};

let mut to: Doer_TO<'_, RBox<()>> = Doer_TO::from_value(13usize, TD_Opaque);

// `to.obj` is an RObject
assert_eq!(debug_string(to.obj.reborrow()), "13");
assert_eq!(debug_string(to.obj.reborrow()), "13");

// `#[sabi_trait]` trait objects have an equivalent `sabi_reborrow` method.
assert_eq!(debug_string(to.sabi_reborrow()), "13");
assert_eq!(debug_string(to.sabi_reborrow()), "13");

fn debug_string<T>(to: T) -> String
where
    T: std::fmt::Debug,
{
    format!("{:?}", to)
}
Source

pub fn reborrow_mut<'re>(&'re mut self) -> RObject<'lt, RMut<'re, ()>, I, V>
where P: AsMutPtr<PtrTarget = ()>, PrivStruct: ReborrowBounds<I::Send, I::Sync>,

Creates a mutable reborrow of this RObject.

The reborrowed RObject cannot use these methods:

  • RObject::clone

This is only callable if RObject is either Send + Sync or !Send + !Sync.

§Example
use abi_stable::{
    sabi_trait::doc_examples::{Doer, Doer_TO},
    std_types::RBox,
    type_level::downcasting::TD_Opaque,
    RMut, RRef,
};

let mut to: Doer_TO<'_, RBox<()>> = Doer_TO::from_value(2usize, TD_Opaque);

// `#[sabi_trait]` trait objects have an equivalent `sabi_reborrow_mut` method,
// which delegate to this method.
assert_eq!(increment(to.sabi_reborrow_mut()).value(), 3);
assert_eq!(increment(to.sabi_reborrow_mut()).value(), 4);

fn increment<T>(mut to: T) -> T
where
    T: Doer,
{
    to.add_into(1);
    to
}
Source§

impl<'lt, P, I, V> RObject<'lt, P, I, V>
where P: GetPointerKind,

Source

pub const fn sabi_et_vtable(&self) -> PrefixRef<V>

Gets the vtable.

Source

pub fn sabi_robject_vtable(&self) -> RObjectVtable_Ref<(), P, I>

The vtable common to all #[sabi_trait] generated trait objects.

Source

pub fn sabi_erased_ref(&self) -> RRef<'_, ErasedObject<()>>
where P: AsPtr<PtrTarget = ()>,

Gets an RRef pointing to the erased object.

Source

pub fn sabi_erased_mut(&mut self) -> RMut<'_, ErasedObject<()>>
where P: AsMutPtr<PtrTarget = ()>,

Gets an RMut pointing to the erased object.

Source

pub fn sabi_as_rref(&self) -> RRef<'_, ()>
where P: AsPtr<PtrTarget = ()>,

Gets an RRef pointing to the erased object.

Source

pub fn sabi_as_rmut(&mut self) -> RMut<'_, ()>
where P: AsMutPtr<PtrTarget = ()>,

Gets an RMut pointing to the erased object.

Source

pub fn sabi_with_value<F, R>(self, f: F) -> R
where P: OwnedPointer<PtrTarget = ()>, F: FnOnce(MovePtr<'_, ()>) -> R,

Calls the f callback with an MovePtr pointing to the erased object.

Source§

impl<'lt, I, V> RObject<'lt, RArc<()>, I, V>

Source

pub fn shallow_clone(&self) -> Self

Does a shallow clone of the object, just incrementing the reference counter

Trait Implementations§

Source§

impl<'lt, P, I, V> Clone for RObject<'lt, P, I, V>
where P: AsPtr, I: InterfaceType, Self: CloneImpl<<P as GetPointerKind>::Kind>,

Clone is implemented for references and smart pointers, using GetPointerKind to decide whether P is a smart pointer or a reference.

RObject does not implement Clone if P == &mut () :

use abi_stable::{
    sabi_trait::{doc_examples::ConstExample_TO, TD_Opaque},
    std_types::*,
};

let mut object = ConstExample_TO::from_value(10usize, TD_Opaque);
let borrow = object.sabi_reborrow_mut();
let _ = borrow.clone();

Here is the same example with sabi_reborrow

use abi_stable::{
    sabi_trait::{doc_examples::ConstExample_TO, TD_Opaque},
    std_types::*,
};

let mut object = ConstExample_TO::from_value(10usize, TD_Opaque);
let borrow = object.sabi_reborrow();
let _ = borrow.clone();
Source§

fn clone(&self) -> Self

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<'lt, P, I, V> Debug for RObject<'lt, P, I, V>
where P: AsPtr<PtrTarget = ()> + AsPtr, I: InterfaceType<Debug = Implemented<Debug>>,

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<'lt, P, I, V> Display for RObject<'lt, P, I, V>
where P: AsPtr<PtrTarget = ()>, I: InterfaceType<Display = Implemented<Display>>,

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<P, I, V> Drop for RObject<'_, P, I, V>
where P: GetPointerKind,

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more
Source§

impl<'lt, P, I, V> Error for RObject<'lt, P, I, V>
where P: AsPtr<PtrTarget = ()>, I: InterfaceType<Display = Implemented<Display>, Debug = Implemented<Debug>, Error = Implemented<Error>>,

1.30.0 · Source§

fn source(&self) -> Option<&(dyn Error + 'static)>

Returns the lower-level source of this error, if any. Read more
1.0.0 · Source§

fn description(&self) -> &str

👎Deprecated since 1.42.0: use the Display impl or to_string()
1.0.0 · Source§

fn cause(&self) -> Option<&dyn Error>

👎Deprecated since 1.33.0: replaced by Error::source, which can support downcasting
Source§

fn provide<'a>(&'a self, request: &mut Request<'a>)

🔬This is a nightly-only experimental API. (error_generic_member_access)
Provides type-based access to context intended for error reports. Read more
Source§

impl<'lt, P, I, V> GetStaticEquivalent_ for RObject<'lt, P, I, V>

Source§

type StaticEquivalent = _static_RObject<'static, <P as GetStaticEquivalent_>::StaticEquivalent, <I as GetStaticEquivalent_>::StaticEquivalent, <V as GetStaticEquivalent_>::StaticEquivalent>

The 'static equivalent of Self
Source§

impl<'lt, P, I, V> StableAbi for RObject<'lt, P, I, V>

Source§

const LAYOUT: &'static TypeLayout = _

The layout of the type provided by implementors.
Source§

type IsNonZeroType = False

Whether this type has a single invalid bit-pattern. Read more
Source§

const ABI_CONSTS: AbiConsts = _

const-equivalents of the associated types.
Source§

impl<'lt, P, I, V> Send for RObject<'lt, P, I, V>

Source§

impl<'lt, P, I, V> Sync for RObject<'lt, P, I, V>

Source§

impl<'lt, P, I, V> Unpin for RObject<'lt, P, I, V>

Auto Trait Implementations§

§

impl<'lt, P, I, V> Freeze for RObject<'lt, P, I, V>
where P: Freeze,

§

impl<'lt, P, I, V> RefUnwindSafe for RObject<'lt, P, I, V>

§

impl<'lt, P, I, V> UnwindSafe for RObject<'lt, P, I, V>

Blanket Implementations§

Source§

impl<T> AlignerFor<1> for T

Source§

type Aligner = AlignTo1<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<1024> for T

Source§

type Aligner = AlignTo1024<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<128> for T

Source§

type Aligner = AlignTo128<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<16> for T

Source§

type Aligner = AlignTo16<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<16384> for T

Source§

type Aligner = AlignTo16384<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<2> for T

Source§

type Aligner = AlignTo2<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<2048> for T

Source§

type Aligner = AlignTo2048<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<256> for T

Source§

type Aligner = AlignTo256<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<32> for T

Source§

type Aligner = AlignTo32<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<32768> for T

Source§

type Aligner = AlignTo32768<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<4> for T

Source§

type Aligner = AlignTo4<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<4096> for T

Source§

type Aligner = AlignTo4096<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<512> for T

Source§

type Aligner = AlignTo512<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<64> for T

Source§

type Aligner = AlignTo64<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<8> for T

Source§

type Aligner = AlignTo8<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<8192> for T

Source§

type Aligner = AlignTo8192<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<'a, T> RCowCompatibleRef<'a> for T
where T: Clone + 'a,

Source§

type RefC = &'a T

The (preferably) ffi-safe equivalent of &Self.
Source§

type ROwned = T

The owned version of Self::RefC.
Source§

fn as_c_ref(from: &'a T) -> <T as RCowCompatibleRef<'a>>::RefC

Converts a reference to an FFI-safe type
Source§

fn as_rust_ref(from: <T as RCowCompatibleRef<'a>>::RefC) -> &'a T

Converts an FFI-safe type to a reference
Source§

impl<S> ROExtAcc for S

Source§

fn f_get<F>(&self, offset: FieldOffset<S, F, Aligned>) -> &F

Gets a reference to a field, determined by offset. Read more
Source§

fn f_get_mut<F>(&mut self, offset: FieldOffset<S, F, Aligned>) -> &mut F

Gets a muatble reference to a field, determined by offset. Read more
Source§

fn f_get_ptr<F, A>(&self, offset: FieldOffset<S, F, A>) -> *const F

Gets a const pointer to a field, the field is determined by offset. Read more
Source§

fn f_get_mut_ptr<F, A>(&mut self, offset: FieldOffset<S, F, A>) -> *mut F

Gets a mutable pointer to a field, determined by offset. Read more
Source§

impl<S> ROExtOps<Aligned> for S

Source§

fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Aligned>, value: F) -> F

Replaces a field (determined by offset) with value, returning the previous value of the field. Read more
Source§

fn f_swap<F>(&mut self, offset: FieldOffset<S, F, Aligned>, right: &mut S)

Swaps a field (determined by offset) with the same field in right. Read more
Source§

fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Aligned>) -> F
where F: Copy,

Gets a copy of a field (determined by offset). The field is determined by offset. Read more
Source§

impl<S> ROExtOps<Unaligned> for S

Source§

fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Unaligned>, value: F) -> F

Replaces a field (determined by offset) with value, returning the previous value of the field. Read more
Source§

fn f_swap<F>(&mut self, offset: FieldOffset<S, F, Unaligned>, right: &mut S)

Swaps a field (determined by offset) with the same field in right. Read more
Source§

fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Unaligned>) -> F
where F: Copy,

Gets a copy of a field (determined by offset). The field is determined by offset. Read more
Source§

impl<T> SelfOps for T
where T: ?Sized,

Source§

fn eq_id(&self, other: &Self) -> bool

Compares the address of self with the address of other. Read more
Source§

fn piped<F, U>(self, f: F) -> U
where F: FnOnce(Self) -> U, Self: Sized,

Emulates the pipeline operator, allowing method syntax in more places. Read more
Source§

fn piped_ref<'a, F, U>(&'a self, f: F) -> U
where F: FnOnce(&'a Self) -> U,

The same as piped except that the function takes &Self Useful for functions that take &Self instead of Self. Read more
Source§

fn piped_mut<'a, F, U>(&'a mut self, f: F) -> U
where F: FnOnce(&'a mut Self) -> U,

The same as piped, except that the function takes &mut Self. Useful for functions that take &mut Self instead of Self.
Source§

fn mutated<F>(self, f: F) -> Self
where F: FnOnce(&mut Self), Self: Sized,

Mutates self using a closure taking self by mutable reference, passing it along the method chain. Read more
Source§

fn observe<F>(self, f: F) -> Self
where F: FnOnce(&Self), Self: Sized,

Observes the value of self, passing it along unmodified. Useful in long method chains. Read more
Source§

fn into_<T>(self) -> T
where Self: Into<T>,

Performs a conversion with Into. using the turbofish .into_::<_>() syntax. Read more
Source§

fn as_ref_<T>(&self) -> &T
where Self: AsRef<T>, T: ?Sized,

Performs a reference to reference conversion with AsRef, using the turbofish .as_ref_::<_>() syntax. Read more
Source§

fn as_mut_<T>(&mut self) -> &mut T
where Self: AsMut<T>, T: ?Sized,

Performs a mutable reference to mutable reference conversion with AsMut, using the turbofish .as_mut_::<_>() syntax. Read more
Source§

fn drop_(self)
where Self: Sized,

Drops self using method notation. Alternative to std::mem::drop. Read more
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

impl<This> TransmuteElement for This
where This: ?Sized,

Source§

unsafe fn transmute_element<T>( self, ) -> <Self as CanTransmuteElement<T>>::TransmutedPtr
where Self: CanTransmuteElement<T>,

Transmutes the element type of this pointer.. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> TypeIdentity for T
where T: ?Sized,

Source§

type Type = T

This is always Self.
Source§

fn into_type(self) -> Self::Type
where Self: Sized, Self::Type: Sized,

Converts a value back to the original type.
Source§

fn as_type(&self) -> &Self::Type

Converts a reference back to the original type.
Source§

fn as_type_mut(&mut self) -> &mut Self::Type

Converts a mutable reference back to the original type.
Source§

fn into_type_box(self: Box<Self>) -> Box<Self::Type>

Converts a box back to the original type.
Source§

fn into_type_arc(this: Arc<Self>) -> Arc<Self::Type>

Converts an Arc back to the original type. Read more
Source§

fn into_type_rc(this: Rc<Self>) -> Rc<Self::Type>

Converts an Rc back to the original type. Read more
Source§

fn from_type(this: Self::Type) -> Self
where Self: Sized, Self::Type: Sized,

Converts a value back to the original type.
Source§

fn from_type_ref(this: &Self::Type) -> &Self

Converts a reference back to the original type.
Source§

fn from_type_mut(this: &mut Self::Type) -> &mut Self

Converts a mutable reference back to the original type.
Source§

fn from_type_box(this: Box<Self::Type>) -> Box<Self>

Converts a box back to the original type.
Source§

fn from_type_arc(this: Arc<Self::Type>) -> Arc<Self>

Converts an Arc back to the original type.
Source§

fn from_type_rc(this: Rc<Self::Type>) -> Rc<Self>

Converts an Rc back to the original type.