struct ConstAnalysis<'a, 'tcx> {
map: Map<'tcx>,
tcx: TyCtxt<'tcx>,
local_decls: &'a LocalDecls<'tcx>,
ecx: InterpCx<'tcx, DummyMachine>,
typing_env: TypingEnv<'tcx>,
}
Fields§
§map: Map<'tcx>
§tcx: TyCtxt<'tcx>
§local_decls: &'a LocalDecls<'tcx>
§ecx: InterpCx<'tcx, DummyMachine>
§typing_env: TypingEnv<'tcx>
Implementations§
Source§impl<'a, 'tcx> ConstAnalysis<'a, 'tcx>
impl<'a, 'tcx> ConstAnalysis<'a, 'tcx>
fn new(tcx: TyCtxt<'tcx>, body: &'a Body<'tcx>, map: Map<'tcx>) -> Self
fn handle_statement( &self, statement: &Statement<'tcx>, state: &mut State<FlatSet<Scalar>>, )
fn handle_intrinsic(&self, intrinsic: &NonDivergingIntrinsic<'tcx>)
fn handle_operand( &self, operand: &Operand<'tcx>, state: &mut State<FlatSet<Scalar>>, ) -> ValueOrPlace<FlatSet<Scalar>>
Sourcefn handle_terminator<'mir>(
&self,
terminator: &'mir Terminator<'tcx>,
state: &mut State<FlatSet<Scalar>>,
) -> TerminatorEdges<'mir, 'tcx>
fn handle_terminator<'mir>( &self, terminator: &'mir Terminator<'tcx>, state: &mut State<FlatSet<Scalar>>, ) -> TerminatorEdges<'mir, 'tcx>
The effect of a successful function call return should not be
applied here, see Analysis::apply_terminator_effect
.
fn handle_call_return( &self, return_places: CallReturnPlaces<'_, 'tcx>, state: &mut State<FlatSet<Scalar>>, )
fn handle_set_discriminant( &self, place: Place<'tcx>, variant_index: VariantIdx, state: &mut State<FlatSet<Scalar>>, )
fn handle_assign( &self, target: Place<'tcx>, rvalue: &Rvalue<'tcx>, state: &mut State<FlatSet<Scalar>>, )
fn handle_rvalue( &self, rvalue: &Rvalue<'tcx>, state: &mut State<FlatSet<Scalar>>, ) -> ValueOrPlace<FlatSet<Scalar>>
fn handle_constant( &self, constant: &ConstOperand<'tcx>, _state: &mut State<FlatSet<Scalar>>, ) -> FlatSet<Scalar>
fn handle_switch_int<'mir>( &self, discr: &'mir Operand<'tcx>, targets: &'mir SwitchTargets, state: &mut State<FlatSet<Scalar>>, ) -> TerminatorEdges<'mir, 'tcx>
Sourcefn assign_operand(
&self,
state: &mut State<FlatSet<Scalar>>,
place: PlaceIndex,
operand: &Operand<'tcx>,
)
fn assign_operand( &self, state: &mut State<FlatSet<Scalar>>, place: PlaceIndex, operand: &Operand<'tcx>, )
The caller must have flooded place
.
Sourcefn assign_constant(
&self,
state: &mut State<FlatSet<Scalar>>,
place: PlaceIndex,
operand: OpTy<'tcx>,
projection: &[PlaceElem<'tcx>],
)
fn assign_constant( &self, state: &mut State<FlatSet<Scalar>>, place: PlaceIndex, operand: OpTy<'tcx>, projection: &[PlaceElem<'tcx>], )
The caller must have flooded place
.
Perform: place = operand.projection
.
fn binary_op( &self, state: &mut State<FlatSet<Scalar>>, op: BinOp, left: &Operand<'tcx>, right: &Operand<'tcx>, ) -> (FlatSet<Scalar>, FlatSet<Scalar>)
fn eval_operand( &self, op: &Operand<'tcx>, state: &mut State<FlatSet<Scalar>>, ) -> FlatSet<ImmTy<'tcx>>
fn eval_discriminant( &self, enum_ty: Ty<'tcx>, variant_index: VariantIdx, ) -> Option<Scalar>
fn wrap_immediate(&self, imm: Immediate) -> FlatSet<Scalar>
Trait Implementations§
Source§impl<'tcx> Analysis<'tcx> for ConstAnalysis<'_, 'tcx>
impl<'tcx> Analysis<'tcx> for ConstAnalysis<'_, 'tcx>
Source§const NAME: &'static str = "ConstAnalysis"
const NAME: &'static str = "ConstAnalysis"
A descriptive name for this analysis. Used only for debugging. Read more
Source§type Domain = State<FlatSet<Scalar>>
type Domain = State<FlatSet<Scalar>>
The type that holds the dataflow state at any given point in the program.
Source§fn bottom_value(&self, _body: &Body<'tcx>) -> Self::Domain
fn bottom_value(&self, _body: &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)
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 moreSource§fn apply_statement_effect(
&mut self,
state: &mut Self::Domain,
statement: &Statement<'tcx>,
_location: Location,
)
fn apply_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_terminator_effect<'mir>(
&mut self,
state: &mut Self::Domain,
terminator: &'mir Terminator<'tcx>,
_location: Location,
) -> TerminatorEdges<'mir, 'tcx>
fn apply_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>,
)
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 moreSource§fn apply_before_statement_effect(
&mut self,
_state: &mut Self::Domain,
_statement: &Statement<'tcx>,
_location: Location,
)
fn apply_before_statement_effect( &mut self, _state: &mut Self::Domain, _statement: &Statement<'tcx>, _location: Location, )
Updates the current dataflow state with an effect that occurs immediately before the
given statement. Read more
Source§fn apply_before_terminator_effect(
&mut self,
_state: &mut Self::Domain,
_terminator: &Terminator<'tcx>,
_location: Location,
)
fn apply_before_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
Source§fn apply_switch_int_edge_effects(
&mut self,
_block: BasicBlock,
_discr: &Operand<'tcx>,
_apply_edge_effects: &mut impl SwitchIntEdgeEffects<Self::Domain>,
)
fn apply_switch_int_edge_effects( &mut self, _block: BasicBlock, _discr: &Operand<'tcx>, _apply_edge_effects: &mut impl SwitchIntEdgeEffects<Self::Domain>, )
Updates the current dataflow state with the effect of taking a particular branch in a
SwitchInt
terminator. Read moreSource§impl<'tcx> DebugWithContext<ConstAnalysis<'_, 'tcx>> for State<FlatSet<Scalar>>
impl<'tcx> DebugWithContext<ConstAnalysis<'_, 'tcx>> for State<FlatSet<Scalar>>
This is used to visualize the dataflow analysis.
fn fmt_with( &self, ctxt: &ConstAnalysis<'_, 'tcx>, f: &mut Formatter<'_>, ) -> Result
Source§fn fmt_diff_with(
&self,
old: &Self,
ctxt: &ConstAnalysis<'_, 'tcx>,
f: &mut Formatter<'_>,
) -> Result
fn fmt_diff_with( &self, old: &Self, ctxt: &ConstAnalysis<'_, 'tcx>, f: &mut Formatter<'_>, ) -> Result
Source§impl<'mir, 'tcx> ResultsVisitor<'mir, 'tcx, ConstAnalysis<'_, 'tcx>> for Collector<'_, 'tcx>
impl<'mir, 'tcx> ResultsVisitor<'mir, 'tcx, ConstAnalysis<'_, 'tcx>> for Collector<'_, 'tcx>
Source§fn visit_statement_before_primary_effect(
&mut self,
results: &mut Results<'tcx, ConstAnalysis<'_, 'tcx>>,
state: &State<FlatSet<Scalar>>,
statement: &'mir Statement<'tcx>,
location: Location,
)
fn visit_statement_before_primary_effect( &mut self, results: &mut Results<'tcx, ConstAnalysis<'_, 'tcx>>, state: &State<FlatSet<Scalar>>, statement: &'mir Statement<'tcx>, location: Location, )
Called with the
before_statement_effect
of the given statement applied to state
but not
its statement_effect
.Source§fn visit_statement_after_primary_effect(
&mut self,
results: &mut Results<'tcx, ConstAnalysis<'_, 'tcx>>,
state: &State<FlatSet<Scalar>>,
statement: &'mir Statement<'tcx>,
location: Location,
)
fn visit_statement_after_primary_effect( &mut self, results: &mut Results<'tcx, ConstAnalysis<'_, 'tcx>>, state: &State<FlatSet<Scalar>>, statement: &'mir Statement<'tcx>, location: Location, )
Called with both the
before_statement_effect
and the statement_effect
of the given
statement applied to state
.Source§fn visit_terminator_before_primary_effect(
&mut self,
results: &mut Results<'tcx, ConstAnalysis<'_, 'tcx>>,
state: &State<FlatSet<Scalar>>,
terminator: &'mir Terminator<'tcx>,
location: Location,
)
fn visit_terminator_before_primary_effect( &mut self, results: &mut Results<'tcx, ConstAnalysis<'_, 'tcx>>, state: &State<FlatSet<Scalar>>, terminator: &'mir Terminator<'tcx>, location: Location, )
Called with the
before_terminator_effect
of the given terminator applied to state
but
not its terminator_effect
.fn visit_block_start(&mut self, _state: &<A as Analysis<'tcx>>::Domain)
Source§fn visit_terminator_after_primary_effect(
&mut self,
_results: &mut Results<'tcx, A>,
_state: &<A as Analysis<'tcx>>::Domain,
_terminator: &'mir Terminator<'tcx>,
_location: Location,
)
fn visit_terminator_after_primary_effect( &mut self, _results: &mut Results<'tcx, A>, _state: &<A as Analysis<'tcx>>::Domain, _terminator: &'mir Terminator<'tcx>, _location: Location, )
Called with both the
before_terminator_effect
and the terminator_effect
of the given
terminator applied to state
. Read morefn visit_block_end(&mut self, _state: &<A as Analysis<'tcx>>::Domain)
Auto Trait Implementations§
impl<'a, 'tcx> DynSend for ConstAnalysis<'a, 'tcx>
impl<'a, 'tcx> DynSync for ConstAnalysis<'a, 'tcx>
impl<'a, 'tcx> Freeze for ConstAnalysis<'a, 'tcx>
impl<'a, 'tcx> !RefUnwindSafe for ConstAnalysis<'a, 'tcx>
impl<'a, 'tcx> !Send for ConstAnalysis<'a, 'tcx>
impl<'a, 'tcx> !Sync for ConstAnalysis<'a, 'tcx>
impl<'a, 'tcx> Unpin for ConstAnalysis<'a, 'tcx>
impl<'a, 'tcx> !UnwindSafe for ConstAnalysis<'a, 'tcx>
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
Mutably borrows from an owned value. Read more
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>
Creates a filterable data provider with the given name for debugging. Read more
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>
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 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>
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 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<T> Pointable for T
impl<T> Pointable 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<'a, T> Captures<'a> for Twhere
T: ?Sized,
impl<T> ErasedDestructor for Twhere
T: 'static,
Layout§
Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...)
attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.
Size: 408 bytes