Struct rustc_const_eval::interpret::place::MPlaceTy   
source · pub struct MPlaceTy<'tcx, Prov: Provenance = CtfeProvenance> {
    mplace: MemPlace<Prov>,
    pub layout: TyAndLayout<'tcx>,
}Expand description
A MemPlace with its layout. Constructing it is only possible in this module.
Fields§
§mplace: MemPlace<Prov>§layout: TyAndLayout<'tcx>Implementations§
source§impl<'tcx, Prov: Provenance> MPlaceTy<'tcx, Prov>
 
impl<'tcx, Prov: Provenance> MPlaceTy<'tcx, Prov>
sourcepub fn fake_alloc_zst(layout: TyAndLayout<'tcx>) -> Self
 
pub fn fake_alloc_zst(layout: TyAndLayout<'tcx>) -> Self
Produces a MemPlace that works for ZST but nothing else. Conceptually this is a new allocation, but it doesn’t actually create an allocation so you don’t need to worry about memory leaks.
sourcepub fn map_provenance(self, f: impl FnOnce(Prov) -> Prov) -> Self
 
pub fn map_provenance(self, f: impl FnOnce(Prov) -> Prov) -> Self
Adjust the provenance of the main pointer (metadata is unaffected).
pub(super) fn mplace(&self) -> &MemPlace<Prov>
pub fn ptr(&self) -> Pointer<Option<Prov>>
pub fn to_ref(&self, cx: &impl HasDataLayout) -> Immediate<Prov>
Trait Implementations§
source§impl<Prov: Provenance> Debug for MPlaceTy<'_, Prov>
 
impl<Prov: Provenance> Debug for MPlaceTy<'_, Prov>
source§impl<'tcx, Prov: PartialEq + Provenance> PartialEq for MPlaceTy<'tcx, Prov>
 
impl<'tcx, Prov: PartialEq + Provenance> PartialEq for MPlaceTy<'tcx, Prov>
source§impl<'tcx, Prov: Provenance> Projectable<'tcx, Prov> for MPlaceTy<'tcx, Prov>
 
impl<'tcx, Prov: Provenance> Projectable<'tcx, Prov> for MPlaceTy<'tcx, Prov>
source§fn layout(&self) -> TyAndLayout<'tcx>
 
fn layout(&self) -> TyAndLayout<'tcx>
Get the layout.
source§fn meta(&self) -> MemPlaceMeta<Prov>
 
fn meta(&self) -> MemPlaceMeta<Prov>
Get the metadata of a wide value.
source§fn offset_with_meta<'mir, M: Machine<'mir, 'tcx, Provenance = Prov>>(
    &self,
    offset: Size,
    mode: OffsetMode,
    meta: MemPlaceMeta<Prov>,
    layout: TyAndLayout<'tcx>,
    ecx: &InterpCx<'mir, 'tcx, M>
) -> InterpResult<'tcx, Self>
 
fn offset_with_meta<'mir, M: Machine<'mir, 'tcx, Provenance = Prov>>( &self, offset: Size, mode: OffsetMode, meta: MemPlaceMeta<Prov>, layout: TyAndLayout<'tcx>, ecx: &InterpCx<'mir, 'tcx, M> ) -> InterpResult<'tcx, Self>
Offset the value by the given amount, replacing the layout and metadata.
source§fn to_op<'mir, M: Machine<'mir, 'tcx, Provenance = Prov>>(
    &self,
    _ecx: &InterpCx<'mir, 'tcx, M>
) -> InterpResult<'tcx, OpTy<'tcx, M::Provenance>>
 
fn to_op<'mir, M: Machine<'mir, 'tcx, Provenance = Prov>>( &self, _ecx: &InterpCx<'mir, 'tcx, M> ) -> InterpResult<'tcx, OpTy<'tcx, M::Provenance>>
Convert this to an 
OpTy. This might be an irreversible transformation, but is useful for
reading from this thing.source§fn len<'mir, M: Machine<'mir, 'tcx, Provenance = Prov>>(
    &self,
    ecx: &InterpCx<'mir, 'tcx, M>
) -> InterpResult<'tcx, u64>
 
fn len<'mir, M: Machine<'mir, 'tcx, Provenance = Prov>>( &self, ecx: &InterpCx<'mir, 'tcx, M> ) -> InterpResult<'tcx, u64>
Get the length of a slice/string/array stored here.
fn offset<'mir, M: Machine<'mir, 'tcx, Provenance = Prov>>( &self, offset: Size, layout: TyAndLayout<'tcx>, ecx: &InterpCx<'mir, 'tcx, M> ) -> InterpResult<'tcx, Self>
fn transmute<'mir, M: Machine<'mir, 'tcx, Provenance = Prov>>( &self, layout: TyAndLayout<'tcx>, ecx: &InterpCx<'mir, 'tcx, M> ) -> InterpResult<'tcx, Self>
source§impl<'tcx, Prov: Provenance> Readable<'tcx, Prov> for MPlaceTy<'tcx, Prov>
 
impl<'tcx, Prov: Provenance> Readable<'tcx, Prov> for MPlaceTy<'tcx, Prov>
source§impl<'tcx, Prov: Provenance> Writeable<'tcx, Prov> for MPlaceTy<'tcx, Prov>
 
impl<'tcx, Prov: Provenance> Writeable<'tcx, Prov> for MPlaceTy<'tcx, Prov>
fn as_mplace_or_local( &self ) -> Either<MPlaceTy<'tcx, Prov>, (Local, Option<Size>, usize, TyAndLayout<'tcx>)>
fn force_mplace<'mir, M: Machine<'mir, 'tcx, Provenance = Prov>>( &self, _ecx: &mut InterpCx<'mir, 'tcx, M> ) -> InterpResult<'tcx, MPlaceTy<'tcx, Prov>>
impl<'tcx, Prov: Eq + Provenance> Eq for MPlaceTy<'tcx, Prov>
impl<'tcx, Prov: Provenance> StructuralPartialEq for MPlaceTy<'tcx, Prov>
Auto Trait Implementations§
impl<'tcx, Prov> DynSend for MPlaceTy<'tcx, Prov>where
    Prov: DynSend,
impl<'tcx, Prov> DynSync for MPlaceTy<'tcx, Prov>where
    Prov: DynSync,
impl<'tcx, Prov> Freeze for MPlaceTy<'tcx, Prov>where
    Prov: Freeze,
impl<'tcx, Prov = CtfeProvenance> !RefUnwindSafe for MPlaceTy<'tcx, Prov>
impl<'tcx, Prov> Send for MPlaceTy<'tcx, Prov>where
    Prov: Send,
impl<'tcx, Prov> Sync for MPlaceTy<'tcx, Prov>where
    Prov: Sync,
impl<'tcx, Prov> Unpin for MPlaceTy<'tcx, Prov>where
    Prov: Unpin,
impl<'tcx, Prov = CtfeProvenance> !UnwindSafe for MPlaceTy<'tcx, Prov>
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.