rustc_const_eval::interpret

Trait ValueVisitor

source
pub trait ValueVisitor<'tcx, M: Machine<'tcx>>: Sized {
    type V: Projectable<'tcx, M::Provenance> + From<MPlaceTy<'tcx, M::Provenance>>;

    // Required method
    fn ecx(&self) -> &InterpCx<'tcx, M>;

    // Provided methods
    fn read_discriminant(
        &mut self,
        v: &Self::V,
    ) -> InterpResult<'tcx, VariantIdx> { ... }
    fn aggregate_field_iter(
        memory_index: &IndexVec<FieldIdx, u32>,
    ) -> impl Iterator<Item = FieldIdx> + 'static { ... }
    fn visit_value(&mut self, v: &Self::V) -> InterpResult<'tcx> { ... }
    fn visit_union(
        &mut self,
        _v: &Self::V,
        _fields: NonZero<usize>,
    ) -> InterpResult<'tcx> { ... }
    fn visit_box(
        &mut self,
        _box_ty: Ty<'tcx>,
        _v: &Self::V,
    ) -> InterpResult<'tcx> { ... }
    fn visit_field(
        &mut self,
        _old_val: &Self::V,
        _field: usize,
        new_val: &Self::V,
    ) -> InterpResult<'tcx> { ... }
    fn visit_variant(
        &mut self,
        _old_val: &Self::V,
        _variant: VariantIdx,
        new_val: &Self::V,
    ) -> InterpResult<'tcx> { ... }
    fn walk_value(&mut self, v: &Self::V) -> InterpResult<'tcx> { ... }
}
Expand description

How to traverse a value and what to do when we are at the leaves.

Required Associated Types§

source

type V: Projectable<'tcx, M::Provenance> + From<MPlaceTy<'tcx, M::Provenance>>

Required Methods§

source

fn ecx(&self) -> &InterpCx<'tcx, M>

The visitor must have an InterpCx in it.

Provided Methods§

source

fn read_discriminant(&mut self, v: &Self::V) -> InterpResult<'tcx, VariantIdx>

read_discriminant can be hooked for better error messages.

source

fn aggregate_field_iter( memory_index: &IndexVec<FieldIdx, u32>, ) -> impl Iterator<Item = FieldIdx> + 'static

This function provides the chance to reorder the order in which fields are visited for FieldsShape::Aggregate.

The default means we iterate in source declaration order; alternatively this can do some work with memory_index to iterate in memory order.

source

fn visit_value(&mut self, v: &Self::V) -> InterpResult<'tcx>

Visits the given value, dispatching as appropriate to more specialized visitors.

source

fn visit_union( &mut self, _v: &Self::V, _fields: NonZero<usize>, ) -> InterpResult<'tcx>

Visits the given value as a union. No automatic recursion can happen here.

source

fn visit_box(&mut self, _box_ty: Ty<'tcx>, _v: &Self::V) -> InterpResult<'tcx>

Visits the given value as the pointer of a Box. There is nothing to recurse into. The type of v will be a raw pointer to T, but this is a field of Box<T> and the pointee type is the actual T. box_ty provides the full type of the Box itself.

source

fn visit_field( &mut self, _old_val: &Self::V, _field: usize, new_val: &Self::V, ) -> InterpResult<'tcx>

Called each time we recurse down to a field of a “product-like” aggregate (structs, tuples, arrays and the like, but not enums), passing in old (outer) and new (inner) value. This gives the visitor the chance to track the stack of nested fields that we are descending through.

source

fn visit_variant( &mut self, _old_val: &Self::V, _variant: VariantIdx, new_val: &Self::V, ) -> InterpResult<'tcx>

Called when recursing into an enum variant. This gives the visitor the chance to track the stack of nested fields that we are descending through.

source

fn walk_value(&mut self, v: &Self::V) -> InterpResult<'tcx>

Traversal logic; should not be overloaded.

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.

Implementors§

source§

impl<'rt, 'tcx, M: Machine<'tcx>> ValueVisitor<'tcx, M> for ValidityVisitor<'rt, 'tcx, M>

source§

type V = PlaceTy<'tcx, <M as Machine<'tcx>>::Provenance>