Struct PointsToAnalysis

Source
struct PointsToAnalysis<'a> {
    fn_sig: Option<&'a EarlyBinder<PolyFnSig>>,
    map: &'a Map,
}
Expand description

This implement a points to analysis for mutable references over a [FlatSet]. The analysis is a may analysis. If you want to know if a reference definitively points to a location you have to combine it with the result of a definitely initialized analysis. See module level documentation for more details.

Fields§

§fn_sig: Option<&'a EarlyBinder<PolyFnSig>>§map: &'a Map

Implementations§

Source§

impl<'a> PointsToAnalysis<'a>

Source

fn new(map: &'a Map, fn_sig: Option<&'a EarlyBinder<PolyFnSig>>) -> Self

Source

fn handle_statement(&self, statement: &Statement<'_>, state: &mut State)

Source

fn handle_assign( &self, target: Place<'_>, rvalue: &Rvalue<'_>, state: &mut State, )

Source

fn handle_ref(&self, place: &Place<'_>, state: &State) -> FlatSet<Loc>

Source

fn handle_operand(&self, operand: &Operand<'_>) -> Option<PlaceIndex>

Source

fn handle_terminator<'mir, 'tcx>( &self, terminator: &'mir Terminator<'tcx>, state: &mut State, ) -> TerminatorEdges<'mir, 'tcx>

The effect of a successful function call return should not be applied here, see [Analysis::apply_primary_terminator_effect].

Source

fn handle_call_return( &self, return_places: CallReturnPlaces<'_, '_>, state: &mut State, )

Trait Implementations§

Source§

impl<'tcx> Analysis<'tcx> for PointsToAnalysis<'_>

Source§

const NAME: &'static str = "PointsToAnalysis"

A descriptive name for this analysis. Used only for debugging. Read more
Source§

type Domain = State

The type that holds the dataflow state at any given point in the program.
Source§

fn bottom_value(&self, _: &Body<'tcx>) -> Self::Domain

Returns the initial value of the dataflow state upon entry to each basic block.
Source§

fn initialize_start_block(&self, body: &Body<'tcx>, state: &mut Self::Domain)

Mutates the initial value of the dataflow state upon entry to the START_BLOCK. Read more
Source§

fn apply_primary_statement_effect( &mut self, state: &mut Self::Domain, statement: &Statement<'tcx>, _location: Location, )

Updates the current dataflow state with the effect of evaluating a statement.
Source§

fn apply_primary_terminator_effect<'mir>( &mut self, state: &mut Self::Domain, terminator: &'mir Terminator<'tcx>, _location: Location, ) -> TerminatorEdges<'mir, 'tcx>

Updates the current dataflow state with the effect of evaluating a terminator. Read more
Source§

fn apply_call_return_effect( &mut self, state: &mut Self::Domain, _block: BasicBlock, return_places: CallReturnPlaces<'_, 'tcx>, )

Updates the current dataflow state with the effect of a successful return from a Call terminator. Read more
§

type Direction = Forward

The direction of this analysis. Either Forward or Backward.
§

type SwitchIntData = !

Auxiliary data used for analyzing SwitchInt terminators, if necessary.
§

fn apply_early_statement_effect( &mut self, _state: &mut Self::Domain, _statement: &Statement<'tcx>, _location: Location, )

Updates the current dataflow state with an “early” effect, i.e. one that occurs immediately before the given statement. Read more
§

fn apply_early_terminator_effect( &mut self, _state: &mut Self::Domain, _terminator: &Terminator<'tcx>, _location: Location, )

Updates the current dataflow state with an effect that occurs immediately before the given terminator. Read more
§

fn get_switch_int_data( &mut self, _block: BasicBlock, _discr: &Operand<'tcx>, ) -> Option<Self::SwitchIntData>

Used to update the current dataflow state with the effect of taking a particular branch in a SwitchInt terminator. Read more
§

fn apply_switch_int_edge_effect( &mut self, _data: &mut Self::SwitchIntData, _state: &mut Self::Domain, _edge: SwitchIntTarget, )

See comments on get_switch_int_data.
§

fn iterate_to_fixpoint<'mir>( self, tcx: TyCtxt<'tcx>, body: &'mir Body<'tcx>, pass_name: Option<&'static str>, ) -> Results<'tcx, Self>
where Self: Sized, Self::Domain: DebugWithContext<Self>,

Finds the fixpoint for this dataflow problem. Read more
Source§

impl DebugWithContext<PointsToAnalysis<'_>> for State

This is used to visualize the dataflow analysis.

Source§

fn fmt_with(&self, ctxt: &PointsToAnalysis<'_>, f: &mut Formatter<'_>) -> Result

Source§

fn fmt_diff_with( &self, old: &Self, ctxt: &PointsToAnalysis<'_>, f: &mut Formatter<'_>, ) -> Result

Print the difference between self and old. Read more
Source§

impl<'a, 'mir, 'tcx> ResultsVisitor<'mir, 'tcx, PointsToAnalysis<'a>> for CollectPointerToBorrows<'_>

Source§

fn visit_block_start(&mut self, state: &State)

Source§

fn visit_after_primary_statement_effect( &mut self, _results: &mut Results<'tcx, PointsToAnalysis<'a>>, state: &State, _statement: &'mir Statement<'tcx>, location: Location, )

Called after the “primary” effect of the given statement is applied to state.
Source§

fn visit_after_primary_terminator_effect( &mut self, results: &mut Results<'tcx, PointsToAnalysis<'a>>, _state: &State, terminator: &'mir Terminator<'tcx>, location: Location, )

Called after the “primary” effect of the given terminator is applied to state. Read more
§

fn visit_after_early_statement_effect( &mut self, _results: &mut Results<'tcx, A>, _state: &<A as Analysis<'tcx>>::Domain, _statement: &'mir Statement<'tcx>, _location: Location, )

Called after the “early” effect of the given statement is applied to state.
§

fn visit_after_early_terminator_effect( &mut self, _results: &mut Results<'tcx, A>, _state: &<A as Analysis<'tcx>>::Domain, _terminator: &'mir Terminator<'tcx>, _location: Location, )

Called after the “early” effect of the given terminator is applied to state.
§

fn visit_block_end(&mut self, _state: &<A as Analysis<'tcx>>::Domain)

Auto Trait Implementations§

§

impl<'a> Freeze for PointsToAnalysis<'a>

§

impl<'a> RefUnwindSafe for PointsToAnalysis<'a>

§

impl<'a> Send for PointsToAnalysis<'a>

§

impl<'a> Sync for PointsToAnalysis<'a>

§

impl<'a> Unpin for PointsToAnalysis<'a>

§

impl<'a> UnwindSafe for PointsToAnalysis<'a>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts 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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts 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 more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more