Struct StableLike

Source
#[repr(C)]
pub struct StableLike<T, As> { /* private fields */ }
Expand description

Lets you tell stabby that T has the same stable layout as As.

Lying about this link between T and As will cause UB if a #[repr(stabby)] enum transitively contains a value of this type.

If you want to be safe when using this, use NoNiches with the correct size and alignment for your type.

Implementations§

Source§

impl<T, As: IStable> StableLike<T, As>

Source

pub const fn new(value: T) -> Self

Wraps a value in a type that provides information about its layout.

Asserts that T and As have the same size and aligment at compile time, and relies on the user for the niche information to be correct.

Source

pub const unsafe fn as_ref_unchecked(&self) -> &T

Returns a reference to the underlying type

§Safety

This is only safe if T is FFI-safe, or if this self was constructed from a value of T that was instanciated within the same shared object.

Source

pub const fn as_ref(&self) -> &T
where T: IStable,

Returns a reference to the underlying type

Source

pub const unsafe fn as_mut_unchecked(&mut self) -> &mut T

§Safety

This is only safe if T is FFI-safe, or if this self was constructed from a value of T that was instanciated within the same shared object.

Source

pub unsafe fn into_inner_unchecked(self) -> T

§Safety

This is only safe if T is FFI-safe, or if this self was constructed from a value of T that was instanciated within the same shared object.

Source

pub fn into_inner(self) -> T
where T: IStable,

Extracts the inner value from self

Trait Implementations§

Source§

impl<T: Clone, As> Clone for StableLike<T, As>

Source§

fn clone(&self) -> Self

Returns a duplicate 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<T: Debug, As> Debug for StableLike<T, As>

Source§

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

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

impl<T: Display, As> Display for StableLike<T, As>

Source§

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

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

impl<T: Hash, As: Hash> Hash for StableLike<T, As>

Source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl<T, As: IStable> IStable for StableLike<T, As>

Source§

const ID: u64

A stable (and ideally unique) identifier for the type. Often generated using crate::report::gen_id, but can be manually set.
Source§

const REPORT: &'static TypeReport = As::REPORT

A compile-time generated report of the fields of the type, allowing for compatibility inspection.
Source§

type Size = <As as IStable>::Size

The size of the annotated type in bytes.
Source§

type Align = <As as IStable>::Align

The alignment of the annotated type in bytes.
Source§

type ForbiddenValues = <As as IStable>::ForbiddenValues

The values that the annotated type cannot occupy.
Source§

type UnusedBits = <As as IStable>::UnusedBits

The padding bits in the annotated types
Source§

type HasExactlyOneNiche = <As as IStable>::HasExactlyOneNiche

Allows the detection of whether or not core::option::Options are stable: Read more
Source§

type ContainsIndirections = <As as IStable>::ContainsIndirections

Whether or not the type contains indirections (pointers, indices in independent data-structures…)
Source§

fn size() -> usize

Returns the size of the type.
Source§

fn align() -> usize

Returns the alignment of the type.
Source§

unsafe fn is_invalid(ptr: *const u8) -> bool

Returns true if ptr points to memory that cannot be a valid value of Self. Read more
Source§

impl<T: Ord, As: Ord> Ord for StableLike<T, As>

Source§

fn cmp(&self, other: &StableLike<T, As>) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · Source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · Source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · Source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized,

Restrict a value to a certain interval. Read more
Source§

impl<T: PartialEq, As: PartialEq> PartialEq for StableLike<T, As>

Source§

fn eq(&self, other: &StableLike<T, As>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<T: PartialOrd, As: PartialOrd> PartialOrd for StableLike<T, As>

Source§

fn partial_cmp(&self, other: &StableLike<T, As>) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · Source§

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Source§

impl<T: Copy, As> Copy for StableLike<T, As>

Source§

impl<T: Eq, As: Eq> Eq for StableLike<T, As>

Source§

impl<T, As> StructuralPartialEq for StableLike<T, As>

Auto Trait Implementations§

§

impl<T, As> Freeze for StableLike<T, As>
where T: Freeze,

§

impl<T, As> RefUnwindSafe for StableLike<T, As>

§

impl<T, As> Send for StableLike<T, As>
where T: Send, As: Send,

§

impl<T, As> Sync for StableLike<T, As>
where T: Sync, As: Sync,

§

impl<T, As> Unpin for StableLike<T, As>
where T: Unpin, As: Unpin,

§

impl<T, As> UnwindSafe for StableLike<T, As>
where T: UnwindSafe, As: UnwindSafe,

Blanket Implementations§

Source§

impl<Source> AccessAs for Source

Source§

fn ref_as<T>(&self) -> <Source as IGuardRef<T>>::Guard<'_>
where Source: IGuardRef<T>, T: ?Sized,

Provides immutable access to a type as if it were its ABI-unstable equivalent.
Source§

fn mut_as<T>(&mut self) -> <Source as IGuardMut<T>>::GuardMut<'_>
where Source: IGuardMut<T>, T: ?Sized,

Provides mutable access to a type as if it were its ABI-unstable equivalent.
Source§

impl<T> Any for T
where T: IStable,

Source§

extern "C" fn report(&self) -> &'static TypeReport

The report of the type.
Source§

extern "C" fn id(&self) -> u64

The id of the type.
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, dest: *mut u8)

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

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, As> IGuardMut<As> for T
where T: Into<As>, As: Into<T>,

Source§

type GuardMut<'a> = MutAs<'a, T, As> where T: 'a

The type of the guard which will clean up the temporary after applying its changes to the original.
Source§

fn guard_mut_inner(&mut self) -> <T as IGuardMut<As>>::GuardMut<'_>

Construct the temporary and guard it through a mutable reference.
Source§

impl<T, As> IGuardRef<As> for T
where T: Into<As>, As: Into<T>,

Source§

type Guard<'a> = RefAs<'a, T, As> where T: 'a

The type of the guard which will clean up the temporary.
Source§

fn guard_ref_inner(&self) -> <T as IGuardRef<As>>::Guard<'_>

Construct the temporary and guard it through an immutable reference.
Source§

impl<T> IPod for T
where T: IStable<ContainsIndirections = B0> + Copy,

Source§

fn identifier() -> u64

Produces an identifier for the type, allowing to check type at runtime (barring collisions).
Source§

impl<T> Includes<End> for T

Source§

type Output = End

The result
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<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§

fn to_string(&self) -> String

Converts the given value to a String. 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.