Struct rustc_mir_dataflow::impls::MaybeLiveLocals [−][src]
pub struct MaybeLiveLocals;
Expand description
A live-variable dataflow analysis.
This analysis considers references as being used only at the point of the
borrow. In other words, this analysis does not track uses because of references that already
exist. See this mir-dataflow
test for an example. You almost never want to use
this analysis without also looking at the results of MaybeBorrowedLocals
.
Field-(in)sensitivity
As the name suggests, this analysis is field insensitive. If a projection of a variable x
is
assigned to (e.g. x.0 = 42
), it does not “define” x
as far as liveness is concerned. In fact,
such an assignment is currently marked as a “use” of x
in an attempt to be maximally
conservative.
Enums and SetDiscriminant
Assigning a literal value to an enum
(e.g. Option<i32>
), does not result in a simple
assignment of the form _1 = /*...*/
in the MIR. For example, the following assignment to x
:
x = Some(4);
compiles to this MIR
((_1 as Some).0: i32) = const 4_i32;
discriminant(_1) = 1;
However, MaybeLiveLocals
does mark x
(_1
) as “killed” after a statement like this.
That’s because it treats the SetDiscriminant
operation as a definition of x
, even though
the writes that actually initialized the locals happened earlier.
This makes MaybeLiveLocals
unsuitable for certain classes of optimization normally associated
with a live variables analysis, notably dead-store elimination. It’s a dirty hack, but it works
okay for the generator state transform (currently the main consumuer of this analysis).
Implementations
Trait Implementations
The type that holds the dataflow state at any given point in the program.
A descriptive name for this analysis. Used only for debugging. Read more
The initial value of the dataflow state upon entry to each basic block.
Mutates the initial value of the dataflow state upon entry to the START_BLOCK
. Read more
See Analysis::apply_statement_effect
.
fn terminator_effect(
&self,
trans: &mut impl GenKill<Self::Idx>,
terminator: &Terminator<'tcx>,
location: Location
)
fn terminator_effect(
&self,
trans: &mut impl GenKill<Self::Idx>,
terminator: &Terminator<'tcx>,
location: Location
)
See Analysis::apply_terminator_effect
.
fn call_return_effect(
&self,
trans: &mut impl GenKill<Self::Idx>,
_block: BasicBlock,
_func: &Operand<'tcx>,
_args: &[Operand<'tcx>],
dest_place: Place<'tcx>
)
fn call_return_effect(
&self,
trans: &mut impl GenKill<Self::Idx>,
_block: BasicBlock,
_func: &Operand<'tcx>,
_args: &[Operand<'tcx>],
dest_place: Place<'tcx>
)
See Analysis::apply_call_return_effect
.
fn yield_resume_effect(
&self,
trans: &mut impl GenKill<Self::Idx>,
_resume_block: BasicBlock,
resume_place: Place<'tcx>
)
fn yield_resume_effect(
&self,
trans: &mut impl GenKill<Self::Idx>,
_resume_block: BasicBlock,
resume_place: Place<'tcx>
)
See Analysis::apply_yield_resume_effect
.
See Analysis::apply_before_statement_effect
.
fn before_terminator_effect(
&self,
_trans: &mut impl GenKill<Self::Idx>,
_terminator: &Terminator<'tcx>,
_location: Location
)
fn before_terminator_effect(
&self,
_trans: &mut impl GenKill<Self::Idx>,
_terminator: &Terminator<'tcx>,
_location: Location
)
See Analysis::apply_before_terminator_effect
.
fn switch_int_edge_effects<G: GenKill<Self::Idx>>(
&self,
_block: BasicBlock,
_discr: &Operand<'tcx>,
_edge_effects: &mut impl SwitchIntEdgeEffects<G>
)
fn switch_int_edge_effects<G: GenKill<Self::Idx>>(
&self,
_block: BasicBlock,
_discr: &Operand<'tcx>,
_edge_effects: &mut impl SwitchIntEdgeEffects<G>
)
See Analysis::apply_switch_int_edge_effects
.
Auto Trait Implementations
impl RefUnwindSafe for MaybeLiveLocals
impl Send for MaybeLiveLocals
impl Sync for MaybeLiveLocals
impl Unpin for MaybeLiveLocals
impl UnwindSafe for MaybeLiveLocals
Blanket Implementations
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: 0 bytes