Struct rustc_const_eval::interpret::place::PlaceTy
source · pub struct PlaceTy<'tcx, Prov: Provenance = AllocId> {
place: Place<Prov>,
pub layout: TyAndLayout<'tcx>,
pub align: Align,
}
Fields§
§place: Place<Prov>
§layout: TyAndLayout<'tcx>
§align: Align
rustc does not have a proper way to represent the type of a field of a repr(packed)
struct:
it needs to have a different alignment than the field type would usually have.
So we represent this here with a separate field that “overwrites” layout.align
.
This means layout.align
should never be used for a PlaceTy
!
Implementations§
source§impl<'tcx, Prov: Provenance> PlaceTy<'tcx, Prov>
impl<'tcx, Prov: Provenance> PlaceTy<'tcx, Prov>
sourcepub fn as_mplace_or_local(&self) -> Either<MPlaceTy<'tcx, Prov>, (usize, Local)>
pub fn as_mplace_or_local(&self) -> Either<MPlaceTy<'tcx, Prov>, (usize, Local)>
A place is either an mplace or some local.
pub fn assert_mem_place(&self) -> MPlaceTy<'tcx, Prov>
Methods from Deref<Target = Place<Prov>>§
sourcepub fn assert_local(&self) -> (usize, Local)
pub fn assert_local(&self) -> (usize, Local)
Asserts that this points to some local variable. Returns the frame idx and the variable idx.
Trait Implementations§
source§impl<'tcx, Prov: Provenance> Deref for PlaceTy<'tcx, Prov>
impl<'tcx, Prov: Provenance> Deref for PlaceTy<'tcx, Prov>
source§impl<'mir, 'tcx: 'mir, M: Machine<'mir, 'tcx>> ValueMut<'mir, 'tcx, M> for PlaceTy<'tcx, M::Provenance>
impl<'mir, 'tcx: 'mir, M: Machine<'mir, 'tcx>> ValueMut<'mir, 'tcx, M> for PlaceTy<'tcx, M::Provenance>
source§fn layout(&self) -> TyAndLayout<'tcx>
fn layout(&self) -> TyAndLayout<'tcx>
Gets this value’s layout.
source§fn to_op_for_read(
&self,
ecx: &InterpCx<'mir, 'tcx, M>
) -> InterpResult<'tcx, OpTy<'tcx, M::Provenance>>
fn to_op_for_read(
&self,
ecx: &InterpCx<'mir, 'tcx, M>
) -> InterpResult<'tcx, OpTy<'tcx, M::Provenance>>
Makes this into an
OpTy
, in a cheap way that is good for reading.source§fn to_op_for_proj(
&self,
ecx: &mut InterpCx<'mir, 'tcx, M>
) -> InterpResult<'tcx, OpTy<'tcx, M::Provenance>>
fn to_op_for_proj(
&self,
ecx: &mut InterpCx<'mir, 'tcx, M>
) -> InterpResult<'tcx, OpTy<'tcx, M::Provenance>>
Makes this into an
OpTy
, in a potentially more expensive way that is good for projections.source§fn project_downcast(
&self,
ecx: &mut InterpCx<'mir, 'tcx, M>,
variant: VariantIdx
) -> InterpResult<'tcx, Self>
fn project_downcast(
&self,
ecx: &mut InterpCx<'mir, 'tcx, M>,
variant: VariantIdx
) -> InterpResult<'tcx, Self>
Projects to the given enum variant.
source§fn project_field(
&self,
ecx: &mut InterpCx<'mir, 'tcx, M>,
field: usize
) -> InterpResult<'tcx, Self>
fn project_field(
&self,
ecx: &mut InterpCx<'mir, 'tcx, M>,
field: usize
) -> InterpResult<'tcx, Self>
Projects to the n-th field.
Auto Trait Implementations§
impl<'tcx, Prov = AllocId> !RefUnwindSafe for PlaceTy<'tcx, Prov>
impl<'tcx, Prov = AllocId> !Send for PlaceTy<'tcx, Prov>
impl<'tcx, Prov = AllocId> !Sync for PlaceTy<'tcx, Prov>
impl<'tcx, Prov> Unpin for PlaceTy<'tcx, Prov>where
Prov: Unpin,
impl<'tcx, Prov = AllocId> !UnwindSafe for PlaceTy<'tcx, Prov>
Blanket Implementations§
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.