Type Alias rustc_mir_dataflow::ResultsClonedCursor
source · pub type ResultsClonedCursor<'res, 'mir, 'tcx, A> = ResultsCursor<'mir, 'tcx, A, ResultsCloned<'res, 'tcx, A>>;
Expand description
A ResultsCursor
which uses a cloned Analysis
while borrowing the underlying Results
. This
allows multiple cursors over the same Results
.
Aliased Type§
struct ResultsClonedCursor<'res, 'mir, 'tcx, A> {
body: &'mir Body<'tcx>,
results: Results<'tcx, A, &'res IndexVec<BasicBlock, <A as AnalysisDomain<'tcx>>::Domain>>,
state: <A as AnalysisDomain<'tcx>>::Domain,
pos: CursorPosition,
state_needs_reset: bool,
reachable_blocks: BitSet<BasicBlock>,
}
Fields§
§body: &'mir Body<'tcx>
§results: Results<'tcx, A, &'res IndexVec<BasicBlock, <A as AnalysisDomain<'tcx>>::Domain>>
§state: <A as AnalysisDomain<'tcx>>::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§
source§impl<'mir, 'tcx, A, R> ResultsCursor<'mir, 'tcx, A, R>where
A: Analysis<'tcx>,
impl<'mir, 'tcx, A, R> ResultsCursor<'mir, 'tcx, A, R>where A: Analysis<'tcx>,
source§impl<'res, 'mir, 'tcx, A> ResultsCursor<'mir, 'tcx, A, ResultsCloned<'res, 'tcx, A>>where
A: Analysis<'tcx> + CloneAnalysis,
impl<'res, 'mir, 'tcx, A> ResultsCursor<'mir, 'tcx, A, ResultsCloned<'res, 'tcx, A>>where A: Analysis<'tcx> + CloneAnalysis,
sourcepub fn new_cursor(&self) -> Self
pub fn new_cursor(&self) -> Self
Creates a new cursor over the same Results
. Note that the cursor’s position is not
copied.
source§impl<'mir, 'tcx, A, R> ResultsCursor<'mir, 'tcx, A, R>where
A: Analysis<'tcx>,
R: AnalysisResults<'tcx, A>,
impl<'mir, 'tcx, A, R> ResultsCursor<'mir, 'tcx, A, R>where A: Analysis<'tcx>, R: AnalysisResults<'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 fn mut_results(&mut self) -> &mut Results<'tcx, A, R::EntrySets>
pub fn mut_results(&mut self) -> &mut Results<'tcx, A, R::EntrySets>
Returns the underlying Results
.
sourcepub fn mut_analysis(&mut self) -> &mut A
pub fn mut_analysis(&mut self) -> &mut A
Returns the Analysis
used to generate the underlying Results
.
sourcepub fn get_with_analysis(&mut self) -> (&A::Domain, &mut A)
pub fn get_with_analysis(&mut self) -> (&A::Domain, &mut A)
Returns both the dataflow state at the current location and the Analysis
.
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(&mut A, &mut A::Domain))
pub fn apply_custom_effect(&mut self, f: impl FnOnce(&mut 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.
Layout§
Note: Encountered an error during type layout; the type failed to be normalized.