rustc_mir_dataflow

Trait ResultsVisitor

source
pub trait ResultsVisitor<'mir, 'tcx, R> {
    type Domain;

    // Provided methods
    fn visit_block_start(&mut self, _state: &Self::Domain) { ... }
    fn visit_statement_before_primary_effect(
        &mut self,
        _results: &mut R,
        _state: &Self::Domain,
        _statement: &'mir Statement<'tcx>,
        _location: Location,
    ) { ... }
    fn visit_statement_after_primary_effect(
        &mut self,
        _results: &mut R,
        _state: &Self::Domain,
        _statement: &'mir Statement<'tcx>,
        _location: Location,
    ) { ... }
    fn visit_terminator_before_primary_effect(
        &mut self,
        _results: &mut R,
        _state: &Self::Domain,
        _terminator: &'mir Terminator<'tcx>,
        _location: Location,
    ) { ... }
    fn visit_terminator_after_primary_effect(
        &mut self,
        _results: &mut R,
        _state: &Self::Domain,
        _terminator: &'mir Terminator<'tcx>,
        _location: Location,
    ) { ... }
    fn visit_block_end(&mut self, _state: &Self::Domain) { ... }
}
Expand description

A visitor over the results of an Analysis. The type parameter R is the results type being visited.

Required Associated Types§

Provided Methods§

source

fn visit_block_start(&mut self, _state: &Self::Domain)

source

fn visit_statement_before_primary_effect( &mut self, _results: &mut R, _state: &Self::Domain, _statement: &'mir Statement<'tcx>, _location: Location, )

Called with the before_statement_effect of the given statement applied to state but not its statement_effect.

source

fn visit_statement_after_primary_effect( &mut self, _results: &mut R, _state: &Self::Domain, _statement: &'mir Statement<'tcx>, _location: Location, )

Called with both the before_statement_effect and the statement_effect of the given statement applied to state.

source

fn visit_terminator_before_primary_effect( &mut self, _results: &mut R, _state: &Self::Domain, _terminator: &'mir Terminator<'tcx>, _location: Location, )

Called with the before_terminator_effect of the given terminator applied to state but not its terminator_effect.

source

fn visit_terminator_after_primary_effect( &mut self, _results: &mut R, _state: &Self::Domain, _terminator: &'mir Terminator<'tcx>, _location: Location, )

Called with both the before_terminator_effect and the terminator_effect of the given terminator applied to state.

The call_return_effect (if one exists) will not be applied to state.

source

fn visit_block_end(&mut self, _state: &Self::Domain)

Implementors§

source§

impl<'mir, 'tcx, R, N> ResultsVisitor<'mir, 'tcx, R> for Visitor<'_, N>
where N: Idx,

source§

impl<'tcx, A> ResultsVisitor<'_, 'tcx, Results<'tcx, A>> for StateDiffCollector<A::Domain>
where A: Analysis<'tcx>, A::Domain: DebugWithContext<A>,

source§

type Domain = <A as AnalysisDomain<'tcx>>::Domain