Struct rustc_mir_dataflow::impls::DefinitelyInitializedPlaces [−][src]
pub struct DefinitelyInitializedPlaces<'a, 'tcx> {
tcx: TyCtxt<'tcx>,
body: &'a Body<'tcx>,
mdpe: &'a MoveDataParamEnv<'tcx>,
}
Expand description
DefinitelyInitializedPlaces
tracks all places that are definitely
initialized upon reaching a particular point in the control flow
for a function.
For example, in code like the following, we have corresponding dataflow information shown in the right-hand comments.
struct S;
fn foo(pred: bool) { // definite-init:
// { }
let a = S; let b = S; let c; let d; // {a, b }
if pred {
drop(a); // { b, }
b = S; // { b, }
} else {
drop(b); // {a, }
d = S; // {a, d}
} // { }
c = S; // { c }
}
To determine whether a place may be uninitialized at a particular control-flow point, one can take the set-complement of this data.
Similarly, at a given drop
statement, the set-difference between
this data and MaybeInitializedPlaces
yields the set of places
that would require a dynamic drop-flag at that statement.
Fields
tcx: TyCtxt<'tcx>
body: &'a Body<'tcx>
mdpe: &'a MoveDataParamEnv<'tcx>
Implementations
fn update_bits(
trans: &mut impl GenKill<MovePathIndex>,
path: MovePathIndex,
state: DropFlagState
)
Trait Implementations
type Domain = Dual<BitSet<MovePathIndex>>
type Domain = Dual<BitSet<MovePathIndex>>
Use set intersection as the join operator.
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
type Idx = MovePathIndex
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
.
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 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
.
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<'a, 'tcx> !RefUnwindSafe for DefinitelyInitializedPlaces<'a, 'tcx>
impl<'a, 'tcx> !Send for DefinitelyInitializedPlaces<'a, 'tcx>
impl<'a, 'tcx> !Sync for DefinitelyInitializedPlaces<'a, 'tcx>
impl<'a, 'tcx> Unpin for DefinitelyInitializedPlaces<'a, 'tcx> where
'tcx: 'a,
impl<'a, 'tcx> !UnwindSafe for DefinitelyInitializedPlaces<'a, 'tcx>
Blanket Implementations
Mutably borrows from an owned value. Read more
impl<'tcx, A, D> RustcPeekAt<'tcx> for A where
A: Analysis<'tcx, Domain = D> + HasMoveData<'tcx>,
D: JoinSemiLattice + Clone + Borrow<BitSet<MovePathIndex>>,
impl<'tcx, A, D> RustcPeekAt<'tcx> for A where
A: Analysis<'tcx, Domain = D> + HasMoveData<'tcx>,
D: JoinSemiLattice + Clone + Borrow<BitSet<MovePathIndex>>,
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: 24 bytes