Struct rustc_mir_dataflow::framework::cursor::ResultsCursor
source · pub struct ResultsCursor<'mir, 'tcx, A, R = Results<'tcx, A>>where
A: Analysis<'tcx>,{
body: &'mir Body<'tcx>,
results: R,
state: A::Domain,
pos: CursorPosition,
state_needs_reset: bool,
reachable_blocks: BitSet<BasicBlock>,
}
Expand description
Allows random access inspection of the results of a dataflow analysis.
This cursor only has linear performance within a basic block when its statements are visited in
the same order as the DIRECTION
of the analysis. In the worst case—when statements are
visited in reverse order—performance will be quadratic in the number of statements in the
block. The order in which basic blocks are inspected has no impact on performance.
A ResultsCursor
can either own (the default) or borrow the dataflow results it inspects. The
type of ownership is determined by R
(see ResultsRefCursor
above).
Fields
body: &'mir Body<'tcx>
results: R
state: A::Domain
pos: CursorPosition
state_needs_reset: bool
Indicates that state
has been modified with a custom effect.
When this flag is set, we need to reset to an entry set before doing a seek.
reachable_blocks: BitSet<BasicBlock>
Implementations
sourceimpl<'mir, 'tcx, A, R> ResultsCursor<'mir, 'tcx, A, R>where
A: Analysis<'tcx>,
R: Borrow<Results<'tcx, A>>,
impl<'mir, 'tcx, A, R> ResultsCursor<'mir, 'tcx, A, R>where
A: Analysis<'tcx>,
R: Borrow<Results<'tcx, A>>,
sourcepub fn new(body: &'mir Body<'tcx>, results: R) -> Self
pub fn new(body: &'mir Body<'tcx>, results: R) -> Self
Returns a new cursor that can inspect results
.
sourcepub(super) fn seek_to_block_entry(&mut self, block: BasicBlock)
pub(super) fn seek_to_block_entry(&mut self, block: BasicBlock)
Resets the cursor to hold the entry set for the given basic block.
For forward dataflow analyses, this is the dataflow state prior to the first statement.
For backward dataflow analyses, this is the dataflow state after the terminator.
sourcepub fn seek_to_block_start(&mut self, block: BasicBlock)
pub fn seek_to_block_start(&mut self, block: BasicBlock)
Resets the cursor to hold the state prior to the first statement in a basic block.
For forward analyses, this is the entry set for the given block.
For backward analyses, this is the state that will be propagated to its predecessors (ignoring edge-specific effects).
sourcepub fn seek_to_block_end(&mut self, block: BasicBlock)
pub fn seek_to_block_end(&mut self, block: BasicBlock)
Resets the cursor to hold the state after the terminator in a basic block.
For backward analyses, this is the entry set for the given block.
For forward analyses, this is the state that will be propagated to its successors (ignoring edge-specific effects).
sourcepub fn seek_before_primary_effect(&mut self, target: Location)
pub fn seek_before_primary_effect(&mut self, target: Location)
Advances the cursor to hold the dataflow state at target
before its “primary” effect is
applied.
The “before” effect at the target location will be applied.
sourcepub fn seek_after_primary_effect(&mut self, target: Location)
pub fn seek_after_primary_effect(&mut self, target: Location)
Advances the cursor to hold the dataflow state at target
after its “primary” effect is
applied.
The “before” effect at the target location will be applied as well.
fn seek_after(&mut self, target: Location, effect: Effect)
sourcepub fn apply_custom_effect(&mut self, f: impl FnOnce(&A, &mut A::Domain))
pub fn apply_custom_effect(&mut self, f: impl FnOnce(&A, &mut A::Domain))
Applies f
to the cursor’s internal state.
This can be used, e.g., to apply the call return effect directly to the cursor without creating an extra copy of the dataflow state.
Auto Trait Implementations
impl<'mir, 'tcx, A, R = Results<'tcx, A>> !RefUnwindSafe for ResultsCursor<'mir, 'tcx, A, R>
impl<'mir, 'tcx, A, R = Results<'tcx, A>> !Send for ResultsCursor<'mir, 'tcx, A, R>
impl<'mir, 'tcx, A, R = Results<'tcx, A>> !Sync for ResultsCursor<'mir, 'tcx, A, R>
impl<'mir, 'tcx, A, R> Unpin for ResultsCursor<'mir, 'tcx, A, R>where
R: Unpin,
<A as AnalysisDomain<'tcx>>::Domain: Unpin,
'tcx: 'mir,
impl<'mir, 'tcx, A, R = Results<'tcx, A>> !UnwindSafe for ResultsCursor<'mir, 'tcx, A, R>
Blanket Implementations
sourceimpl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut 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.