Struct rustc_mir_dataflow::framework::engine::Engine [−][src]
pub struct Engine<'a, 'tcx, A> where
A: Analysis<'tcx>, {
tcx: TyCtxt<'tcx>,
body: &'a Body<'tcx>,
dead_unwinds: Option<&'a BitSet<BasicBlock>>,
entry_sets: IndexVec<BasicBlock, A::Domain>,
pass_name: Option<&'static str>,
analysis: A,
apply_trans_for_block: Option<Box<dyn Fn(BasicBlock, &mut A::Domain)>>,
}
Expand description
A solver for dataflow problems.
Fields
tcx: TyCtxt<'tcx>
body: &'a Body<'tcx>
dead_unwinds: Option<&'a BitSet<BasicBlock>>
entry_sets: IndexVec<BasicBlock, A::Domain>
pass_name: Option<&'static str>
analysis: A
apply_trans_for_block: Option<Box<dyn Fn(BasicBlock, &mut A::Domain)>>
Cached, cumulative transfer functions for each block.
Implementations
impl<A, D, T, 'tcx, 'a> Engine<'a, 'tcx, A> where
A: GenKillAnalysis<'tcx, Idx = T, Domain = D>,
D: Clone + JoinSemiLattice + GenKill<T> + BorrowMut<BitSet<T>>,
T: Idx,
impl<A, D, T, 'tcx, 'a> Engine<'a, 'tcx, A> where
A: GenKillAnalysis<'tcx, Idx = T, Domain = D>,
D: Clone + JoinSemiLattice + GenKill<T> + BorrowMut<BitSet<T>>,
T: Idx,
Creates a new Engine
to solve a gen-kill dataflow problem.
impl<A, D, 'tcx, 'a> Engine<'a, 'tcx, A> where
A: Analysis<'tcx, Domain = D>,
D: Clone + JoinSemiLattice,
impl<A, D, 'tcx, 'a> Engine<'a, 'tcx, A> where
A: Analysis<'tcx, Domain = D>,
D: Clone + JoinSemiLattice,
Creates a new Engine
to solve a dataflow problem with an arbitrary transfer
function.
Gen-kill problems should use new_gen_kill
, which will coalesce transfer functions for
better performance.
fn new(
tcx: TyCtxt<'tcx>,
body: &'a Body<'tcx>,
analysis: A,
apply_trans_for_block: Option<Box<dyn Fn(BasicBlock, &mut A::Domain)>>
) -> Self
Signals that we do not want dataflow state to propagate across unwind edges for these
BasicBlock
s.
You must take care that dead_unwinds
does not contain a BasicBlock
that can actually
unwind during execution. Otherwise, your dataflow results will not be correct.
Adds an identifier to the graphviz output for this particular run of a dataflow analysis.
Some analyses are run multiple times in the compilation pipeline. Give them a pass_name
to differentiate them. Otherwise, only the results for the latest run will be saved.
Computes the fixpoint for this dataflow problem and returns it.
Auto Trait Implementations
impl<'a, 'tcx, A> !RefUnwindSafe for Engine<'a, 'tcx, A>
impl<'a, 'tcx, A> Unpin for Engine<'a, 'tcx, A> where
A: Unpin,
<A as AnalysisDomain<'tcx>>::Domain: Unpin,
'tcx: 'a,
impl<'a, 'tcx, A> !UnwindSafe for Engine<'a, 'tcx, A>
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.