pub struct Engine<'mir, 'tcx, A>where
A: Analysis<'tcx>,{
tcx: TyCtxt<'tcx>,
body: &'mir Body<'tcx>,
entry_sets: IndexVec<BasicBlock, A::Domain>,
pass_name: Option<&'static str>,
analysis: A,
apply_statement_trans_for_block: Option<Box<dyn Fn(BasicBlock, &mut A::Domain)>>,
}
Expand description
A solver for dataflow problems.
Fields§
§tcx: TyCtxt<'tcx>
§body: &'mir Body<'tcx>
§entry_sets: IndexVec<BasicBlock, A::Domain>
§pass_name: Option<&'static str>
§analysis: A
§apply_statement_trans_for_block: Option<Box<dyn Fn(BasicBlock, &mut A::Domain)>>
Cached, cumulative transfer functions for each block.
Implementations§
source§impl<'mir, 'tcx, A, D, T> Engine<'mir, 'tcx, A>where
A: GenKillAnalysis<'tcx, Idx = T, Domain = D>,
D: Clone + JoinSemiLattice + GenKill<T> + BitSetExt<T>,
T: Idx,
impl<'mir, 'tcx, A, D, T> Engine<'mir, 'tcx, A>where
A: GenKillAnalysis<'tcx, Idx = T, Domain = D>,
D: Clone + JoinSemiLattice + GenKill<T> + BitSetExt<T>,
T: Idx,
sourcepub fn new_gen_kill(
tcx: TyCtxt<'tcx>,
body: &'mir Body<'tcx>,
analysis: A,
) -> Self
pub fn new_gen_kill( tcx: TyCtxt<'tcx>, body: &'mir Body<'tcx>, analysis: A, ) -> Self
Creates a new Engine
to solve a gen-kill dataflow problem.
source§impl<'mir, 'tcx, A, D> Engine<'mir, 'tcx, A>
impl<'mir, 'tcx, A, D> Engine<'mir, 'tcx, A>
sourcepub fn new_generic(
tcx: TyCtxt<'tcx>,
body: &'mir Body<'tcx>,
analysis: A,
) -> Self
pub fn new_generic( tcx: TyCtxt<'tcx>, body: &'mir Body<'tcx>, analysis: A, ) -> Self
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: &'mir Body<'tcx>, analysis: A, apply_statement_trans_for_block: Option<Box<dyn Fn(BasicBlock, &mut A::Domain)>>, ) -> Self
sourcepub fn pass_name(self, name: &'static str) -> Self
pub fn pass_name(self, name: &'static str) -> Self
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.
sourcepub fn iterate_to_fixpoint(self) -> Results<'tcx, A>where
A::Domain: DebugWithContext<A>,
pub fn iterate_to_fixpoint(self) -> Results<'tcx, A>where
A::Domain: DebugWithContext<A>,
Computes the fixpoint for this dataflow problem and returns it.
Auto Trait Implementations§
impl<'mir, 'tcx, A> Freeze for Engine<'mir, 'tcx, A>where
A: Freeze,
impl<'mir, 'tcx, A> !RefUnwindSafe for Engine<'mir, 'tcx, A>
impl<'mir, 'tcx, A> !Send for Engine<'mir, 'tcx, A>
impl<'mir, 'tcx, A> !Sync for Engine<'mir, 'tcx, A>
impl<'mir, 'tcx, A> Unpin for Engine<'mir, 'tcx, A>
impl<'mir, 'tcx, A> !UnwindSafe for Engine<'mir, 'tcx, A>
Blanket Implementations§
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
source§impl<T, R> CollectAndApply<T, R> for T
impl<T, R> CollectAndApply<T, R> for T
source§impl<T> Filterable for T
impl<T> Filterable for T
source§fn filterable(
self,
filter_name: &'static str,
) -> RequestFilterDataProvider<T, fn(_: DataRequest<'_>) -> bool>
fn filterable( self, filter_name: &'static str, ) -> RequestFilterDataProvider<T, fn(_: DataRequest<'_>) -> bool>
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<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§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
source§impl<I, T, U> Upcast<I, U> for Twhere
U: UpcastFrom<I, T>,
impl<I, T, U> Upcast<I, U> for Twhere
U: UpcastFrom<I, T>,
source§impl<I, T> UpcastFrom<I, T> for T
impl<I, T> UpcastFrom<I, T> for T
fn upcast_from(from: T, _tcx: I) -> 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.