Auto merge of #96116 - ouz-a:mir-opt, r=oli-obk
Make derefer work everwhere Follow up work on previous PR's #95649 and #95857. r? rust-lang/mir-opt _Co-Authored-By: `@oli-obk_`
This commit is contained in:
commit
055bf4ccd5
12 changed files with 609 additions and 267 deletions
|
@ -141,6 +141,7 @@ impl<'tcx> MirPatch<'tcx> {
|
|||
|
||||
let mut delta = 0;
|
||||
let mut last_bb = START_BLOCK;
|
||||
let mut stmts_and_targets: Vec<(Statement<'_>, BasicBlock)> = Vec::new();
|
||||
for (mut loc, stmt) in new_statements {
|
||||
if loc.block != last_bb {
|
||||
delta = 0;
|
||||
|
@ -149,11 +150,30 @@ impl<'tcx> MirPatch<'tcx> {
|
|||
debug!("MirPatch: adding statement {:?} at loc {:?}+{}", stmt, loc, delta);
|
||||
loc.statement_index += delta;
|
||||
let source_info = Self::source_info_for_index(&body[loc.block], loc);
|
||||
|
||||
// For mir-opt `Derefer` to work in all cases we need to
|
||||
// get terminator's targets and apply the statement to all of them.
|
||||
if loc.statement_index > body[loc.block].statements.len() {
|
||||
let term = body[loc.block].terminator();
|
||||
let successors = term.successors().clone();
|
||||
|
||||
for i in successors {
|
||||
stmts_and_targets
|
||||
.push((Statement { source_info, kind: stmt.clone() }, i.clone()));
|
||||
}
|
||||
delta += 1;
|
||||
continue;
|
||||
}
|
||||
|
||||
body[loc.block]
|
||||
.statements
|
||||
.insert(loc.statement_index, Statement { source_info, kind: stmt });
|
||||
delta += 1;
|
||||
}
|
||||
|
||||
for (stmt, target) in stmts_and_targets.into_iter().rev() {
|
||||
body[target].statements.insert(0, stmt);
|
||||
}
|
||||
}
|
||||
|
||||
pub fn source_info_for_index(data: &BasicBlockData<'_>, loc: Location) -> SourceInfo {
|
||||
|
|
|
@ -1,68 +1,89 @@
|
|||
use crate::MirPass;
|
||||
use rustc_index::vec::IndexVec;
|
||||
use rustc_middle::mir::patch::MirPatch;
|
||||
use rustc_middle::mir::visit::{MutVisitor, PlaceContext};
|
||||
use rustc_middle::mir::*;
|
||||
use rustc_middle::ty::TyCtxt;
|
||||
pub struct Derefer;
|
||||
|
||||
pub fn deref_finder<'tcx>(tcx: TyCtxt<'tcx>, body: &mut Body<'tcx>) {
|
||||
let mut patch = MirPatch::new(body);
|
||||
let (basic_blocks, local_decl) = body.basic_blocks_and_local_decls_mut();
|
||||
for (block, data) in basic_blocks.iter_enumerated_mut() {
|
||||
for (i, stmt) in data.statements.iter_mut().enumerate() {
|
||||
match stmt.kind {
|
||||
StatementKind::Assign(box (og_place, Rvalue::Ref(region, borrow_knd, place))) => {
|
||||
let mut place_local = place.local;
|
||||
let mut last_len = 0;
|
||||
for (idx, (p_ref, p_elem)) in place.iter_projections().enumerate() {
|
||||
if p_elem == ProjectionElem::Deref && !p_ref.projection.is_empty() {
|
||||
// The type that we are derefing.
|
||||
let ty = p_ref.ty(local_decl, tcx).ty;
|
||||
let temp = patch.new_temp(ty, stmt.source_info.span);
|
||||
pub struct DerefChecker<'tcx> {
|
||||
tcx: TyCtxt<'tcx>,
|
||||
patcher: MirPatch<'tcx>,
|
||||
local_decls: IndexVec<Local, LocalDecl<'tcx>>,
|
||||
}
|
||||
|
||||
// Because we are assigning this right before original statement
|
||||
// we are using index i of statement.
|
||||
let loc = Location { block: block, statement_index: i };
|
||||
patch.add_statement(loc, StatementKind::StorageLive(temp));
|
||||
impl<'tcx> MutVisitor<'tcx> for DerefChecker<'tcx> {
|
||||
fn tcx(&self) -> TyCtxt<'tcx> {
|
||||
self.tcx
|
||||
}
|
||||
|
||||
// We are adding current p_ref's projections to our
|
||||
// temp value, excluding projections we already covered.
|
||||
let deref_place = Place::from(place_local)
|
||||
.project_deeper(&p_ref.projection[last_len..], tcx);
|
||||
patch.add_assign(
|
||||
loc,
|
||||
Place::from(temp),
|
||||
Rvalue::Use(Operand::Move(deref_place)),
|
||||
);
|
||||
fn visit_place(&mut self, place: &mut Place<'tcx>, _: PlaceContext, loc: Location) {
|
||||
let mut place_local = place.local;
|
||||
let mut last_len = 0;
|
||||
let mut last_deref_idx = 0;
|
||||
|
||||
place_local = temp;
|
||||
last_len = p_ref.projection.len();
|
||||
let mut prev_temp: Option<Local> = None;
|
||||
|
||||
// We are creating a place by using our temp value's location
|
||||
// and copying derefed values which we need to create new statement.
|
||||
let temp_place =
|
||||
Place::from(temp).project_deeper(&place.projection[idx..], tcx);
|
||||
let new_stmt = Statement {
|
||||
source_info: stmt.source_info,
|
||||
kind: StatementKind::Assign(Box::new((
|
||||
og_place,
|
||||
Rvalue::Ref(region, borrow_knd, temp_place),
|
||||
))),
|
||||
};
|
||||
|
||||
// Replace current statement with newly created one.
|
||||
*stmt = new_stmt;
|
||||
|
||||
// Since our job with the temp is done it should be gone
|
||||
let loc = Location { block: block, statement_index: i + 1 };
|
||||
patch.add_statement(loc, StatementKind::StorageDead(temp));
|
||||
}
|
||||
}
|
||||
}
|
||||
_ => (),
|
||||
for (idx, (p_ref, p_elem)) in place.iter_projections().enumerate() {
|
||||
if p_elem == ProjectionElem::Deref && !p_ref.projection.is_empty() {
|
||||
last_deref_idx = idx;
|
||||
}
|
||||
}
|
||||
|
||||
for (idx, (p_ref, p_elem)) in place.iter_projections().enumerate() {
|
||||
if p_elem == ProjectionElem::Deref && !p_ref.projection.is_empty() {
|
||||
let ty = p_ref.ty(&self.local_decls, self.tcx).ty;
|
||||
let temp =
|
||||
self.patcher.new_temp(ty, self.local_decls[p_ref.local].source_info.span);
|
||||
|
||||
self.patcher.add_statement(loc, StatementKind::StorageLive(temp));
|
||||
|
||||
// We are adding current p_ref's projections to our
|
||||
// temp value, excluding projections we already covered.
|
||||
let deref_place = Place::from(place_local)
|
||||
.project_deeper(&p_ref.projection[last_len..], self.tcx);
|
||||
self.patcher.add_assign(
|
||||
loc,
|
||||
Place::from(temp),
|
||||
Rvalue::Use(Operand::Move(deref_place)),
|
||||
);
|
||||
|
||||
place_local = temp;
|
||||
last_len = p_ref.projection.len();
|
||||
|
||||
// Change `Place` only if we are actually at the Place's last deref
|
||||
if idx == last_deref_idx {
|
||||
let temp_place =
|
||||
Place::from(temp).project_deeper(&place.projection[idx..], self.tcx);
|
||||
*place = temp_place;
|
||||
}
|
||||
|
||||
// We are destroying last temp since it's no longer used.
|
||||
if let Some(prev_temp) = prev_temp {
|
||||
self.patcher.add_statement(loc, StatementKind::StorageDead(prev_temp));
|
||||
}
|
||||
|
||||
prev_temp = Some(temp);
|
||||
}
|
||||
}
|
||||
|
||||
// Since we won't be able to reach final temp, we destroy it outside the loop.
|
||||
if let Some(prev_temp) = prev_temp {
|
||||
let last_loc = Location { block: loc.block, statement_index: loc.statement_index + 1 };
|
||||
self.patcher.add_statement(last_loc, StatementKind::StorageDead(prev_temp));
|
||||
}
|
||||
}
|
||||
patch.apply(body);
|
||||
}
|
||||
|
||||
pub fn deref_finder<'tcx>(tcx: TyCtxt<'tcx>, body: &mut Body<'tcx>) {
|
||||
let patch = MirPatch::new(body);
|
||||
let mut checker = DerefChecker { tcx, patcher: patch, local_decls: body.local_decls.clone() };
|
||||
|
||||
for (bb, data) in body.basic_blocks_mut().iter_enumerated_mut() {
|
||||
checker.visit_basic_block_data(bb, data);
|
||||
}
|
||||
|
||||
checker.patcher.apply(body);
|
||||
}
|
||||
|
||||
impl<'tcx> MirPass<'tcx> for Derefer {
|
||||
|
|
111
src/test/mir-opt/derefer_complex_case.main.Derefer.diff
Normal file
111
src/test/mir-opt/derefer_complex_case.main.Derefer.diff
Normal file
|
@ -0,0 +1,111 @@
|
|||
- // MIR for `main` before Derefer
|
||||
+ // MIR for `main` after Derefer
|
||||
|
||||
fn main() -> () {
|
||||
let mut _0: (); // return place in scope 0 at $DIR/derefer_complex_case.rs:3:11: 3:11
|
||||
let mut _1: std::slice::Iter<i32>; // in scope 0 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
let mut _2: &[i32; 2]; // in scope 0 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
let _3: [i32; 2]; // in scope 0 at $DIR/derefer_complex_case.rs:4:18: 4:26
|
||||
let mut _4: std::slice::Iter<i32>; // in scope 0 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
let mut _5: (); // in scope 0 at $DIR/derefer_complex_case.rs:3:1: 5:2
|
||||
let _6: (); // in scope 0 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
let mut _7: std::option::Option<&i32>; // in scope 0 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
let mut _8: &mut std::slice::Iter<i32>; // in scope 0 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
let mut _9: &mut std::slice::Iter<i32>; // in scope 0 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
let mut _10: isize; // in scope 0 at $DIR/derefer_complex_case.rs:4:5: 4:40
|
||||
let mut _11: !; // in scope 0 at $DIR/derefer_complex_case.rs:4:5: 4:40
|
||||
let mut _13: i32; // in scope 0 at $DIR/derefer_complex_case.rs:4:34: 4:37
|
||||
let mut _14: &[i32; 2]; // in scope 0 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
+ let mut _15: &i32; // in scope 0 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
scope 1 {
|
||||
debug iter => _4; // in scope 1 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
let _12: i32; // in scope 1 at $DIR/derefer_complex_case.rs:4:10: 4:13
|
||||
scope 2 {
|
||||
debug foo => _12; // in scope 2 at $DIR/derefer_complex_case.rs:4:10: 4:13
|
||||
}
|
||||
}
|
||||
|
||||
bb0: {
|
||||
StorageLive(_1); // scope 0 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
StorageLive(_2); // scope 0 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
_14 = const main::promoted[0]; // scope 0 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
// mir::Constant
|
||||
// + span: $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
// + literal: Const { ty: &[i32; 2], val: Unevaluated(main, [], Some(promoted[0])) }
|
||||
_2 = &(*_14); // scope 0 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
_1 = <&[i32; 2] as IntoIterator>::into_iter(move _2) -> bb1; // scope 0 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
// mir::Constant
|
||||
// + span: $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
// + literal: Const { ty: fn(&[i32; 2]) -> <&[i32; 2] as IntoIterator>::IntoIter {<&[i32; 2] as IntoIterator>::into_iter}, val: Value(Scalar(<ZST>)) }
|
||||
}
|
||||
|
||||
bb1: {
|
||||
StorageDead(_2); // scope 0 at $DIR/derefer_complex_case.rs:4:25: 4:26
|
||||
StorageLive(_4); // scope 0 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
_4 = move _1; // scope 0 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
goto -> bb2; // scope 1 at $DIR/derefer_complex_case.rs:4:5: 4:40
|
||||
}
|
||||
|
||||
bb2: {
|
||||
StorageLive(_6); // scope 1 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
StorageLive(_7); // scope 1 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
StorageLive(_8); // scope 1 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
StorageLive(_9); // scope 1 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
_9 = &mut _4; // scope 1 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
_8 = &mut (*_9); // scope 1 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
_7 = <std::slice::Iter<i32> as Iterator>::next(move _8) -> bb3; // scope 1 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
// mir::Constant
|
||||
// + span: $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
// + literal: Const { ty: for<'r> fn(&'r mut std::slice::Iter<i32>) -> Option<<std::slice::Iter<i32> as Iterator>::Item> {<std::slice::Iter<i32> as Iterator>::next}, val: Value(Scalar(<ZST>)) }
|
||||
}
|
||||
|
||||
bb3: {
|
||||
StorageDead(_8); // scope 1 at $DIR/derefer_complex_case.rs:4:25: 4:26
|
||||
_10 = discriminant(_7); // scope 1 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
switchInt(move _10) -> [0_isize: bb6, 1_isize: bb4, otherwise: bb5]; // scope 1 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
}
|
||||
|
||||
bb4: {
|
||||
StorageLive(_12); // scope 1 at $DIR/derefer_complex_case.rs:4:10: 4:13
|
||||
- _12 = (*((_7 as Some).0: &i32)); // scope 1 at $DIR/derefer_complex_case.rs:4:10: 4:13
|
||||
+ StorageLive(_15); // scope 1 at $DIR/derefer_complex_case.rs:4:10: 4:13
|
||||
+ _15 = move ((_7 as Some).0: &i32); // scope 1 at $DIR/derefer_complex_case.rs:4:10: 4:13
|
||||
+ _12 = (*_15); // scope 1 at $DIR/derefer_complex_case.rs:4:10: 4:13
|
||||
+ StorageDead(_15); // scope 2 at $DIR/derefer_complex_case.rs:4:34: 4:37
|
||||
StorageLive(_13); // scope 2 at $DIR/derefer_complex_case.rs:4:34: 4:37
|
||||
_13 = _12; // scope 2 at $DIR/derefer_complex_case.rs:4:34: 4:37
|
||||
_6 = std::mem::drop::<i32>(move _13) -> bb7; // scope 2 at $DIR/derefer_complex_case.rs:4:29: 4:38
|
||||
// mir::Constant
|
||||
// + span: $DIR/derefer_complex_case.rs:4:29: 4:33
|
||||
// + literal: Const { ty: fn(i32) {std::mem::drop::<i32>}, val: Value(Scalar(<ZST>)) }
|
||||
}
|
||||
|
||||
bb5: {
|
||||
unreachable; // scope 1 at $DIR/derefer_complex_case.rs:4:17: 4:26
|
||||
}
|
||||
|
||||
bb6: {
|
||||
_0 = const (); // scope 1 at $DIR/derefer_complex_case.rs:4:5: 4:40
|
||||
StorageDead(_9); // scope 1 at $DIR/derefer_complex_case.rs:4:39: 4:40
|
||||
StorageDead(_7); // scope 1 at $DIR/derefer_complex_case.rs:4:39: 4:40
|
||||
StorageDead(_6); // scope 1 at $DIR/derefer_complex_case.rs:4:39: 4:40
|
||||
StorageDead(_4); // scope 0 at $DIR/derefer_complex_case.rs:4:39: 4:40
|
||||
StorageDead(_1); // scope 0 at $DIR/derefer_complex_case.rs:4:39: 4:40
|
||||
return; // scope 0 at $DIR/derefer_complex_case.rs:5:2: 5:2
|
||||
}
|
||||
|
||||
bb7: {
|
||||
StorageDead(_13); // scope 2 at $DIR/derefer_complex_case.rs:4:37: 4:38
|
||||
StorageDead(_12); // scope 1 at $DIR/derefer_complex_case.rs:4:39: 4:40
|
||||
StorageDead(_9); // scope 1 at $DIR/derefer_complex_case.rs:4:39: 4:40
|
||||
StorageDead(_7); // scope 1 at $DIR/derefer_complex_case.rs:4:39: 4:40
|
||||
StorageDead(_6); // scope 1 at $DIR/derefer_complex_case.rs:4:39: 4:40
|
||||
_5 = const (); // scope 1 at $DIR/derefer_complex_case.rs:4:5: 4:40
|
||||
goto -> bb2; // scope 1 at $DIR/derefer_complex_case.rs:4:5: 4:40
|
||||
+ }
|
||||
+
|
||||
+ bb8 (cleanup): {
|
||||
+ resume; // scope 0 at $DIR/derefer_complex_case.rs:3:1: 5:2
|
||||
}
|
||||
}
|
||||
|
5
src/test/mir-opt/derefer_complex_case.rs
Normal file
5
src/test/mir-opt/derefer_complex_case.rs
Normal file
|
@ -0,0 +1,5 @@
|
|||
// EMIT_MIR derefer_complex_case.main.Derefer.diff
|
||||
|
||||
fn main() {
|
||||
for &foo in &[42, 43] { drop(foo) }
|
||||
}
|
103
src/test/mir-opt/derefer_terminator_test.main.Derefer.diff
Normal file
103
src/test/mir-opt/derefer_terminator_test.main.Derefer.diff
Normal file
|
@ -0,0 +1,103 @@
|
|||
- // MIR for `main` before Derefer
|
||||
+ // MIR for `main` after Derefer
|
||||
|
||||
fn main() -> () {
|
||||
let mut _0: (); // return place in scope 0 at $DIR/derefer_terminator_test.rs:2:11: 2:11
|
||||
let _1: bool; // in scope 0 at $DIR/derefer_terminator_test.rs:3:9: 3:10
|
||||
let _3: (); // in scope 0 at $DIR/derefer_terminator_test.rs:5:5: 8:6
|
||||
let mut _4: &&&&bool; // in scope 0 at $DIR/derefer_terminator_test.rs:5:15: 5:22
|
||||
let _5: &&&bool; // in scope 0 at $DIR/derefer_terminator_test.rs:5:17: 5:21
|
||||
let _6: &&bool; // in scope 0 at $DIR/derefer_terminator_test.rs:5:18: 5:21
|
||||
let _7: &bool; // in scope 0 at $DIR/derefer_terminator_test.rs:5:19: 5:21
|
||||
+ let mut _10: &&&bool; // in scope 0 at $DIR/derefer_terminator_test.rs:5:15: 5:22
|
||||
+ let mut _11: &&bool; // in scope 0 at $DIR/derefer_terminator_test.rs:5:15: 5:22
|
||||
+ let mut _12: &bool; // in scope 0 at $DIR/derefer_terminator_test.rs:5:15: 5:22
|
||||
scope 1 {
|
||||
debug b => _1; // in scope 1 at $DIR/derefer_terminator_test.rs:3:9: 3:10
|
||||
let _2: bool; // in scope 1 at $DIR/derefer_terminator_test.rs:4:9: 4:10
|
||||
scope 2 {
|
||||
debug d => _2; // in scope 2 at $DIR/derefer_terminator_test.rs:4:9: 4:10
|
||||
let _8: i32; // in scope 2 at $DIR/derefer_terminator_test.rs:6:22: 6:23
|
||||
let _9: i32; // in scope 2 at $DIR/derefer_terminator_test.rs:9:9: 9:10
|
||||
scope 3 {
|
||||
debug x => _8; // in scope 3 at $DIR/derefer_terminator_test.rs:6:22: 6:23
|
||||
}
|
||||
scope 4 {
|
||||
debug y => _9; // in scope 4 at $DIR/derefer_terminator_test.rs:9:9: 9:10
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
bb0: {
|
||||
StorageLive(_1); // scope 0 at $DIR/derefer_terminator_test.rs:3:9: 3:10
|
||||
_1 = foo() -> bb1; // scope 0 at $DIR/derefer_terminator_test.rs:3:13: 3:18
|
||||
// mir::Constant
|
||||
// + span: $DIR/derefer_terminator_test.rs:3:13: 3:16
|
||||
// + literal: Const { ty: fn() -> bool {foo}, val: Value(Scalar(<ZST>)) }
|
||||
}
|
||||
|
||||
bb1: {
|
||||
StorageLive(_2); // scope 1 at $DIR/derefer_terminator_test.rs:4:9: 4:10
|
||||
_2 = foo() -> bb2; // scope 1 at $DIR/derefer_terminator_test.rs:4:13: 4:18
|
||||
// mir::Constant
|
||||
// + span: $DIR/derefer_terminator_test.rs:4:13: 4:16
|
||||
// + literal: Const { ty: fn() -> bool {foo}, val: Value(Scalar(<ZST>)) }
|
||||
}
|
||||
|
||||
bb2: {
|
||||
StorageLive(_3); // scope 2 at $DIR/derefer_terminator_test.rs:5:5: 8:6
|
||||
StorageLive(_4); // scope 2 at $DIR/derefer_terminator_test.rs:5:15: 5:22
|
||||
StorageLive(_5); // scope 2 at $DIR/derefer_terminator_test.rs:5:17: 5:21
|
||||
StorageLive(_6); // scope 2 at $DIR/derefer_terminator_test.rs:5:18: 5:21
|
||||
StorageLive(_7); // scope 2 at $DIR/derefer_terminator_test.rs:5:19: 5:21
|
||||
_7 = &_1; // scope 2 at $DIR/derefer_terminator_test.rs:5:19: 5:21
|
||||
_6 = &_7; // scope 2 at $DIR/derefer_terminator_test.rs:5:18: 5:21
|
||||
_5 = &_6; // scope 2 at $DIR/derefer_terminator_test.rs:5:17: 5:21
|
||||
_4 = &_5; // scope 2 at $DIR/derefer_terminator_test.rs:5:15: 5:22
|
||||
- switchInt((*(*(*(*_4))))) -> [false: bb3, otherwise: bb4]; // scope 2 at $DIR/derefer_terminator_test.rs:5:5: 5:22
|
||||
+ StorageLive(_10); // scope 2 at $DIR/derefer_terminator_test.rs:5:5: 5:22
|
||||
+ _10 = move (*_4); // scope 2 at $DIR/derefer_terminator_test.rs:5:5: 5:22
|
||||
+ StorageLive(_11); // scope 2 at $DIR/derefer_terminator_test.rs:5:5: 5:22
|
||||
+ _11 = move (*_10); // scope 2 at $DIR/derefer_terminator_test.rs:5:5: 5:22
|
||||
+ StorageDead(_10); // scope 2 at $DIR/derefer_terminator_test.rs:5:5: 5:22
|
||||
+ StorageLive(_12); // scope 2 at $DIR/derefer_terminator_test.rs:5:5: 5:22
|
||||
+ _12 = move (*_11); // scope 2 at $DIR/derefer_terminator_test.rs:5:5: 5:22
|
||||
+ StorageDead(_11); // scope 2 at $DIR/derefer_terminator_test.rs:5:5: 5:22
|
||||
+ switchInt((*_12)) -> [false: bb3, otherwise: bb4]; // scope 2 at $DIR/derefer_terminator_test.rs:5:5: 5:22
|
||||
}
|
||||
|
||||
bb3: {
|
||||
+ StorageDead(_12); // scope 2 at $DIR/derefer_terminator_test.rs:5:5: 5:22
|
||||
_3 = const (); // scope 2 at $DIR/derefer_terminator_test.rs:7:18: 7:20
|
||||
goto -> bb5; // scope 2 at $DIR/derefer_terminator_test.rs:7:18: 7:20
|
||||
}
|
||||
|
||||
bb4: {
|
||||
+ StorageDead(_12); // scope 2 at $DIR/derefer_terminator_test.rs:5:5: 5:22
|
||||
StorageLive(_8); // scope 2 at $DIR/derefer_terminator_test.rs:6:22: 6:23
|
||||
_8 = const 5_i32; // scope 2 at $DIR/derefer_terminator_test.rs:6:26: 6:27
|
||||
_3 = const (); // scope 2 at $DIR/derefer_terminator_test.rs:6:17: 6:29
|
||||
StorageDead(_8); // scope 2 at $DIR/derefer_terminator_test.rs:6:28: 6:29
|
||||
goto -> bb5; // scope 2 at $DIR/derefer_terminator_test.rs:6:28: 6:29
|
||||
}
|
||||
|
||||
bb5: {
|
||||
StorageDead(_7); // scope 2 at $DIR/derefer_terminator_test.rs:8:5: 8:6
|
||||
StorageDead(_6); // scope 2 at $DIR/derefer_terminator_test.rs:8:5: 8:6
|
||||
StorageDead(_5); // scope 2 at $DIR/derefer_terminator_test.rs:8:5: 8:6
|
||||
StorageDead(_4); // scope 2 at $DIR/derefer_terminator_test.rs:8:5: 8:6
|
||||
StorageDead(_3); // scope 2 at $DIR/derefer_terminator_test.rs:8:5: 8:6
|
||||
StorageLive(_9); // scope 2 at $DIR/derefer_terminator_test.rs:9:9: 9:10
|
||||
_9 = const 42_i32; // scope 2 at $DIR/derefer_terminator_test.rs:9:13: 9:15
|
||||
_0 = const (); // scope 0 at $DIR/derefer_terminator_test.rs:2:11: 10:2
|
||||
StorageDead(_9); // scope 2 at $DIR/derefer_terminator_test.rs:10:1: 10:2
|
||||
StorageDead(_2); // scope 1 at $DIR/derefer_terminator_test.rs:10:1: 10:2
|
||||
StorageDead(_1); // scope 0 at $DIR/derefer_terminator_test.rs:10:1: 10:2
|
||||
return; // scope 0 at $DIR/derefer_terminator_test.rs:10:2: 10:2
|
||||
+ }
|
||||
+
|
||||
+ bb6 (cleanup): {
|
||||
+ resume; // scope 0 at $DIR/derefer_terminator_test.rs:2:1: 10:2
|
||||
}
|
||||
}
|
||||
|
14
src/test/mir-opt/derefer_terminator_test.rs
Normal file
14
src/test/mir-opt/derefer_terminator_test.rs
Normal file
|
@ -0,0 +1,14 @@
|
|||
// EMIT_MIR derefer_terminator_test.main.Derefer.diff
|
||||
fn main() {
|
||||
let b = foo();
|
||||
let d = foo();
|
||||
match ****(&&&&b) {
|
||||
true => {let x = 5;},
|
||||
false => {}
|
||||
}
|
||||
let y = 42;
|
||||
}
|
||||
|
||||
fn foo() -> bool {
|
||||
true
|
||||
}
|
|
@ -5,8 +5,8 @@
|
|||
let mut _0: (); // return place in scope 0 at $DIR/derefer_test.rs:2:11: 2:11
|
||||
let mut _1: (i32, i32); // in scope 0 at $DIR/derefer_test.rs:3:9: 3:14
|
||||
let mut _3: &mut (i32, i32); // in scope 0 at $DIR/derefer_test.rs:4:22: 4:28
|
||||
+ let mut _6: &mut (i32, i32); // in scope 0 at $DIR/derefer_test.rs:5:13: 5:26
|
||||
+ let mut _7: &mut (i32, i32); // in scope 0 at $DIR/derefer_test.rs:6:13: 6:26
|
||||
+ let mut _6: &mut (i32, i32); // in scope 0 at $DIR/derefer_test.rs:4:9: 4:14
|
||||
+ let mut _7: &mut (i32, i32); // in scope 0 at $DIR/derefer_test.rs:4:9: 4:14
|
||||
scope 1 {
|
||||
debug a => _1; // in scope 1 at $DIR/derefer_test.rs:3:9: 3:14
|
||||
let mut _2: (i32, &mut (i32, i32)); // in scope 1 at $DIR/derefer_test.rs:4:9: 4:14
|
||||
|
|
|
@ -7,12 +7,12 @@
|
|||
let mut _3: &mut (i32, i32); // in scope 0 at $DIR/derefer_test_multiple.rs:4:22: 4:28
|
||||
let mut _5: &mut (i32, &mut (i32, i32)); // in scope 0 at $DIR/derefer_test_multiple.rs:5:22: 5:28
|
||||
let mut _7: &mut (i32, &mut (i32, &mut (i32, i32))); // in scope 0 at $DIR/derefer_test_multiple.rs:6:22: 6:28
|
||||
+ let mut _10: &mut (i32, &mut (i32, &mut (i32, i32))); // in scope 0 at $DIR/derefer_test_multiple.rs:7:13: 7:30
|
||||
+ let mut _11: &mut (i32, &mut (i32, i32)); // in scope 0 at $DIR/derefer_test_multiple.rs:7:13: 7:30
|
||||
+ let mut _12: &mut (i32, i32); // in scope 0 at $DIR/derefer_test_multiple.rs:7:13: 7:30
|
||||
+ let mut _13: &mut (i32, &mut (i32, &mut (i32, i32))); // in scope 0 at $DIR/derefer_test_multiple.rs:8:13: 8:30
|
||||
+ let mut _14: &mut (i32, &mut (i32, i32)); // in scope 0 at $DIR/derefer_test_multiple.rs:8:13: 8:30
|
||||
+ let mut _15: &mut (i32, i32); // in scope 0 at $DIR/derefer_test_multiple.rs:8:13: 8:30
|
||||
+ let mut _10: &mut (i32, &mut (i32, &mut (i32, i32))); // in scope 0 at $DIR/derefer_test_multiple.rs:6:9: 6:14
|
||||
+ let mut _11: &mut (i32, &mut (i32, i32)); // in scope 0 at $DIR/derefer_test_multiple.rs:6:9: 6:14
|
||||
+ let mut _12: &mut (i32, i32); // in scope 0 at $DIR/derefer_test_multiple.rs:6:9: 6:14
|
||||
+ let mut _13: &mut (i32, &mut (i32, &mut (i32, i32))); // in scope 0 at $DIR/derefer_test_multiple.rs:6:9: 6:14
|
||||
+ let mut _14: &mut (i32, &mut (i32, i32)); // in scope 0 at $DIR/derefer_test_multiple.rs:6:9: 6:14
|
||||
+ let mut _15: &mut (i32, i32); // in scope 0 at $DIR/derefer_test_multiple.rs:6:9: 6:14
|
||||
scope 1 {
|
||||
debug a => _1; // in scope 1 at $DIR/derefer_test_multiple.rs:3:9: 3:14
|
||||
let mut _2: (i32, &mut (i32, i32)); // in scope 1 at $DIR/derefer_test_multiple.rs:4:9: 4:14
|
||||
|
@ -69,11 +69,11 @@
|
|||
+ _10 = move (_6.1: &mut (i32, &mut (i32, &mut (i32, i32)))); // scope 4 at $DIR/derefer_test_multiple.rs:7:13: 7:30
|
||||
+ StorageLive(_11); // scope 4 at $DIR/derefer_test_multiple.rs:7:13: 7:30
|
||||
+ _11 = move ((*_10).1: &mut (i32, &mut (i32, i32))); // scope 4 at $DIR/derefer_test_multiple.rs:7:13: 7:30
|
||||
+ StorageDead(_10); // scope 4 at $DIR/derefer_test_multiple.rs:7:13: 7:30
|
||||
+ StorageLive(_12); // scope 4 at $DIR/derefer_test_multiple.rs:7:13: 7:30
|
||||
+ _12 = move ((*_11).1: &mut (i32, i32)); // scope 4 at $DIR/derefer_test_multiple.rs:7:13: 7:30
|
||||
+ StorageDead(_11); // scope 4 at $DIR/derefer_test_multiple.rs:7:13: 7:30
|
||||
+ _8 = &mut ((*_12).1: i32); // scope 4 at $DIR/derefer_test_multiple.rs:7:13: 7:30
|
||||
+ StorageDead(_10); // scope 5 at $DIR/derefer_test_multiple.rs:8:9: 8:10
|
||||
+ StorageDead(_11); // scope 5 at $DIR/derefer_test_multiple.rs:8:9: 8:10
|
||||
+ StorageDead(_12); // scope 5 at $DIR/derefer_test_multiple.rs:8:9: 8:10
|
||||
StorageLive(_9); // scope 5 at $DIR/derefer_test_multiple.rs:8:9: 8:10
|
||||
- _9 = &mut ((*((*((*(_6.1: &mut (i32, &mut (i32, &mut (i32, i32))))).1: &mut (i32, &mut (i32, i32)))).1: &mut (i32, i32))).1: i32); // scope 5 at $DIR/derefer_test_multiple.rs:8:13: 8:30
|
||||
|
@ -81,11 +81,11 @@
|
|||
+ _13 = move (_6.1: &mut (i32, &mut (i32, &mut (i32, i32)))); // scope 5 at $DIR/derefer_test_multiple.rs:8:13: 8:30
|
||||
+ StorageLive(_14); // scope 5 at $DIR/derefer_test_multiple.rs:8:13: 8:30
|
||||
+ _14 = move ((*_13).1: &mut (i32, &mut (i32, i32))); // scope 5 at $DIR/derefer_test_multiple.rs:8:13: 8:30
|
||||
+ StorageDead(_13); // scope 5 at $DIR/derefer_test_multiple.rs:8:13: 8:30
|
||||
+ StorageLive(_15); // scope 5 at $DIR/derefer_test_multiple.rs:8:13: 8:30
|
||||
+ _15 = move ((*_14).1: &mut (i32, i32)); // scope 5 at $DIR/derefer_test_multiple.rs:8:13: 8:30
|
||||
+ StorageDead(_14); // scope 5 at $DIR/derefer_test_multiple.rs:8:13: 8:30
|
||||
+ _9 = &mut ((*_15).1: i32); // scope 5 at $DIR/derefer_test_multiple.rs:8:13: 8:30
|
||||
+ StorageDead(_13); // scope 0 at $DIR/derefer_test_multiple.rs:2:12: 9:2
|
||||
+ StorageDead(_14); // scope 0 at $DIR/derefer_test_multiple.rs:2:12: 9:2
|
||||
+ StorageDead(_15); // scope 0 at $DIR/derefer_test_multiple.rs:2:12: 9:2
|
||||
_0 = const (); // scope 0 at $DIR/derefer_test_multiple.rs:2:12: 9:2
|
||||
StorageDead(_9); // scope 5 at $DIR/derefer_test_multiple.rs:9:1: 9:2
|
||||
|
|
|
@ -36,8 +36,19 @@
|
|||
let mut _31: f32; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:25:50: 25:55
|
||||
let mut _32: !; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:26:14: 26:28
|
||||
let mut _33: (); // in scope 0 at $DIR/early_otherwise_branch_68867.rs:26:25: 26:27
|
||||
+ let mut _34: isize; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
+ let mut _35: bool; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
let mut _34: &ViewportPercentageLength; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
let mut _35: &ViewportPercentageLength; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
let mut _36: &ViewportPercentageLength; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
let mut _37: &ViewportPercentageLength; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
let mut _38: &ViewportPercentageLength; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
let mut _39: &ViewportPercentageLength; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
let mut _40: &ViewportPercentageLength; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
let mut _41: &ViewportPercentageLength; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
let mut _42: &ViewportPercentageLength; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
let mut _43: &ViewportPercentageLength; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
let mut _44: &ViewportPercentageLength; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
let mut _45: &ViewportPercentageLength; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
let mut _46: &ViewportPercentageLength; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
scope 1 {
|
||||
- debug one => _12; // in scope 1 at $DIR/early_otherwise_branch_68867.rs:22:14: 22:17
|
||||
- debug other => _13; // in scope 1 at $DIR/early_otherwise_branch_68867.rs:22:24: 22:29
|
||||
|
@ -81,27 +92,26 @@
|
|||
StorageDead(_6); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:23: 21:24
|
||||
- StorageDead(_5); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:23: 21:24
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:23: 21:24
|
||||
_11 = discriminant((*(_4.0: &ViewportPercentageLength))); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
- switchInt(move _11) -> [0_isize: bb1, 1_isize: bb3, 2_isize: bb4, 3_isize: bb5, otherwise: bb11]; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
+ StorageLive(_34); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
+ _34 = discriminant((*(_4.1: &ViewportPercentageLength))); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
+ StorageLive(_35); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
+ _35 = Ne(_11, move _34); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
+ StorageDead(_34); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
+ switchInt(move _35) -> [false: bb7, otherwise: bb1]; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
StorageLive(_34); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
_34 = move (_4.0: &ViewportPercentageLength); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
_11 = discriminant((*_34)); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
StorageDead(_34); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
switchInt(move _11) -> [0_isize: bb1, 1_isize: bb3, 2_isize: bb4, 3_isize: bb5, otherwise: bb2]; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
}
|
||||
|
||||
bb1: {
|
||||
- _7 = discriminant((*(_4.1: &ViewportPercentageLength))); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
- switchInt(move _7) -> [0_isize: bb6, otherwise: bb2]; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
- }
|
||||
-
|
||||
- bb2: {
|
||||
+ StorageDead(_35); // scope 0 at $DIR/early_otherwise_branch_68867.rs:26:25: 26:27
|
||||
StorageLive(_35); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
_35 = move (_4.1: &ViewportPercentageLength); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
_7 = discriminant((*_35)); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
StorageDead(_35); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
switchInt(move _7) -> [0_isize: bb6, otherwise: bb2]; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
}
|
||||
|
||||
bb2: {
|
||||
StorageLive(_33); // scope 0 at $DIR/early_otherwise_branch_68867.rs:26:25: 26:27
|
||||
- nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:26:25: 26:27
|
||||
nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:26:25: 26:27
|
||||
Deinit(_0); // scope 0 at $DIR/early_otherwise_branch_68867.rs:26:21: 26:28
|
||||
- nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:26:21: 26:28
|
||||
nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:26:21: 26:28
|
||||
discriminant(_0) = 1; // scope 0 at $DIR/early_otherwise_branch_68867.rs:26:21: 26:28
|
||||
StorageDead(_33); // scope 0 at $DIR/early_otherwise_branch_68867.rs:26:27: 26:28
|
||||
- StorageDead(_3); // scope 0 at $DIR/early_otherwise_branch_68867.rs:27:6: 27:7
|
||||
|
@ -111,105 +121,45 @@
|
|||
return; // scope 0 at $DIR/early_otherwise_branch_68867.rs:28:2: 28:2
|
||||
}
|
||||
|
||||
+ bb2: {
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:14: 22:17
|
||||
+ _15 = (((*(_4.0: &ViewportPercentageLength)) as Vw).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:14: 22:17
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:24: 22:29
|
||||
+ _16 = (((*(_4.1: &ViewportPercentageLength)) as Vw).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:24: 22:29
|
||||
+ nop; // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:38: 22:49
|
||||
+ nop; // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:38: 22:41
|
||||
+ nop; // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:38: 22:41
|
||||
+ nop; // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:44: 22:49
|
||||
+ nop; // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:44: 22:49
|
||||
+ ((((_0 as Ok).0: ViewportPercentageLength) as Vw).0: f32) = Add(move _15, move _16); // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:38: 22:49
|
||||
+ nop; // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:48: 22:49
|
||||
+ nop; // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:48: 22:49
|
||||
+ Deinit(((_0 as Ok).0: ViewportPercentageLength)); // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:35: 22:50
|
||||
+ nop; // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:35: 22:50
|
||||
+ discriminant(((_0 as Ok).0: ViewportPercentageLength)) = 0; // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:35: 22:50
|
||||
+ nop; // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:49: 22:50
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:49: 22:50
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:49: 22:50
|
||||
+ goto -> bb6; // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:49: 22:50
|
||||
+ }
|
||||
+
|
||||
bb3: {
|
||||
- _8 = discriminant((*(_4.1: &ViewportPercentageLength))); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
- switchInt(move _8) -> [1_isize: bb7, otherwise: bb2]; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:14: 23:17
|
||||
+ _20 = (((*(_4.0: &ViewportPercentageLength)) as Vh).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:14: 23:17
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:24: 23:29
|
||||
+ _21 = (((*(_4.1: &ViewportPercentageLength)) as Vh).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:24: 23:29
|
||||
+ nop; // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:38: 23:49
|
||||
+ nop; // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:38: 23:41
|
||||
+ nop; // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:38: 23:41
|
||||
+ nop; // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:44: 23:49
|
||||
+ nop; // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:44: 23:49
|
||||
+ ((((_0 as Ok).0: ViewportPercentageLength) as Vh).0: f32) = Add(move _20, move _21); // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:38: 23:49
|
||||
+ nop; // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:48: 23:49
|
||||
+ nop; // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:48: 23:49
|
||||
+ Deinit(((_0 as Ok).0: ViewportPercentageLength)); // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:35: 23:50
|
||||
+ nop; // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:35: 23:50
|
||||
+ discriminant(((_0 as Ok).0: ViewportPercentageLength)) = 1; // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:35: 23:50
|
||||
+ nop; // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:49: 23:50
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:49: 23:50
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:49: 23:50
|
||||
+ goto -> bb6; // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:49: 23:50
|
||||
StorageLive(_36); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
_36 = move (_4.1: &ViewportPercentageLength); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
_8 = discriminant((*_36)); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
StorageDead(_36); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
switchInt(move _8) -> [1_isize: bb7, otherwise: bb2]; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
}
|
||||
|
||||
bb4: {
|
||||
- _9 = discriminant((*(_4.1: &ViewportPercentageLength))); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
- switchInt(move _9) -> [2_isize: bb8, otherwise: bb2]; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:16: 24:19
|
||||
+ _25 = (((*(_4.0: &ViewportPercentageLength)) as Vmin).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:16: 24:19
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:28: 24:33
|
||||
+ _26 = (((*(_4.1: &ViewportPercentageLength)) as Vmin).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:28: 24:33
|
||||
+ nop; // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:44: 24:55
|
||||
+ nop; // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:44: 24:47
|
||||
+ nop; // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:44: 24:47
|
||||
+ nop; // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:50: 24:55
|
||||
+ nop; // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:50: 24:55
|
||||
+ ((((_0 as Ok).0: ViewportPercentageLength) as Vmin).0: f32) = Add(move _25, move _26); // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:44: 24:55
|
||||
+ nop; // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:54: 24:55
|
||||
+ nop; // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:54: 24:55
|
||||
+ Deinit(((_0 as Ok).0: ViewportPercentageLength)); // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:39: 24:56
|
||||
+ nop; // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:39: 24:56
|
||||
+ discriminant(((_0 as Ok).0: ViewportPercentageLength)) = 2; // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:39: 24:56
|
||||
+ nop; // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:55: 24:56
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:55: 24:56
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:55: 24:56
|
||||
+ goto -> bb6; // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:55: 24:56
|
||||
StorageLive(_37); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
_37 = move (_4.1: &ViewportPercentageLength); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
_9 = discriminant((*_37)); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
StorageDead(_37); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
switchInt(move _9) -> [2_isize: bb8, otherwise: bb2]; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
}
|
||||
|
||||
bb5: {
|
||||
- _10 = discriminant((*(_4.1: &ViewportPercentageLength))); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
- switchInt(move _10) -> [3_isize: bb9, otherwise: bb2]; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:16: 25:19
|
||||
+ _30 = (((*(_4.0: &ViewportPercentageLength)) as Vmax).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:16: 25:19
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:28: 25:33
|
||||
+ _31 = (((*(_4.1: &ViewportPercentageLength)) as Vmax).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:28: 25:33
|
||||
+ nop; // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:44: 25:55
|
||||
+ nop; // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:44: 25:47
|
||||
+ nop; // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:44: 25:47
|
||||
+ nop; // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:50: 25:55
|
||||
+ nop; // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:50: 25:55
|
||||
+ ((((_0 as Ok).0: ViewportPercentageLength) as Vmax).0: f32) = Add(move _30, move _31); // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:44: 25:55
|
||||
+ nop; // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:54: 25:55
|
||||
+ nop; // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:54: 25:55
|
||||
+ Deinit(((_0 as Ok).0: ViewportPercentageLength)); // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:39: 25:56
|
||||
+ nop; // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:39: 25:56
|
||||
+ discriminant(((_0 as Ok).0: ViewportPercentageLength)) = 3; // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:39: 25:56
|
||||
+ nop; // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:55: 25:56
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:55: 25:56
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:55: 25:56
|
||||
+ goto -> bb6; // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:55: 25:56
|
||||
StorageLive(_38); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
_38 = move (_4.1: &ViewportPercentageLength); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
_10 = discriminant((*_38)); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
StorageDead(_38); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
switchInt(move _10) -> [3_isize: bb9, otherwise: bb2]; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
}
|
||||
|
||||
bb6: {
|
||||
- StorageLive(_12); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:14: 22:17
|
||||
- _12 = (((*(_4.0: &ViewportPercentageLength)) as Vw).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:14: 22:17
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:14: 22:17
|
||||
StorageLive(_39); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:14: 22:17
|
||||
_39 = move (_4.0: &ViewportPercentageLength); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:14: 22:17
|
||||
- _12 = (((*_39) as Vw).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:14: 22:17
|
||||
+ _15 = (((*_39) as Vw).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:14: 22:17
|
||||
StorageDead(_39); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:24: 22:29
|
||||
- StorageLive(_13); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:24: 22:29
|
||||
- _13 = (((*(_4.1: &ViewportPercentageLength)) as Vw).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:24: 22:29
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:24: 22:29
|
||||
StorageLive(_40); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:24: 22:29
|
||||
_40 = move (_4.1: &ViewportPercentageLength); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:24: 22:29
|
||||
- _13 = (((*_40) as Vw).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:24: 22:29
|
||||
+ _16 = (((*_40) as Vw).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:24: 22:29
|
||||
StorageDead(_40); // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:38: 22:49
|
||||
- StorageLive(_14); // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:38: 22:49
|
||||
- StorageLive(_15); // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:38: 22:41
|
||||
- _15 = _12; // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:38: 22:41
|
||||
|
@ -224,14 +174,38 @@
|
|||
- StorageDead(_14); // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:49: 22:50
|
||||
- StorageDead(_13); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:49: 22:50
|
||||
- StorageDead(_12); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:49: 22:50
|
||||
- goto -> bb10; // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:49: 22:50
|
||||
- }
|
||||
-
|
||||
- bb7: {
|
||||
+ nop; // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:38: 22:49
|
||||
+ nop; // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:38: 22:41
|
||||
+ nop; // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:38: 22:41
|
||||
+ nop; // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:44: 22:49
|
||||
+ nop; // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:44: 22:49
|
||||
+ ((((_0 as Ok).0: ViewportPercentageLength) as Vw).0: f32) = Add(move _15, move _16); // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:38: 22:49
|
||||
+ nop; // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:48: 22:49
|
||||
+ nop; // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:48: 22:49
|
||||
+ Deinit(((_0 as Ok).0: ViewportPercentageLength)); // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:35: 22:50
|
||||
+ nop; // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:35: 22:50
|
||||
+ discriminant(((_0 as Ok).0: ViewportPercentageLength)) = 0; // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:35: 22:50
|
||||
+ nop; // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:49: 22:50
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:49: 22:50
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:49: 22:50
|
||||
goto -> bb10; // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:49: 22:50
|
||||
}
|
||||
|
||||
bb7: {
|
||||
- StorageLive(_17); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:14: 23:17
|
||||
- _17 = (((*(_4.0: &ViewportPercentageLength)) as Vh).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:14: 23:17
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:14: 23:17
|
||||
StorageLive(_41); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:14: 23:17
|
||||
_41 = move (_4.0: &ViewportPercentageLength); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:14: 23:17
|
||||
- _17 = (((*_41) as Vh).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:14: 23:17
|
||||
+ _20 = (((*_41) as Vh).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:14: 23:17
|
||||
StorageDead(_41); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:24: 23:29
|
||||
- StorageLive(_18); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:24: 23:29
|
||||
- _18 = (((*(_4.1: &ViewportPercentageLength)) as Vh).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:24: 23:29
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:24: 23:29
|
||||
StorageLive(_42); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:24: 23:29
|
||||
_42 = move (_4.1: &ViewportPercentageLength); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:24: 23:29
|
||||
- _18 = (((*_42) as Vh).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:24: 23:29
|
||||
+ _21 = (((*_42) as Vh).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:24: 23:29
|
||||
StorageDead(_42); // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:38: 23:49
|
||||
- StorageLive(_19); // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:38: 23:49
|
||||
- StorageLive(_20); // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:38: 23:41
|
||||
- _20 = _17; // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:38: 23:41
|
||||
|
@ -246,14 +220,38 @@
|
|||
- StorageDead(_19); // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:49: 23:50
|
||||
- StorageDead(_18); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:49: 23:50
|
||||
- StorageDead(_17); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:49: 23:50
|
||||
- goto -> bb10; // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:49: 23:50
|
||||
- }
|
||||
-
|
||||
- bb8: {
|
||||
+ nop; // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:38: 23:49
|
||||
+ nop; // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:38: 23:41
|
||||
+ nop; // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:38: 23:41
|
||||
+ nop; // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:44: 23:49
|
||||
+ nop; // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:44: 23:49
|
||||
+ ((((_0 as Ok).0: ViewportPercentageLength) as Vh).0: f32) = Add(move _20, move _21); // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:38: 23:49
|
||||
+ nop; // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:48: 23:49
|
||||
+ nop; // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:48: 23:49
|
||||
+ Deinit(((_0 as Ok).0: ViewportPercentageLength)); // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:35: 23:50
|
||||
+ nop; // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:35: 23:50
|
||||
+ discriminant(((_0 as Ok).0: ViewportPercentageLength)) = 1; // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:35: 23:50
|
||||
+ nop; // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:49: 23:50
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:49: 23:50
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:49: 23:50
|
||||
goto -> bb10; // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:49: 23:50
|
||||
}
|
||||
|
||||
bb8: {
|
||||
- StorageLive(_22); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:16: 24:19
|
||||
- _22 = (((*(_4.0: &ViewportPercentageLength)) as Vmin).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:16: 24:19
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:16: 24:19
|
||||
StorageLive(_43); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:16: 24:19
|
||||
_43 = move (_4.0: &ViewportPercentageLength); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:16: 24:19
|
||||
- _22 = (((*_43) as Vmin).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:16: 24:19
|
||||
+ _25 = (((*_43) as Vmin).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:16: 24:19
|
||||
StorageDead(_43); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:28: 24:33
|
||||
- StorageLive(_23); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:28: 24:33
|
||||
- _23 = (((*(_4.1: &ViewportPercentageLength)) as Vmin).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:28: 24:33
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:28: 24:33
|
||||
StorageLive(_44); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:28: 24:33
|
||||
_44 = move (_4.1: &ViewportPercentageLength); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:28: 24:33
|
||||
- _23 = (((*_44) as Vmin).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:28: 24:33
|
||||
+ _26 = (((*_44) as Vmin).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:28: 24:33
|
||||
StorageDead(_44); // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:44: 24:55
|
||||
- StorageLive(_24); // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:44: 24:55
|
||||
- StorageLive(_25); // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:44: 24:47
|
||||
- _25 = _22; // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:44: 24:47
|
||||
|
@ -268,14 +266,38 @@
|
|||
- StorageDead(_24); // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:55: 24:56
|
||||
- StorageDead(_23); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:55: 24:56
|
||||
- StorageDead(_22); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:55: 24:56
|
||||
- goto -> bb10; // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:55: 24:56
|
||||
- }
|
||||
-
|
||||
- bb9: {
|
||||
+ nop; // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:44: 24:55
|
||||
+ nop; // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:44: 24:47
|
||||
+ nop; // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:44: 24:47
|
||||
+ nop; // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:50: 24:55
|
||||
+ nop; // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:50: 24:55
|
||||
+ ((((_0 as Ok).0: ViewportPercentageLength) as Vmin).0: f32) = Add(move _25, move _26); // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:44: 24:55
|
||||
+ nop; // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:54: 24:55
|
||||
+ nop; // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:54: 24:55
|
||||
+ Deinit(((_0 as Ok).0: ViewportPercentageLength)); // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:39: 24:56
|
||||
+ nop; // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:39: 24:56
|
||||
+ discriminant(((_0 as Ok).0: ViewportPercentageLength)) = 2; // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:39: 24:56
|
||||
+ nop; // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:55: 24:56
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:55: 24:56
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:55: 24:56
|
||||
goto -> bb10; // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:55: 24:56
|
||||
}
|
||||
|
||||
bb9: {
|
||||
- StorageLive(_27); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:16: 25:19
|
||||
- _27 = (((*(_4.0: &ViewportPercentageLength)) as Vmax).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:16: 25:19
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:16: 25:19
|
||||
StorageLive(_45); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:16: 25:19
|
||||
_45 = move (_4.0: &ViewportPercentageLength); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:16: 25:19
|
||||
- _27 = (((*_45) as Vmax).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:16: 25:19
|
||||
+ _30 = (((*_45) as Vmax).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:16: 25:19
|
||||
StorageDead(_45); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:28: 25:33
|
||||
- StorageLive(_28); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:28: 25:33
|
||||
- _28 = (((*(_4.1: &ViewportPercentageLength)) as Vmax).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:28: 25:33
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:28: 25:33
|
||||
StorageLive(_46); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:28: 25:33
|
||||
_46 = move (_4.1: &ViewportPercentageLength); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:28: 25:33
|
||||
- _28 = (((*_46) as Vmax).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:28: 25:33
|
||||
+ _31 = (((*_46) as Vmax).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:28: 25:33
|
||||
StorageDead(_46); // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:44: 25:55
|
||||
- StorageLive(_29); // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:44: 25:55
|
||||
- StorageLive(_30); // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:44: 25:47
|
||||
- _30 = _27; // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:44: 25:47
|
||||
|
@ -290,10 +312,24 @@
|
|||
- StorageDead(_29); // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:55: 25:56
|
||||
- StorageDead(_28); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:55: 25:56
|
||||
- StorageDead(_27); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:55: 25:56
|
||||
- goto -> bb10; // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:55: 25:56
|
||||
- }
|
||||
-
|
||||
- bb10: {
|
||||
+ nop; // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:44: 25:55
|
||||
+ nop; // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:44: 25:47
|
||||
+ nop; // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:44: 25:47
|
||||
+ nop; // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:50: 25:55
|
||||
+ nop; // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:50: 25:55
|
||||
+ ((((_0 as Ok).0: ViewportPercentageLength) as Vmax).0: f32) = Add(move _30, move _31); // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:44: 25:55
|
||||
+ nop; // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:54: 25:55
|
||||
+ nop; // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:54: 25:55
|
||||
+ Deinit(((_0 as Ok).0: ViewportPercentageLength)); // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:39: 25:56
|
||||
+ nop; // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:39: 25:56
|
||||
+ discriminant(((_0 as Ok).0: ViewportPercentageLength)) = 3; // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:39: 25:56
|
||||
+ nop; // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:55: 25:56
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:55: 25:56
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:55: 25:56
|
||||
goto -> bb10; // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:55: 25:56
|
||||
}
|
||||
|
||||
bb10: {
|
||||
Deinit(_0); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:5: 27:7
|
||||
- ((_0 as Ok).0: ViewportPercentageLength) = move _3; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:5: 27:7
|
||||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:5: 27:7
|
||||
|
@ -304,12 +340,5 @@
|
|||
+ nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:28:1: 28:2
|
||||
return; // scope 0 at $DIR/early_otherwise_branch_68867.rs:28:2: 28:2
|
||||
}
|
||||
|
||||
- bb11: {
|
||||
- unreachable; // scope 0 at $DIR/early_otherwise_branch_68867.rs:28:2: 28:2
|
||||
+ bb7: {
|
||||
+ StorageDead(_35); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
+ switchInt(_11) -> [0_isize: bb2, 1_isize: bb3, 2_isize: bb4, 3_isize: bb5, otherwise: bb1]; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -36,8 +36,19 @@
|
|||
let mut _31: f32; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:25:50: 25:55
|
||||
let mut _32: !; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:26:14: 26:28
|
||||
let mut _33: (); // in scope 0 at $DIR/early_otherwise_branch_68867.rs:26:25: 26:27
|
||||
+ let mut _34: isize; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
+ let mut _35: bool; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
let mut _34: &ViewportPercentageLength; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
let mut _35: &ViewportPercentageLength; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
let mut _36: &ViewportPercentageLength; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
let mut _37: &ViewportPercentageLength; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
let mut _38: &ViewportPercentageLength; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
let mut _39: &ViewportPercentageLength; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
let mut _40: &ViewportPercentageLength; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
let mut _41: &ViewportPercentageLength; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
let mut _42: &ViewportPercentageLength; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
let mut _43: &ViewportPercentageLength; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
let mut _44: &ViewportPercentageLength; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
let mut _45: &ViewportPercentageLength; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
let mut _46: &ViewportPercentageLength; // in scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
scope 1 {
|
||||
debug one => _12; // in scope 1 at $DIR/early_otherwise_branch_68867.rs:22:14: 22:17
|
||||
debug other => _13; // in scope 1 at $DIR/early_otherwise_branch_68867.rs:22:24: 22:29
|
||||
|
@ -67,27 +78,26 @@
|
|||
(_4.1: &ViewportPercentageLength) = move _6; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
StorageDead(_6); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:23: 21:24
|
||||
StorageDead(_5); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:23: 21:24
|
||||
_11 = discriminant((*(_4.0: &ViewportPercentageLength))); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
- switchInt(move _11) -> [0_isize: bb1, 1_isize: bb3, 2_isize: bb4, 3_isize: bb5, otherwise: bb11]; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
+ StorageLive(_34); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
+ _34 = discriminant((*(_4.1: &ViewportPercentageLength))); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
+ StorageLive(_35); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
+ _35 = Ne(_11, move _34); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
+ StorageDead(_34); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
+ switchInt(move _35) -> [false: bb7, otherwise: bb1]; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
StorageLive(_34); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
_34 = move (_4.0: &ViewportPercentageLength); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
_11 = discriminant((*_34)); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
StorageDead(_34); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
switchInt(move _11) -> [0_isize: bb1, 1_isize: bb3, 2_isize: bb4, 3_isize: bb5, otherwise: bb2]; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
}
|
||||
|
||||
bb1: {
|
||||
- _7 = discriminant((*(_4.1: &ViewportPercentageLength))); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
- switchInt(move _7) -> [0_isize: bb6, otherwise: bb2]; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
- }
|
||||
-
|
||||
- bb2: {
|
||||
+ StorageDead(_35); // scope 0 at $DIR/early_otherwise_branch_68867.rs:26:25: 26:27
|
||||
StorageLive(_35); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
_35 = move (_4.1: &ViewportPercentageLength); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
_7 = discriminant((*_35)); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
StorageDead(_35); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
switchInt(move _7) -> [0_isize: bb6, otherwise: bb2]; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
}
|
||||
|
||||
bb2: {
|
||||
StorageLive(_33); // scope 0 at $DIR/early_otherwise_branch_68867.rs:26:25: 26:27
|
||||
- nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:26:25: 26:27
|
||||
nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:26:25: 26:27
|
||||
Deinit(_0); // scope 0 at $DIR/early_otherwise_branch_68867.rs:26:21: 26:28
|
||||
- nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:26:21: 26:28
|
||||
nop; // scope 0 at $DIR/early_otherwise_branch_68867.rs:26:21: 26:28
|
||||
discriminant(_0) = 1; // scope 0 at $DIR/early_otherwise_branch_68867.rs:26:21: 26:28
|
||||
StorageDead(_33); // scope 0 at $DIR/early_otherwise_branch_68867.rs:26:27: 26:28
|
||||
StorageDead(_3); // scope 0 at $DIR/early_otherwise_branch_68867.rs:27:6: 27:7
|
||||
|
@ -95,27 +105,41 @@
|
|||
return; // scope 0 at $DIR/early_otherwise_branch_68867.rs:28:2: 28:2
|
||||
}
|
||||
|
||||
- bb3: {
|
||||
- _8 = discriminant((*(_4.1: &ViewportPercentageLength))); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
- switchInt(move _8) -> [1_isize: bb7, otherwise: bb2]; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
- }
|
||||
-
|
||||
- bb4: {
|
||||
- _9 = discriminant((*(_4.1: &ViewportPercentageLength))); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
- switchInt(move _9) -> [2_isize: bb8, otherwise: bb2]; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
- }
|
||||
-
|
||||
- bb5: {
|
||||
- _10 = discriminant((*(_4.1: &ViewportPercentageLength))); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
- switchInt(move _10) -> [3_isize: bb9, otherwise: bb2]; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
- }
|
||||
-
|
||||
- bb6: {
|
||||
+ bb2: {
|
||||
bb3: {
|
||||
StorageLive(_36); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
_36 = move (_4.1: &ViewportPercentageLength); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
_8 = discriminant((*_36)); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
StorageDead(_36); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
switchInt(move _8) -> [1_isize: bb7, otherwise: bb2]; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
}
|
||||
|
||||
bb4: {
|
||||
StorageLive(_37); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
_37 = move (_4.1: &ViewportPercentageLength); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
_9 = discriminant((*_37)); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
StorageDead(_37); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
switchInt(move _9) -> [2_isize: bb8, otherwise: bb2]; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
}
|
||||
|
||||
bb5: {
|
||||
StorageLive(_38); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
_38 = move (_4.1: &ViewportPercentageLength); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
_10 = discriminant((*_38)); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:14: 21:24
|
||||
StorageDead(_38); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
switchInt(move _10) -> [3_isize: bb9, otherwise: bb2]; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
}
|
||||
|
||||
bb6: {
|
||||
StorageLive(_12); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:14: 22:17
|
||||
_12 = (((*(_4.0: &ViewportPercentageLength)) as Vw).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:14: 22:17
|
||||
StorageLive(_39); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:14: 22:17
|
||||
_39 = move (_4.0: &ViewportPercentageLength); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:14: 22:17
|
||||
_12 = (((*_39) as Vw).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:14: 22:17
|
||||
StorageDead(_39); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:24: 22:29
|
||||
StorageLive(_13); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:24: 22:29
|
||||
_13 = (((*(_4.1: &ViewportPercentageLength)) as Vw).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:24: 22:29
|
||||
StorageLive(_40); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:24: 22:29
|
||||
_40 = move (_4.1: &ViewportPercentageLength); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:24: 22:29
|
||||
_13 = (((*_40) as Vw).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:24: 22:29
|
||||
StorageDead(_40); // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:38: 22:49
|
||||
StorageLive(_14); // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:38: 22:49
|
||||
StorageLive(_15); // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:38: 22:41
|
||||
_15 = _12; // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:38: 22:41
|
||||
|
@ -130,16 +154,20 @@
|
|||
StorageDead(_14); // scope 1 at $DIR/early_otherwise_branch_68867.rs:22:49: 22:50
|
||||
StorageDead(_13); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:49: 22:50
|
||||
StorageDead(_12); // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:49: 22:50
|
||||
- goto -> bb10; // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:49: 22:50
|
||||
+ goto -> bb6; // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:49: 22:50
|
||||
goto -> bb10; // scope 0 at $DIR/early_otherwise_branch_68867.rs:22:49: 22:50
|
||||
}
|
||||
|
||||
- bb7: {
|
||||
+ bb3: {
|
||||
bb7: {
|
||||
StorageLive(_17); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:14: 23:17
|
||||
_17 = (((*(_4.0: &ViewportPercentageLength)) as Vh).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:14: 23:17
|
||||
StorageLive(_41); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:14: 23:17
|
||||
_41 = move (_4.0: &ViewportPercentageLength); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:14: 23:17
|
||||
_17 = (((*_41) as Vh).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:14: 23:17
|
||||
StorageDead(_41); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:24: 23:29
|
||||
StorageLive(_18); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:24: 23:29
|
||||
_18 = (((*(_4.1: &ViewportPercentageLength)) as Vh).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:24: 23:29
|
||||
StorageLive(_42); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:24: 23:29
|
||||
_42 = move (_4.1: &ViewportPercentageLength); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:24: 23:29
|
||||
_18 = (((*_42) as Vh).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:24: 23:29
|
||||
StorageDead(_42); // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:38: 23:49
|
||||
StorageLive(_19); // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:38: 23:49
|
||||
StorageLive(_20); // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:38: 23:41
|
||||
_20 = _17; // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:38: 23:41
|
||||
|
@ -154,16 +182,20 @@
|
|||
StorageDead(_19); // scope 2 at $DIR/early_otherwise_branch_68867.rs:23:49: 23:50
|
||||
StorageDead(_18); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:49: 23:50
|
||||
StorageDead(_17); // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:49: 23:50
|
||||
- goto -> bb10; // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:49: 23:50
|
||||
+ goto -> bb6; // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:49: 23:50
|
||||
goto -> bb10; // scope 0 at $DIR/early_otherwise_branch_68867.rs:23:49: 23:50
|
||||
}
|
||||
|
||||
- bb8: {
|
||||
+ bb4: {
|
||||
bb8: {
|
||||
StorageLive(_22); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:16: 24:19
|
||||
_22 = (((*(_4.0: &ViewportPercentageLength)) as Vmin).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:16: 24:19
|
||||
StorageLive(_43); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:16: 24:19
|
||||
_43 = move (_4.0: &ViewportPercentageLength); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:16: 24:19
|
||||
_22 = (((*_43) as Vmin).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:16: 24:19
|
||||
StorageDead(_43); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:28: 24:33
|
||||
StorageLive(_23); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:28: 24:33
|
||||
_23 = (((*(_4.1: &ViewportPercentageLength)) as Vmin).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:28: 24:33
|
||||
StorageLive(_44); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:28: 24:33
|
||||
_44 = move (_4.1: &ViewportPercentageLength); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:28: 24:33
|
||||
_23 = (((*_44) as Vmin).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:28: 24:33
|
||||
StorageDead(_44); // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:44: 24:55
|
||||
StorageLive(_24); // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:44: 24:55
|
||||
StorageLive(_25); // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:44: 24:47
|
||||
_25 = _22; // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:44: 24:47
|
||||
|
@ -178,16 +210,20 @@
|
|||
StorageDead(_24); // scope 3 at $DIR/early_otherwise_branch_68867.rs:24:55: 24:56
|
||||
StorageDead(_23); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:55: 24:56
|
||||
StorageDead(_22); // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:55: 24:56
|
||||
- goto -> bb10; // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:55: 24:56
|
||||
+ goto -> bb6; // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:55: 24:56
|
||||
goto -> bb10; // scope 0 at $DIR/early_otherwise_branch_68867.rs:24:55: 24:56
|
||||
}
|
||||
|
||||
- bb9: {
|
||||
+ bb5: {
|
||||
bb9: {
|
||||
StorageLive(_27); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:16: 25:19
|
||||
_27 = (((*(_4.0: &ViewportPercentageLength)) as Vmax).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:16: 25:19
|
||||
StorageLive(_45); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:16: 25:19
|
||||
_45 = move (_4.0: &ViewportPercentageLength); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:16: 25:19
|
||||
_27 = (((*_45) as Vmax).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:16: 25:19
|
||||
StorageDead(_45); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:28: 25:33
|
||||
StorageLive(_28); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:28: 25:33
|
||||
_28 = (((*(_4.1: &ViewportPercentageLength)) as Vmax).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:28: 25:33
|
||||
StorageLive(_46); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:28: 25:33
|
||||
_46 = move (_4.1: &ViewportPercentageLength); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:28: 25:33
|
||||
_28 = (((*_46) as Vmax).0: f32); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:28: 25:33
|
||||
StorageDead(_46); // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:44: 25:55
|
||||
StorageLive(_29); // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:44: 25:55
|
||||
StorageLive(_30); // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:44: 25:47
|
||||
_30 = _27; // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:44: 25:47
|
||||
|
@ -202,12 +238,10 @@
|
|||
StorageDead(_29); // scope 4 at $DIR/early_otherwise_branch_68867.rs:25:55: 25:56
|
||||
StorageDead(_28); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:55: 25:56
|
||||
StorageDead(_27); // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:55: 25:56
|
||||
- goto -> bb10; // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:55: 25:56
|
||||
+ goto -> bb6; // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:55: 25:56
|
||||
goto -> bb10; // scope 0 at $DIR/early_otherwise_branch_68867.rs:25:55: 25:56
|
||||
}
|
||||
|
||||
- bb10: {
|
||||
+ bb6: {
|
||||
bb10: {
|
||||
Deinit(_0); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:5: 27:7
|
||||
((_0 as Ok).0: ViewportPercentageLength) = move _3; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:5: 27:7
|
||||
discriminant(_0) = 0; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:5: 27:7
|
||||
|
@ -215,12 +249,5 @@
|
|||
StorageDead(_4); // scope 0 at $DIR/early_otherwise_branch_68867.rs:28:1: 28:2
|
||||
return; // scope 0 at $DIR/early_otherwise_branch_68867.rs:28:2: 28:2
|
||||
}
|
||||
|
||||
- bb11: {
|
||||
- unreachable; // scope 0 at $DIR/early_otherwise_branch_68867.rs:28:2: 28:2
|
||||
+ bb7: {
|
||||
+ StorageDead(_35); // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
+ switchInt(_11) -> [0_isize: bb2, 1_isize: bb3, 2_isize: bb4, 3_isize: bb5, otherwise: bb1]; // scope 0 at $DIR/early_otherwise_branch_68867.rs:21:8: 21:24
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -6,6 +6,7 @@
|
|||
let mut _0: u32; // return place in scope 0 at $DIR/early_otherwise_branch_soundness.rs:12:26: 12:29
|
||||
let mut _2: isize; // in scope 0 at $DIR/early_otherwise_branch_soundness.rs:13:20: 13:30
|
||||
let mut _3: isize; // in scope 0 at $DIR/early_otherwise_branch_soundness.rs:13:12: 13:31
|
||||
let mut _4: &E; // in scope 0 at $DIR/early_otherwise_branch_soundness.rs:12:16: 12:17
|
||||
|
||||
bb0: {
|
||||
_3 = discriminant((*_1)); // scope 0 at $DIR/early_otherwise_branch_soundness.rs:13:12: 13:31
|
||||
|
@ -13,7 +14,10 @@
|
|||
}
|
||||
|
||||
bb1: {
|
||||
_2 = discriminant((*(((*_1) as Some).0: &E))); // scope 0 at $DIR/early_otherwise_branch_soundness.rs:13:12: 13:31
|
||||
StorageLive(_4); // scope 0 at $DIR/early_otherwise_branch_soundness.rs:13:12: 13:31
|
||||
_4 = move (((*_1) as Some).0: &E); // scope 0 at $DIR/early_otherwise_branch_soundness.rs:13:12: 13:31
|
||||
_2 = discriminant((*_4)); // scope 0 at $DIR/early_otherwise_branch_soundness.rs:13:12: 13:31
|
||||
StorageDead(_4); // scope 0 at $DIR/early_otherwise_branch_soundness.rs:13:12: 13:31
|
||||
switchInt(move _2) -> [1_isize: bb2, otherwise: bb3]; // scope 0 at $DIR/early_otherwise_branch_soundness.rs:13:12: 13:31
|
||||
}
|
||||
|
||||
|
|
|
@ -19,6 +19,8 @@ fn foo(_1: T, _2: i32) -> (i32, T) {
|
|||
debug t => (*((*_6).1: &T)); // in scope 2 at $DIR/inline-closure-captures.rs:10:17: 10:18
|
||||
let mut _10: i32; // in scope 2 at $DIR/inline-closure-captures.rs:11:19: 11:20
|
||||
let mut _11: T; // in scope 2 at $DIR/inline-closure-captures.rs:11:22: 11:23
|
||||
let mut _12: &i32; // in scope 2 at $DIR/inline-closure-captures.rs:11:13: 11:24
|
||||
let mut _13: &T; // in scope 2 at $DIR/inline-closure-captures.rs:11:13: 11:24
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -43,9 +45,15 @@ fn foo(_1: T, _2: i32) -> (i32, T) {
|
|||
StorageLive(_9); // scope 1 at $DIR/inline-closure-captures.rs:12:5: 12:9
|
||||
_9 = move (_7.0: i32); // scope 1 at $DIR/inline-closure-captures.rs:12:5: 12:9
|
||||
StorageLive(_10); // scope 2 at $DIR/inline-closure-captures.rs:11:19: 11:20
|
||||
_10 = (*((*_6).0: &i32)); // scope 2 at $DIR/inline-closure-captures.rs:11:19: 11:20
|
||||
StorageLive(_12); // scope 2 at $DIR/inline-closure-captures.rs:11:19: 11:20
|
||||
_12 = move ((*_6).0: &i32); // scope 2 at $DIR/inline-closure-captures.rs:11:19: 11:20
|
||||
_10 = (*_12); // scope 2 at $DIR/inline-closure-captures.rs:11:19: 11:20
|
||||
StorageDead(_12); // scope 2 at $DIR/inline-closure-captures.rs:11:22: 11:23
|
||||
StorageLive(_11); // scope 2 at $DIR/inline-closure-captures.rs:11:22: 11:23
|
||||
_11 = (*((*_6).1: &T)); // scope 2 at $DIR/inline-closure-captures.rs:11:22: 11:23
|
||||
StorageLive(_13); // scope 2 at $DIR/inline-closure-captures.rs:11:22: 11:23
|
||||
_13 = move ((*_6).1: &T); // scope 2 at $DIR/inline-closure-captures.rs:11:22: 11:23
|
||||
_11 = (*_13); // scope 2 at $DIR/inline-closure-captures.rs:11:22: 11:23
|
||||
StorageDead(_13); // scope 2 at $DIR/inline-closure-captures.rs:11:18: 11:24
|
||||
Deinit(_0); // scope 2 at $DIR/inline-closure-captures.rs:11:18: 11:24
|
||||
(_0.0: i32) = move _10; // scope 2 at $DIR/inline-closure-captures.rs:11:18: 11:24
|
||||
(_0.1: T) = move _11; // scope 2 at $DIR/inline-closure-captures.rs:11:18: 11:24
|
||||
|
|
Loading…
Add table
Reference in a new issue