stable_mir::mir::alloc

Enum GlobalAlloc

source
pub enum GlobalAlloc {
    Function(Instance),
    VTable(Ty, Option<Binder<ExistentialTraitRef>>),
    Static(StaticDef),
    Memory(Allocation),
}
Expand description

An allocation in the SMIR global memory can be either a function pointer, a static, or a “real” allocation with some data in it.

Variants§

§

Function(Instance)

The alloc ID is used as a function pointer.

§

VTable(Ty, Option<Binder<ExistentialTraitRef>>)

This alloc ID points to a symbolic (not-reified) vtable. The None trait ref is used to represent auto traits.

§

Static(StaticDef)

The alloc ID points to a “lazy” static variable that did not get computed (yet). This is also used to break the cycle in recursive statics.

§

Memory(Allocation)

The alloc ID points to memory.

Implementations§

source§

impl GlobalAlloc

source

pub fn vtable_allocation(&self) -> Option<AllocId>

Retrieve the allocation id for a global allocation if it exists.

For [GlobalAlloc::VTable], this will return the allocation for the VTable of the given type for the optional trait if the type implements the trait.

This method will always return None for allocations other than [GlobalAlloc::VTable].

Trait Implementations§

source§

impl Clone for GlobalAlloc

source§

fn clone(&self) -> GlobalAlloc

Returns a copy of the value. Read more
source§

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

Performs copy-assignment from source. Read more
source§

impl Debug for GlobalAlloc

source§

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

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

impl From<AllocId> for GlobalAlloc

source§

fn from(value: AllocId) -> Self

Converts to this type from the input type.
source§

impl PartialEq for GlobalAlloc

source§

fn eq(&self, other: &GlobalAlloc) -> bool

Tests for self and other values to be equal, and is used by ==.
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 Serialize for GlobalAlloc

source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
source§

impl Eq for GlobalAlloc

source§

impl StructuralPartialEq for GlobalAlloc

Auto Trait Implementations§

Blanket Implementations§

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, 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, 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.

Layout§

Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.

Size: 72 bytes

Size for each variant:

  • Function: 24 bytes
  • VTable: 64 bytes
  • Static: 8 bytes
  • Memory: 64 bytes