Struct abi_stable::prefix_type::PrefixRef

source ·
pub struct PrefixRef<P> { /* private fields */ }
Expand description

A reference to a prefix type.

This is the type that all *_Ref pointer types generated by StableAbi wrap.

§Example

use abi_stable::{
    prefix_type::{PrefixRef, PrefixTypeTrait, WithMetadata},
    staticref, StableAbi,
};

fn main() {
    // `Module_Ref`'s constructor can also be called at compile-time
    asserts(Module_Ref(PREFIX_A));
    asserts(Module_Ref(PREFIX_B));
}

fn asserts(module: Module_Ref) {
    assert_eq!(module.first(), 5);
    assert_eq!(module.second(), 8);

    // If this Module_Ref had come from a previous version of the library without a
    // `third` field it would return `None`.
    assert_eq!(module.third(), Some(13));
}

#[repr(C)]
#[derive(StableAbi)]
#[sabi(kind(Prefix(prefix_ref = Module_Ref, prefix_fields = Module_Prefix)))]
struct Module {
    first: usize,
    // The `#[sabi(last_prefix_field)]` attribute here means that this is
    // the last field in this struct that was defined in the
    // first compatible version of the library,
    // requiring new fields to always be added after it.
    // Moving this attribute is a breaking change, it can only be done in a
    // major version bump..
    #[sabi(last_prefix_field)]
    second: usize,
    third: usize,
}

const MOD_VAL: Module = Module {
    first: 5,
    second: 8,
    third: 13,
};

/////////////////////////////////////////
// First way to construct a PrefixRef
// This is a way that PrefixRef can be constructed in statics

const PREFIX_A: PrefixRef<Module_Prefix> = {
    const S: &WithMetadata<Module> = &WithMetadata::new(MOD_VAL);

    S.static_as_prefix()
};

/////////////////////////////////////////
// Second way to construct a PrefixRef
// This is a way that PrefixRef can be constructed in associated constants,

struct WithAssoc;

impl WithAssoc {
    // This macro declares a `StaticRef` pointing to the assigned `WithMetadata`.
    staticref!{const MOD_WM: WithMetadata<Module> = WithMetadata::new(MOD_VAL)}
}

const PREFIX_B: PrefixRef<Module_Prefix> = WithAssoc::MOD_WM.as_prefix();

/////////////////////////////////////////

Implementations§

source§

impl<P> PrefixRef<P>

source

pub const unsafe fn from_raw<T>(ptr: *const WithMetadata_<T, P>) -> Self

Constructs a PrefixRef from a raw pointer.

§Safety

The pointer must be a non-dangling pointer to a valid, initialized instance of T, and live for the rest of the program’s lifetime (if called at compile-time it means live for the entire program).

T must implement PrefixTypeTrait<Fields = P>, this is automatically true if this is called with &WithMetadata::new(<value>).

§Example
use abi_stable::{
    for_examples::{Module, Module_Prefix, Module_Ref},
    prefix_type::{PrefixRef, PrefixTypeTrait, WithMetadata},
    rstr,
    std_types::*,
};

const MOD_WM: &WithMetadata<Module> = {
    &WithMetadata::new(
        Module {
            first: RSome(3),
            second: rstr!("hello"),
            third: 8,
        },
    )
};

const PREFIX: PrefixRef<Module_Prefix> = unsafe { PrefixRef::from_raw(MOD_WM) };

const MODULE: Module_Ref = Module_Ref(PREFIX);

assert_eq!(MODULE.first(), RSome(3));

assert_eq!(MODULE.second().as_str(), "hello");

// The accessor returns an `Option` because the field comes after the prefix,
// and returning an Option is the default for those.
assert_eq!(MODULE.third(), Some(8));
source

pub const fn from_staticref<T>(ptr: StaticRef<WithMetadata_<T, P>>) -> Self

Constructs a PrefixRef from a StaticRef.

§Example
use abi_stable::{
    for_examples::{Module, Module_Prefix, Module_Ref},
    prefix_type::{PrefixRef, PrefixTypeTrait, WithMetadata},
    rstr, staticref,
    std_types::*,
};

struct Foo {}

impl Foo {
    // This macro declares a `StaticRef` pointing to the assigned `WithMetadata`.
    staticref! {const MOD_WM: WithMetadata<Module> =
        WithMetadata::new(Module{
            first: RNone,
            second: rstr!("world"),
            third: 13,
        })
    }
}

const PREFIX: PrefixRef<Module_Prefix> = PrefixRef::from_staticref(Foo::MOD_WM);

const MODULE: Module_Ref = Module_Ref(PREFIX);

assert_eq!(MODULE.first(), RNone);

assert_eq!(MODULE.second().as_str(), "world");

// The accessor returns an `Option` because the field comes after the prefix,
// and returning an Option is the default for those.
assert_eq!(MODULE.third(), Some(13));
source

pub const fn from_ref<T>(ptr: &'static WithMetadata_<T, P>) -> Self

Constructs a PrefixRef from a static reference.

§Example
use abi_stable::{
    for_examples::{Module, Module_Prefix, Module_Ref},
    prefix_type::{PrefixRef, PrefixTypeTrait, WithMetadata},
    rstr,
    std_types::*,
};

const MOD_WM: &WithMetadata<Module> = {
    &WithMetadata::new(
        Module {
            first: RNone,
            second: rstr!("foo"),
            third: 21,
        },
    )
};

const PREFIX: PrefixRef<Module_Prefix> = PrefixRef::from_ref(MOD_WM);

const MODULE: Module_Ref = Module_Ref(PREFIX);

assert_eq!(MODULE.first(), RNone);

assert_eq!(MODULE.second().as_str(), "foo");

// The accessor returns an `Option` because the field comes after the prefix,
// and returning an Option is the default for those.
assert_eq!(MODULE.third(), Some(21));
source

pub const fn field_accessibility(&self) -> FieldAccessibility

A bit array that describes the accessibility of each field in P.

§Example
use abi_stable::{
    for_examples::{Module, Module_Prefix},
    prefix_type::{PrefixRef, PrefixTypeTrait, WithMetadata},
    std_types::*,
};

const MOD_WM: &WithMetadata<Module> = {
    &WithMetadata::new(
        Module {
            first: RNone,
            second: RStr::empty(),
            third: 0,
        },
    )
};

const PREFIX: PrefixRef<Module_Prefix> = PrefixRef::from_ref(MOD_WM);

let accessibility = PREFIX.field_accessibility();

assert!(accessibility.at(0).is_accessible()); // The `first` field
assert!(accessibility.at(1).is_accessible()); // The `second` field
assert!(accessibility.at(2).is_accessible()); // The `third` field
assert!(!accessibility.at(3).is_accessible()); // There's no field after `third`
source

pub const fn type_layout(&self) -> &'static PTStructLayout

The basic layout of the prefix type, for error messages.

source

pub const fn prefix<'a>(self) -> &'a P

Gets a reference to the pointed-to prefix.

§Example
use abi_stable::{
    for_examples::{Module, Module_Prefix},
    prefix_type::{PrefixRef, PrefixTypeTrait, WithMetadata},
    rstr,
    std_types::*,
};

const MOD_WM: &WithMetadata<Module> = {
    &WithMetadata::new(
        Module {
            first: RNone,
            second: rstr!("foo"),
            third: 21,
        },
    )
};

const PREFIX_REF: PrefixRef<Module_Prefix> = PrefixRef::from_ref(MOD_WM);

let prefix: &Module_Prefix = PREFIX_REF.prefix();

assert_eq!(prefix.first, RNone);

assert_eq!(prefix.second.as_str(), "foo");

// The `third` field is not in the prefix, so it can't be accessed here.
// prefix.third;
source

pub const fn to_raw_ptr(self) -> *const WithMetadata_<P, P>

Converts this PrefixRef into a raw pointer.

source

pub const unsafe fn cast<U>(self) -> PrefixRef<U>

Casts the pointed-to prefix to another type.

§Safety

This function is intended for casting the PrefixRef<P> to PrefixRef<U>, and then cast back to PrefixRef<P> to use it again.

The prefix in the returned PrefixRef<U> must only be accessed when this PrefixRef was originally cosntructed with a ẀithMetadata_<_, U>. access includes calling prefix, and reading the value field in the WithMetadata that this points to.

Trait Implementations§

source§

impl<P> Clone for PrefixRef<P>

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<P> Debug for PrefixRef<P>

source§

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

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

impl<P> GetPointerKind for PrefixRef<P>

source§

type PtrTarget = WithMetadata_<P, P>

What this pointer points to. Read more
source§

type Kind = PK_Reference

The kind of the pointer. Read more
source§

const KIND: PointerKind = <Self::Kind as PointerKindVariant>::VALUE

The value-level version of the Kind associated type. Read more
source§

impl<P> GetStaticEquivalent_ for PrefixRef<P>

source§

type StaticEquivalent = PrefixRef<<P as GetStaticEquivalent_>::StaticEquivalent>

The 'static equivalent of Self
source§

impl<P> PrefixRefTrait for PrefixRef<P>

source§

type PrefixFields = P

A struct that contains all the fields of some other struct up to the field annotated with #[sabi(last_prefix_field)] inclusive. Read more
source§

fn from_prefix_ref(this: PrefixRef<Self::PrefixFields>) -> Self

Converts a PrefixRef to Self
source§

fn to_prefix_ref(self) -> PrefixRef<Self::PrefixFields>

Converts Self to a PrefixRef
source§

impl<P> StableAbi for PrefixRef<P>
where P: PrefixStableAbi,

source§

type IsNonZeroType = True

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

const LAYOUT: &'static TypeLayout = _

The layout of the type provided by implementors.
source§

const ABI_CONSTS: AbiConsts = _

const-equivalents of the associated types.
source§

impl<P> Copy for PrefixRef<P>

source§

impl<'a, P: 'a> Send for PrefixRef<P>
where &'a WithMetadata_<P, P>: Send,

source§

impl<'a, P: 'a> Sync for PrefixRef<P>
where &'a WithMetadata_<P, P>: Sync,

Auto Trait Implementations§

§

impl<P> Freeze for PrefixRef<P>

§

impl<P> RefUnwindSafe for PrefixRef<P>
where P: RefUnwindSafe,

§

impl<P> Unpin for PrefixRef<P>

§

impl<P> UnwindSafe for PrefixRef<P>
where P: RefUnwindSafe,

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 T)

🔬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> ImmutableRef for T
where T: Copy + GetPointerKind<Kind = PK_Reference>,

source§

fn to_nonnull(self) -> NonNull<Self::PtrTarget>

Converts this pointer to a NonNull.
source§

unsafe fn from_nonnull(from: NonNull<Self::PtrTarget>) -> Self

Constructs this pointer from a NonNull. Read more
source§

fn to_raw_ptr(self) -> *const Self::PtrTarget

Converts this pointer to a raw pointer.
source§

unsafe fn from_raw_ptr(from: *const Self::PtrTarget) -> Option<Self>

Constructs this pointer from a raw pointer. Read more
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<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.