Enum rustc_transmute::layout::tree::Tree   
source · pub(crate) enum Tree<D, R>{
    Seq(Vec<Self>),
    Alt(Vec<Self>),
    Def(D),
    Ref(R),
    Byte(Byte),
}Expand description
A tree-based representation of a type layout.
Invariants:
- All paths through the layout have the same length (in bytes).
Nice-to-haves:
- An Altis never directly nested beneath anotherAlt.
- A Seqis never directly nested beneath anotherSeq.
- Seqs and- Alts with a single member do not exist.
Variants§
Seq(Vec<Self>)
A sequence of successive layouts.
Alt(Vec<Self>)
A choice between alternative layouts.
Def(D)
A definition node.
Ref(R)
A reference node.
Byte(Byte)
A byte node.
Implementations§
source§impl<'tcx> Tree<Def<'tcx>, Ref<'tcx>>
 
impl<'tcx> Tree<Def<'tcx>, Ref<'tcx>>
pub fn from_ty(ty: Ty<'tcx>, tcx: TyCtxt<'tcx>) -> Result<Self, Err>
fn from_repr_c_variant( ty: Ty<'tcx>, adt_def: AdtDef<'tcx>, args_ref: GenericArgsRef<'tcx>, layout_summary: &LayoutSummary, discr: Option<Discr<'tcx>>, variant_def: &'tcx VariantDef, tcx: TyCtxt<'tcx> ) -> Result<Self, Err>
pub fn from_discr(discr: Discr<'tcx>, tcx: TyCtxt<'tcx>, size: usize) -> Self
source§impl<D, R> Tree<D, R>
 
impl<D, R> Tree<D, R>
sourcepub(crate) fn uninhabited() -> Self
 
pub(crate) fn uninhabited() -> Self
A Tree representing an uninhabited type.
sourcepub(crate) fn from_bits(bits: u8) -> Self
 
pub(crate) fn from_bits(bits: u8) -> Self
A Tree whose layout accepts exactly the given bit pattern.
sourcepub(crate) fn number(width_in_bytes: usize) -> Self
 
pub(crate) fn number(width_in_bytes: usize) -> Self
A Tree whose layout is a number of the given width.
sourcepub(crate) fn padding(width_in_bytes: usize) -> Self
 
pub(crate) fn padding(width_in_bytes: usize) -> Self
A Tree whose layout is entirely padding of the given width.
sourcepub(crate) fn prune<F>(self, f: &F) -> Tree<!, R>
 
pub(crate) fn prune<F>(self, f: &F) -> Tree<!, R>
Remove all Def nodes, and all branches of the layout for which f
produces true.
sourcepub(crate) fn is_inhabited(&self) -> bool
 
pub(crate) fn is_inhabited(&self) -> bool
Produces true if Tree is an inhabited type; otherwise false.
Trait Implementations§
source§impl<D, R> PartialEq for Tree<D, R>
 
impl<D, R> PartialEq for Tree<D, R>
impl<D, R> Eq for Tree<D, R>
impl<D, R> StructuralPartialEq for Tree<D, R>
Auto Trait Implementations§
impl<D, R> DynSend for Tree<D, R>
impl<D, R> DynSync for Tree<D, R>
impl<D, R> Freeze for Tree<D, R>
impl<D, R> RefUnwindSafe for Tree<D, R>where
    D: RefUnwindSafe,
    R: RefUnwindSafe,
impl<D, R> Send for Tree<D, R>
impl<D, R> Sync for Tree<D, R>
impl<D, R> Unpin for Tree<D, R>
impl<D, R> UnwindSafe for Tree<D, R>where
    D: UnwindSafe,
    R: UnwindSafe,
Blanket Implementations§
§impl<T> AnyEq for T
 
impl<T> AnyEq for T
source§impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
 
impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
source§impl<T, R> CollectAndApply<T, R> for T
 
impl<T, R> CollectAndApply<T, R> for T
source§impl<Q, K> Equivalent<K> for Q
 
impl<Q, K> Equivalent<K> for Q
§impl<Q, K> Equivalent<K> for Q
 
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
 
fn equivalent(&self, key: &K) -> bool
Checks if this value is equivalent to the given key. Read more
§impl<Q, K> Equivalent<K> for Q
 
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
 
fn equivalent(&self, key: &K) -> bool
Compare self to 
key and return true if they are equal.§impl<T> Filterable for T
 
impl<T> Filterable for T
source§impl<T> Instrument for T
 
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
 
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
 
fn in_current_span(self) -> Instrumented<Self>
source§impl<P> IntoQueryParam<P> for P
 
impl<P> IntoQueryParam<P> for P
fn into_query_param(self) -> P
source§impl<T> MaybeResult<T> for T
 
impl<T> MaybeResult<T> for T
§impl<T> Pointable for T
 
impl<T> Pointable for T
source§impl<'tcx, T> ToPredicate<'tcx, T> for T
 
impl<'tcx, T> ToPredicate<'tcx, T> for T
fn to_predicate(self, _tcx: TyCtxt<'tcx>) -> T
source§impl<Tcx, T> Value<Tcx> for Twhere
    Tcx: DepContext,
 
impl<Tcx, T> Value<Tcx> for Twhere
    Tcx: DepContext,
default fn from_cycle_error( tcx: Tcx, cycle_error: &CycleError, _guar: ErrorGuaranteed ) -> T
source§impl<T> WithSubscriber for T
 
impl<T> WithSubscriber for T
source§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
 
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
source§fn with_current_subscriber(self) -> WithDispatch<Self>
 
fn with_current_subscriber(self) -> WithDispatch<Self>
impl<'a, T> Captures<'a> for Twhere
    T: ?Sized,
impl<T> ErasedDestructor for Twhere
    T: 'static,
impl<T> MaybeSendSync for T
Layout§
Note: Unable to compute type layout, possibly due to this type having generic parameters. Layout can only be computed for concrete, fully-instantiated types.