Add SwitchTargetValue.
This is much clearer than `Option<u128>`.
This commit is contained in:
@@ -1,6 +1,8 @@
|
||||
use std::ops::RangeInclusive;
|
||||
|
||||
use rustc_middle::mir::{self, BasicBlock, CallReturnPlaces, Location, TerminatorEdges};
|
||||
use rustc_middle::mir::{
|
||||
self, BasicBlock, CallReturnPlaces, Location, SwitchTargetValue, TerminatorEdges,
|
||||
};
|
||||
|
||||
use super::visitor::ResultsVisitor;
|
||||
use super::{Analysis, Effect, EffectIndex, Results, SwitchIntTarget};
|
||||
@@ -290,7 +292,8 @@ impl Direction for Forward {
|
||||
let mut tmp = analysis.bottom_value(body);
|
||||
for (value, target) in targets.iter() {
|
||||
tmp.clone_from(exit_state);
|
||||
let si_target = SwitchIntTarget { value: Some(value), target };
|
||||
let si_target =
|
||||
SwitchIntTarget { value: SwitchTargetValue::Normal(value), target };
|
||||
analysis.apply_switch_int_edge_effect(&mut data, &mut tmp, si_target);
|
||||
propagate(target, &tmp);
|
||||
}
|
||||
@@ -302,7 +305,7 @@ impl Direction for Forward {
|
||||
analysis.apply_switch_int_edge_effect(
|
||||
&mut data,
|
||||
exit_state,
|
||||
SwitchIntTarget { value: None, target: otherwise },
|
||||
SwitchIntTarget { value: SwitchTargetValue::Otherwise, target: otherwise },
|
||||
);
|
||||
propagate(otherwise, exit_state);
|
||||
} else {
|
||||
|
||||
@@ -38,7 +38,9 @@ use rustc_data_structures::work_queue::WorkQueue;
|
||||
use rustc_index::bit_set::{DenseBitSet, MixedBitSet};
|
||||
use rustc_index::{Idx, IndexVec};
|
||||
use rustc_middle::bug;
|
||||
use rustc_middle::mir::{self, BasicBlock, CallReturnPlaces, Location, TerminatorEdges, traversal};
|
||||
use rustc_middle::mir::{
|
||||
self, BasicBlock, CallReturnPlaces, Location, SwitchTargetValue, TerminatorEdges, traversal,
|
||||
};
|
||||
use rustc_middle::ty::TyCtxt;
|
||||
use tracing::error;
|
||||
|
||||
@@ -431,7 +433,7 @@ impl EffectIndex {
|
||||
}
|
||||
|
||||
pub struct SwitchIntTarget {
|
||||
pub value: Option<u128>,
|
||||
pub value: SwitchTargetValue,
|
||||
pub target: BasicBlock,
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user