Struct rustc_mir_dataflow::framework::cursor::ResultsCursor   
source · pub struct ResultsCursor<'mir, 'tcx, A>where
    A: Analysis<'tcx>,{
    body: &'mir Body<'tcx>,
    results: Results<'tcx, A>,
    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.
Fields§
§body: &'mir Body<'tcx>§results: Results<'tcx, A>§state: A::Domain§pos: CursorPosition§state_needs_reset: boolIndicates 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> ResultsCursor<'mir, 'tcx, A>where
    A: Analysis<'tcx>,
 
impl<'mir, 'tcx, A> ResultsCursor<'mir, 'tcx, A>where
    A: Analysis<'tcx>,
sourcepub fn into_results(self) -> Results<'tcx, A>
 
pub fn into_results(self) -> Results<'tcx, A>
Unwraps this cursor, returning the underlying Results.
sourcepub fn new(body: &'mir Body<'tcx>, results: Results<'tcx, A>) -> Self
 
pub fn new(body: &'mir Body<'tcx>, results: Results<'tcx, A>) -> Self
Returns a new cursor that can inspect results.
sourcepub fn mut_results(&mut self) -> &mut Results<'tcx, A>
 
pub fn mut_results(&mut self) -> &mut Results<'tcx, A>
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(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.
Auto Trait Implementations§
impl<'mir, 'tcx, A> DynSend for ResultsCursor<'mir, 'tcx, A>
impl<'mir, 'tcx, A> DynSync for ResultsCursor<'mir, 'tcx, A>
impl<'mir, 'tcx, A> Freeze for ResultsCursor<'mir, 'tcx, A>
impl<'mir, 'tcx, A> !RefUnwindSafe for ResultsCursor<'mir, 'tcx, A>
impl<'mir, 'tcx, A> Send for ResultsCursor<'mir, 'tcx, A>
impl<'mir, 'tcx, A> Sync for ResultsCursor<'mir, 'tcx, A>
impl<'mir, 'tcx, A> Unpin for ResultsCursor<'mir, 'tcx, A>
impl<'mir, 'tcx, A> !UnwindSafe for ResultsCursor<'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
§impl<T> Filterable for T
 
impl<T> Filterable for T
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<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
§impl<T> Pointable for T
 
impl<T> Pointable for T
source§impl<'tcx, T> ToPredicate<'tcx, T> for T
 
impl<'tcx, T> ToPredicate<'tcx, T> for T
fn to_predicate(self, _tcx: TyCtxt<'tcx>) -> 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.