[−][src]Struct rustc_ap_rustc_target::abi::TyAndLayout
The layout of a type, alongside the type itself. Provides various type traversal APIs (e.g., recursing into fields).
Note that the layout is NOT guaranteed to always be identical
to that obtained from layout_of(ty)
, as we need to produce
layouts for which Rust types do not exist, such as enum variants
or synthetic fields of enums (i.e., discriminants) and fat pointers.
Fields
ty: Ty
layout: &'a Layout
Methods
impl<'a, Ty> TyAndLayout<'a, Ty>
[src]
pub fn homogeneous_aggregate<C>(
&self,
cx: &C
) -> Result<HomogeneousAggregate, Heterogeneous> where
Ty: TyAndLayoutMethods<'a, C> + Copy,
C: LayoutOf<Ty = Ty, TyAndLayout = Self>,
[src]
&self,
cx: &C
) -> Result<HomogeneousAggregate, Heterogeneous> where
Ty: TyAndLayoutMethods<'a, C> + Copy,
C: LayoutOf<Ty = Ty, TyAndLayout = Self>,
Returns Homogeneous
if this layout is an aggregate containing fields of
only a single type (e.g., (u32, u32)
). Such aggregates are often
special-cased in ABIs.
Note: We generally ignore fields of zero-sized type when computing this value (see #56877).
This is public so that it can be used in unit tests, but should generally only be relevant to the ABI details of specific targets.
impl<'a, Ty> TyAndLayout<'a, Ty>
[src]
pub fn for_variant<C>(self, cx: &C, variant_index: VariantIdx) -> Self where
Ty: TyAndLayoutMethods<'a, C>,
C: LayoutOf<Ty = Ty>,
[src]
Ty: TyAndLayoutMethods<'a, C>,
C: LayoutOf<Ty = Ty>,
pub fn field<C>(self, cx: &C, i: usize) -> C::TyAndLayout where
Ty: TyAndLayoutMethods<'a, C>,
C: LayoutOf<Ty = Ty>,
[src]
Ty: TyAndLayoutMethods<'a, C>,
C: LayoutOf<Ty = Ty>,
Callers might want to use C: LayoutOf<Ty=Ty, TyAndLayout: MaybeResult<Self>>
to allow recursion (see might_permit_zero_init
below for an example).
pub fn pointee_info_at<C>(self, cx: &C, offset: Size) -> Option<PointeeInfo> where
Ty: TyAndLayoutMethods<'a, C>,
C: LayoutOf<Ty = Ty>,
[src]
Ty: TyAndLayoutMethods<'a, C>,
C: LayoutOf<Ty = Ty>,
impl<'a, Ty> TyAndLayout<'a, Ty>
[src]
pub fn is_unsized(&self) -> bool
[src]
Returns true
if the layout corresponds to an unsized type.
pub fn is_zst(&self) -> bool
[src]
Returns true
if the type is a ZST and not unsized.
pub fn might_permit_raw_init<C, E>(self, cx: &C, zero: bool) -> Result<bool, E> where
Self: Copy,
Ty: TyAndLayoutMethods<'a, C>,
C: LayoutOf<Ty = Ty, TyAndLayout: MaybeResult<Self, Error = E>> + HasDataLayout,
[src]
Self: Copy,
Ty: TyAndLayoutMethods<'a, C>,
C: LayoutOf<Ty = Ty, TyAndLayout: MaybeResult<Self, Error = E>> + HasDataLayout,
Determines if this type permits "raw" initialization by just transmuting some
memory into an instance of T
.
zero
indicates if the memory is zero-initialized, or alternatively
left entirely uninitialized.
This is conservative: in doubt, it will answer true
.
FIXME: Once we removed all the conservatism, we could alternatively create an all-0/all-undef constant and run the const value validator to see if this is a valid value for the given type.
Methods from Deref<Target = &'a Layout>
Trait Implementations
impl<'a, Ty: Clone> Clone for TyAndLayout<'a, Ty>
[src]
fn clone(&self) -> TyAndLayout<'a, Ty>
[src]
fn clone_from(&mut self, source: &Self)
1.0.0[src]
impl<'a, Ty: Copy> Copy for TyAndLayout<'a, Ty>
[src]
impl<'a, Ty: Debug> Debug for TyAndLayout<'a, Ty>
[src]
impl<'a, Ty> Deref for TyAndLayout<'a, Ty>
[src]
impl<'a, Ty: Eq> Eq for TyAndLayout<'a, Ty>
[src]
impl<'a, Ty: Hash> Hash for TyAndLayout<'a, Ty>
[src]
fn hash<__H: Hasher>(&self, state: &mut __H)
[src]
fn hash_slice<H>(data: &[Self], state: &mut H) where
H: Hasher,
1.3.0[src]
H: Hasher,
impl<'a, Ty: PartialEq> PartialEq<TyAndLayout<'a, Ty>> for TyAndLayout<'a, Ty>
[src]
fn eq(&self, other: &TyAndLayout<'a, Ty>) -> bool
[src]
fn ne(&self, other: &TyAndLayout<'a, Ty>) -> bool
[src]
impl<'a, Ty> StructuralEq for TyAndLayout<'a, Ty>
[src]
impl<'a, Ty> StructuralPartialEq for TyAndLayout<'a, Ty>
[src]
Auto Trait Implementations
impl<'a, Ty> RefUnwindSafe for TyAndLayout<'a, Ty> where
Ty: RefUnwindSafe,
Ty: RefUnwindSafe,
impl<'a, Ty> Send for TyAndLayout<'a, Ty> where
Ty: Send,
Ty: Send,
impl<'a, Ty> Sync for TyAndLayout<'a, Ty> where
Ty: Sync,
Ty: Sync,
impl<'a, Ty> Unpin for TyAndLayout<'a, Ty> where
Ty: Unpin,
Ty: Unpin,
impl<'a, Ty> UnwindSafe for TyAndLayout<'a, Ty> where
Ty: UnwindSafe,
Ty: UnwindSafe,
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T
[src]
impl<'a, T> Captures<'a> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<Q, K> Equivalent<K> for Q where
K: Borrow<Q> + ?Sized,
Q: Eq + ?Sized,
[src]
K: Borrow<Q> + ?Sized,
Q: Eq + ?Sized,
fn equivalent(&self, key: &K) -> bool
[src]
impl<T> Erased for T
[src]
impl<T> From<T> for T
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T> MaybeResult<T> for T
[src]
type Error = !
fn from(Result<T, <T as MaybeResult<T>>::Error>) -> T
[src]
fn to_result(Self) -> Result<T, <T as MaybeResult<T>>::Error>
[src]
impl<T> Same<T> for T
type Output = T
Should always be Self
impl<E> SpecializationError for E
[src]
default fn not_found<S, T>(
trait_name: &'static str,
method_name: &'static str
) -> E where
T: ?Sized,
[src]
trait_name: &'static str,
method_name: &'static str
) -> E where
T: ?Sized,
impl<T> ToOwned for T where
T: Clone,
[src]
T: Clone,
type Owned = T
The resulting type after obtaining ownership.
fn to_owned(&self) -> T
[src]
fn clone_into(&self, target: &mut T)
[src]
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,