Fix SourceScope
for if let
bindings.
This commit is contained in:
parent
ec55c61305
commit
b48f3d86fc
12 changed files with 121 additions and 94 deletions
|
@ -70,8 +70,9 @@ impl<'a, 'tcx> Builder<'a, 'tcx> {
|
|||
&this.thir[cond],
|
||||
Some(condition_scope),
|
||||
condition_scope,
|
||||
then_expr.span,
|
||||
then_expr.span
|
||||
));
|
||||
|
||||
this.expr_into_dest(destination, then_blk, then_expr)
|
||||
});
|
||||
then_block.and(else_block)
|
||||
|
@ -97,7 +98,7 @@ impl<'a, 'tcx> Builder<'a, 'tcx> {
|
|||
ExprKind::Let { expr, ref pat } => {
|
||||
let scope = this.local_scope();
|
||||
let (true_block, false_block) = this.in_if_then_scope(scope, |this| {
|
||||
this.lower_let_expr(block, &this.thir[expr], pat, scope, expr_span)
|
||||
this.lower_let_expr(block, &this.thir[expr], pat, scope, None, expr_span)
|
||||
});
|
||||
|
||||
this.cfg.push_assign_constant(
|
||||
|
|
|
@ -41,7 +41,7 @@ impl<'a, 'tcx> Builder<'a, 'tcx> {
|
|||
expr: &Expr<'tcx>,
|
||||
temp_scope_override: Option<region::Scope>,
|
||||
break_scope: region::Scope,
|
||||
variable_scope_span: Span,
|
||||
variable_span: Span,
|
||||
) -> BlockAnd<()> {
|
||||
let this = self;
|
||||
let expr_span = expr.span;
|
||||
|
@ -53,7 +53,7 @@ impl<'a, 'tcx> Builder<'a, 'tcx> {
|
|||
&this.thir[lhs],
|
||||
temp_scope_override,
|
||||
break_scope,
|
||||
variable_scope_span,
|
||||
variable_span,
|
||||
));
|
||||
|
||||
let rhs_then_block = unpack!(this.then_else_break(
|
||||
|
@ -61,7 +61,7 @@ impl<'a, 'tcx> Builder<'a, 'tcx> {
|
|||
&this.thir[rhs],
|
||||
temp_scope_override,
|
||||
break_scope,
|
||||
variable_scope_span,
|
||||
variable_span,
|
||||
));
|
||||
|
||||
rhs_then_block.unit()
|
||||
|
@ -74,12 +74,22 @@ impl<'a, 'tcx> Builder<'a, 'tcx> {
|
|||
&this.thir[value],
|
||||
temp_scope_override,
|
||||
break_scope,
|
||||
variable_scope_span,
|
||||
variable_span,
|
||||
)
|
||||
})
|
||||
}
|
||||
ExprKind::Let { expr, ref pat } => {
|
||||
this.lower_let_expr(block, &this.thir[expr], pat, break_scope, variable_scope_span)
|
||||
let variable_scope =
|
||||
this.new_source_scope(variable_span, LintLevel::Inherited, None);
|
||||
this.source_scope = variable_scope;
|
||||
this.lower_let_expr(
|
||||
block,
|
||||
&this.thir[expr],
|
||||
pat,
|
||||
break_scope,
|
||||
Some(variable_scope),
|
||||
variable_span,
|
||||
)
|
||||
}
|
||||
_ => {
|
||||
let temp_scope = temp_scope_override.unwrap_or_else(|| this.local_scope());
|
||||
|
@ -1773,6 +1783,7 @@ impl<'a, 'tcx> Builder<'a, 'tcx> {
|
|||
expr: &Expr<'tcx>,
|
||||
pat: &Pat<'tcx>,
|
||||
else_target: region::Scope,
|
||||
source_scope: Option<SourceScope>,
|
||||
span: Span,
|
||||
) -> BlockAnd<()> {
|
||||
let expr_span = expr.span;
|
||||
|
@ -1798,7 +1809,14 @@ impl<'a, 'tcx> Builder<'a, 'tcx> {
|
|||
let otherwise_post_guard_block = otherwise_candidate.pre_binding_block.unwrap();
|
||||
self.break_for_else(otherwise_post_guard_block, else_target, self.source_info(expr_span));
|
||||
|
||||
self.declare_bindings(None, pat.span.to(span), pat, ArmHasGuard(false), opt_expr_place);
|
||||
self.declare_bindings(
|
||||
source_scope,
|
||||
pat.span.to(span),
|
||||
pat,
|
||||
ArmHasGuard(false),
|
||||
opt_expr_place,
|
||||
);
|
||||
|
||||
let post_guard_block = self.bind_pattern(
|
||||
self.source_info(pat.span),
|
||||
guard_candidate,
|
||||
|
@ -1975,7 +1993,7 @@ impl<'a, 'tcx> Builder<'a, 'tcx> {
|
|||
Guard::IfLet(ref pat, scrutinee) => {
|
||||
let s = &this.thir[scrutinee];
|
||||
guard_span = s.span;
|
||||
this.lower_let_expr(block, s, pat, match_scope, arm_span)
|
||||
this.lower_let_expr(block, s, pat, match_scope, None, arm_span)
|
||||
}
|
||||
});
|
||||
|
||||
|
|
|
@ -10,22 +10,24 @@
|
|||
scope 1 {
|
||||
debug x => _1; // in scope 1 at $DIR/discriminant.rs:11:9: 11:10
|
||||
}
|
||||
scope 2 {
|
||||
}
|
||||
|
||||
bb0: {
|
||||
StorageLive(_1); // scope 0 at $DIR/discriminant.rs:11:9: 11:10
|
||||
StorageLive(_2); // scope 0 at $DIR/discriminant.rs:11:13: 11:64
|
||||
StorageLive(_3); // scope 0 at $DIR/discriminant.rs:11:34: 11:44
|
||||
Deinit(_3); // scope 0 at $DIR/discriminant.rs:11:34: 11:44
|
||||
((_3 as Some).0: bool) = const true; // scope 0 at $DIR/discriminant.rs:11:34: 11:44
|
||||
discriminant(_3) = 1; // scope 0 at $DIR/discriminant.rs:11:34: 11:44
|
||||
- _4 = discriminant(_3); // scope 0 at $DIR/discriminant.rs:11:21: 11:31
|
||||
- switchInt(move _4) -> [1_isize: bb1, otherwise: bb3]; // scope 0 at $DIR/discriminant.rs:11:21: 11:31
|
||||
+ _4 = const 1_isize; // scope 0 at $DIR/discriminant.rs:11:21: 11:31
|
||||
+ switchInt(const 1_isize) -> [1_isize: bb1, otherwise: bb3]; // scope 0 at $DIR/discriminant.rs:11:21: 11:31
|
||||
StorageLive(_3); // scope 2 at $DIR/discriminant.rs:11:34: 11:44
|
||||
Deinit(_3); // scope 2 at $DIR/discriminant.rs:11:34: 11:44
|
||||
((_3 as Some).0: bool) = const true; // scope 2 at $DIR/discriminant.rs:11:34: 11:44
|
||||
discriminant(_3) = 1; // scope 2 at $DIR/discriminant.rs:11:34: 11:44
|
||||
- _4 = discriminant(_3); // scope 2 at $DIR/discriminant.rs:11:21: 11:31
|
||||
- switchInt(move _4) -> [1_isize: bb1, otherwise: bb3]; // scope 2 at $DIR/discriminant.rs:11:21: 11:31
|
||||
+ _4 = const 1_isize; // scope 2 at $DIR/discriminant.rs:11:21: 11:31
|
||||
+ switchInt(const 1_isize) -> [1_isize: bb1, otherwise: bb3]; // scope 2 at $DIR/discriminant.rs:11:21: 11:31
|
||||
}
|
||||
|
||||
bb1: {
|
||||
switchInt(((_3 as Some).0: bool)) -> [false: bb3, otherwise: bb2]; // scope 0 at $DIR/discriminant.rs:11:21: 11:31
|
||||
switchInt(((_3 as Some).0: bool)) -> [false: bb3, otherwise: bb2]; // scope 2 at $DIR/discriminant.rs:11:21: 11:31
|
||||
}
|
||||
|
||||
bb2: {
|
||||
|
|
|
@ -7,18 +7,20 @@
|
|||
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
|
||||
scope 1 {
|
||||
}
|
||||
|
||||
bb0: {
|
||||
_3 = discriminant((*_1)); // scope 0 at $DIR/early_otherwise_branch_soundness.rs:13:12: 13:31
|
||||
switchInt(move _3) -> [1_isize: bb1, otherwise: bb3]; // scope 0 at $DIR/early_otherwise_branch_soundness.rs:13:12: 13:31
|
||||
_3 = discriminant((*_1)); // scope 1 at $DIR/early_otherwise_branch_soundness.rs:13:12: 13:31
|
||||
switchInt(move _3) -> [1_isize: bb1, otherwise: bb3]; // scope 1 at $DIR/early_otherwise_branch_soundness.rs:13:12: 13:31
|
||||
}
|
||||
|
||||
bb1: {
|
||||
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
|
||||
StorageLive(_4); // scope 1 at $DIR/early_otherwise_branch_soundness.rs:13:12: 13:31
|
||||
_4 = move (((*_1) as Some).0: &E); // scope 1 at $DIR/early_otherwise_branch_soundness.rs:13:12: 13:31
|
||||
_2 = discriminant((*_4)); // scope 1 at $DIR/early_otherwise_branch_soundness.rs:13:12: 13:31
|
||||
StorageDead(_4); // scope 1 at $DIR/early_otherwise_branch_soundness.rs:13:12: 13:31
|
||||
switchInt(move _2) -> [1_isize: bb2, otherwise: bb3]; // scope 1 at $DIR/early_otherwise_branch_soundness.rs:13:12: 13:31
|
||||
}
|
||||
|
||||
bb2: {
|
||||
|
|
|
@ -27,9 +27,9 @@
|
|||
let _6: core::num::flt2dec::Sign; // in scope 1 at $DIR/funky_arms.rs:19:9: 19:13
|
||||
scope 2 {
|
||||
debug sign => _6; // in scope 2 at $DIR/funky_arms.rs:19:9: 19:13
|
||||
let _10: usize; // in scope 2 at $DIR/funky_arms.rs:24:17: 24:26
|
||||
scope 3 {
|
||||
debug precision => _10; // in scope 3 at $DIR/funky_arms.rs:24:17: 24:26
|
||||
let _10: usize; // in scope 3 at $DIR/funky_arms.rs:24:17: 24:26
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -63,24 +63,24 @@
|
|||
}
|
||||
|
||||
bb4: {
|
||||
StorageLive(_7); // scope 2 at $DIR/funky_arms.rs:24:30: 24:45
|
||||
StorageLive(_8); // scope 2 at $DIR/funky_arms.rs:24:30: 24:45
|
||||
_8 = &(*_1); // scope 2 at $DIR/funky_arms.rs:24:30: 24:45
|
||||
_7 = Formatter::precision(move _8) -> bb5; // scope 2 at $DIR/funky_arms.rs:24:30: 24:45
|
||||
StorageLive(_7); // scope 3 at $DIR/funky_arms.rs:24:30: 24:45
|
||||
StorageLive(_8); // scope 3 at $DIR/funky_arms.rs:24:30: 24:45
|
||||
_8 = &(*_1); // scope 3 at $DIR/funky_arms.rs:24:30: 24:45
|
||||
_7 = Formatter::precision(move _8) -> bb5; // scope 3 at $DIR/funky_arms.rs:24:30: 24:45
|
||||
// mir::Constant
|
||||
// + span: $DIR/funky_arms.rs:24:34: 24:43
|
||||
// + literal: Const { ty: for<'r> fn(&'r Formatter) -> Option<usize> {Formatter::precision}, val: Value(Scalar(<ZST>)) }
|
||||
}
|
||||
|
||||
bb5: {
|
||||
StorageDead(_8); // scope 2 at $DIR/funky_arms.rs:24:44: 24:45
|
||||
_9 = discriminant(_7); // scope 2 at $DIR/funky_arms.rs:24:12: 24:27
|
||||
switchInt(move _9) -> [1_isize: bb6, otherwise: bb8]; // scope 2 at $DIR/funky_arms.rs:24:12: 24:27
|
||||
StorageDead(_8); // scope 3 at $DIR/funky_arms.rs:24:44: 24:45
|
||||
_9 = discriminant(_7); // scope 3 at $DIR/funky_arms.rs:24:12: 24:27
|
||||
switchInt(move _9) -> [1_isize: bb6, otherwise: bb8]; // scope 3 at $DIR/funky_arms.rs:24:12: 24:27
|
||||
}
|
||||
|
||||
bb6: {
|
||||
StorageLive(_10); // scope 2 at $DIR/funky_arms.rs:24:17: 24:26
|
||||
_10 = ((_7 as Some).0: usize); // scope 2 at $DIR/funky_arms.rs:24:17: 24:26
|
||||
StorageLive(_10); // scope 3 at $DIR/funky_arms.rs:24:17: 24:26
|
||||
_10 = ((_7 as Some).0: usize); // scope 3 at $DIR/funky_arms.rs:24:17: 24:26
|
||||
StorageLive(_11); // scope 2 at $DIR/funky_arms.rs:26:43: 26:46
|
||||
_11 = &mut (*_1); // scope 2 at $DIR/funky_arms.rs:26:43: 26:46
|
||||
StorageLive(_12); // scope 2 at $DIR/funky_arms.rs:26:48: 26:51
|
||||
|
|
|
@ -14,9 +14,9 @@ fn main() -> () {
|
|||
let mut _11: isize; // in scope 0 at $DIR/issue-41888.rs:15:1: 15:2
|
||||
scope 1 {
|
||||
debug e => _1; // in scope 1 at $DIR/issue-41888.rs:7:9: 7:10
|
||||
let _6: K; // in scope 1 at $DIR/issue-41888.rs:10:21: 10:23
|
||||
scope 2 {
|
||||
debug _k => _6; // in scope 2 at $DIR/issue-41888.rs:10:21: 10:23
|
||||
let _6: K; // in scope 2 at $DIR/issue-41888.rs:10:21: 10:23
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -51,14 +51,14 @@ fn main() -> () {
|
|||
|
||||
bb4: {
|
||||
StorageDead(_3); // scope 1 at $DIR/issue-41888.rs:9:19: 9:20
|
||||
_5 = discriminant(_1); // scope 1 at $DIR/issue-41888.rs:10:16: 10:24
|
||||
switchInt(move _5) -> [0_isize: bb5, otherwise: bb6]; // scope 1 at $DIR/issue-41888.rs:10:16: 10:24
|
||||
_5 = discriminant(_1); // scope 2 at $DIR/issue-41888.rs:10:16: 10:24
|
||||
switchInt(move _5) -> [0_isize: bb5, otherwise: bb6]; // scope 2 at $DIR/issue-41888.rs:10:16: 10:24
|
||||
}
|
||||
|
||||
bb5: {
|
||||
StorageLive(_6); // scope 1 at $DIR/issue-41888.rs:10:21: 10:23
|
||||
_9 = const false; // scope 1 at $DIR/issue-41888.rs:10:21: 10:23
|
||||
_6 = move ((_1 as F).0: K); // scope 1 at $DIR/issue-41888.rs:10:21: 10:23
|
||||
StorageLive(_6); // scope 2 at $DIR/issue-41888.rs:10:21: 10:23
|
||||
_9 = const false; // scope 2 at $DIR/issue-41888.rs:10:21: 10:23
|
||||
_6 = move ((_1 as F).0: K); // scope 2 at $DIR/issue-41888.rs:10:21: 10:23
|
||||
_0 = const (); // scope 1 at $DIR/issue-41888.rs:10:29: 13:10
|
||||
StorageDead(_6); // scope 1 at $DIR/issue-41888.rs:13:9: 13:10
|
||||
goto -> bb8; // scope 1 at $DIR/issue-41888.rs:10:9: 13:10
|
||||
|
|
|
@ -10,9 +10,9 @@
|
|||
let mut _6: u32; // in scope 0 at $DIR/issue-75439.rs:10:33: 10:35
|
||||
scope 1 {
|
||||
debug dwords => _2; // in scope 1 at $DIR/issue-75439.rs:7:9: 7:15
|
||||
let _4: u32; // in scope 1 at $DIR/issue-75439.rs:9:27: 9:29
|
||||
scope 3 {
|
||||
debug ip => _4; // in scope 3 at $DIR/issue-75439.rs:9:27: 9:29
|
||||
let _4: u32; // in scope 3 at $DIR/issue-75439.rs:9:27: 9:29
|
||||
}
|
||||
scope 4 {
|
||||
}
|
||||
|
@ -32,15 +32,15 @@
|
|||
|
||||
bb1: {
|
||||
StorageDead(_3); // scope 2 at $DIR/issue-75439.rs:7:52: 7:53
|
||||
switchInt(_2[0 of 4]) -> [0_u32: bb2, otherwise: bb8]; // scope 1 at $DIR/issue-75439.rs:9:12: 9:30
|
||||
switchInt(_2[0 of 4]) -> [0_u32: bb2, otherwise: bb8]; // scope 3 at $DIR/issue-75439.rs:9:12: 9:30
|
||||
}
|
||||
|
||||
bb2: {
|
||||
switchInt(_2[1 of 4]) -> [0_u32: bb3, otherwise: bb8]; // scope 1 at $DIR/issue-75439.rs:9:12: 9:30
|
||||
switchInt(_2[1 of 4]) -> [0_u32: bb3, otherwise: bb8]; // scope 3 at $DIR/issue-75439.rs:9:12: 9:30
|
||||
}
|
||||
|
||||
bb3: {
|
||||
switchInt(_2[2 of 4]) -> [0_u32: bb5, 4294901760_u32: bb6, otherwise: bb8]; // scope 1 at $DIR/issue-75439.rs:9:12: 9:30
|
||||
switchInt(_2[2 of 4]) -> [0_u32: bb5, 4294901760_u32: bb6, otherwise: bb8]; // scope 3 at $DIR/issue-75439.rs:9:12: 9:30
|
||||
}
|
||||
|
||||
bb4: {
|
||||
|
@ -54,15 +54,15 @@
|
|||
}
|
||||
|
||||
bb5: {
|
||||
StorageLive(_4); // scope 1 at $DIR/issue-75439.rs:9:27: 9:29
|
||||
_4 = _2[3 of 4]; // scope 1 at $DIR/issue-75439.rs:9:27: 9:29
|
||||
goto -> bb4; // scope 1 at $DIR/issue-75439.rs:9:12: 9:30
|
||||
StorageLive(_4); // scope 3 at $DIR/issue-75439.rs:9:27: 9:29
|
||||
_4 = _2[3 of 4]; // scope 3 at $DIR/issue-75439.rs:9:27: 9:29
|
||||
goto -> bb4; // scope 3 at $DIR/issue-75439.rs:9:12: 9:30
|
||||
}
|
||||
|
||||
bb6: {
|
||||
StorageLive(_4); // scope 1 at $DIR/issue-75439.rs:9:27: 9:29
|
||||
_4 = _2[3 of 4]; // scope 1 at $DIR/issue-75439.rs:9:27: 9:29
|
||||
goto -> bb4; // scope 1 at $DIR/issue-75439.rs:9:12: 9:30
|
||||
StorageLive(_4); // scope 3 at $DIR/issue-75439.rs:9:27: 9:29
|
||||
_4 = _2[3 of 4]; // scope 3 at $DIR/issue-75439.rs:9:27: 9:29
|
||||
goto -> bb4; // scope 3 at $DIR/issue-75439.rs:9:12: 9:30
|
||||
}
|
||||
|
||||
bb7: {
|
||||
|
|
|
@ -8,38 +8,38 @@
|
|||
let mut _3: std::option::Option<T>; // in scope 0 at $DIR/simplify-locals-fixedpoint.rs:4:51: 4:68
|
||||
let mut _4: isize; // in scope 0 at $DIR/simplify-locals-fixedpoint.rs:4:22: 4:26
|
||||
let mut _5: isize; // in scope 0 at $DIR/simplify-locals-fixedpoint.rs:4:13: 4:20
|
||||
let _6: u8; // in scope 0 at $DIR/simplify-locals-fixedpoint.rs:4:18: 4:19
|
||||
- let mut _7: bool; // in scope 0 at $DIR/simplify-locals-fixedpoint.rs:5:12: 5:20
|
||||
- let mut _8: u8; // in scope 0 at $DIR/simplify-locals-fixedpoint.rs:5:12: 5:13
|
||||
scope 1 {
|
||||
debug a => _6; // in scope 1 at $DIR/simplify-locals-fixedpoint.rs:4:18: 4:19
|
||||
let _6: u8; // in scope 1 at $DIR/simplify-locals-fixedpoint.rs:4:18: 4:19
|
||||
}
|
||||
|
||||
bb0: {
|
||||
StorageLive(_1); // scope 0 at $DIR/simplify-locals-fixedpoint.rs:4:30: 4:69
|
||||
StorageLive(_2); // scope 0 at $DIR/simplify-locals-fixedpoint.rs:4:31: 4:49
|
||||
Deinit(_2); // scope 0 at $DIR/simplify-locals-fixedpoint.rs:4:31: 4:49
|
||||
discriminant(_2) = 0; // scope 0 at $DIR/simplify-locals-fixedpoint.rs:4:31: 4:49
|
||||
StorageLive(_3); // scope 0 at $DIR/simplify-locals-fixedpoint.rs:4:51: 4:68
|
||||
Deinit(_3); // scope 0 at $DIR/simplify-locals-fixedpoint.rs:4:51: 4:68
|
||||
discriminant(_3) = 0; // scope 0 at $DIR/simplify-locals-fixedpoint.rs:4:51: 4:68
|
||||
Deinit(_1); // scope 0 at $DIR/simplify-locals-fixedpoint.rs:4:30: 4:69
|
||||
(_1.0: std::option::Option<u8>) = move _2; // scope 0 at $DIR/simplify-locals-fixedpoint.rs:4:30: 4:69
|
||||
(_1.1: std::option::Option<T>) = move _3; // scope 0 at $DIR/simplify-locals-fixedpoint.rs:4:30: 4:69
|
||||
StorageDead(_3); // scope 0 at $DIR/simplify-locals-fixedpoint.rs:4:68: 4:69
|
||||
StorageDead(_2); // scope 0 at $DIR/simplify-locals-fixedpoint.rs:4:68: 4:69
|
||||
_5 = discriminant((_1.0: std::option::Option<u8>)); // scope 0 at $DIR/simplify-locals-fixedpoint.rs:4:12: 4:27
|
||||
switchInt(move _5) -> [1_isize: bb1, otherwise: bb3]; // scope 0 at $DIR/simplify-locals-fixedpoint.rs:4:12: 4:27
|
||||
StorageLive(_1); // scope 1 at $DIR/simplify-locals-fixedpoint.rs:4:30: 4:69
|
||||
StorageLive(_2); // scope 1 at $DIR/simplify-locals-fixedpoint.rs:4:31: 4:49
|
||||
Deinit(_2); // scope 1 at $DIR/simplify-locals-fixedpoint.rs:4:31: 4:49
|
||||
discriminant(_2) = 0; // scope 1 at $DIR/simplify-locals-fixedpoint.rs:4:31: 4:49
|
||||
StorageLive(_3); // scope 1 at $DIR/simplify-locals-fixedpoint.rs:4:51: 4:68
|
||||
Deinit(_3); // scope 1 at $DIR/simplify-locals-fixedpoint.rs:4:51: 4:68
|
||||
discriminant(_3) = 0; // scope 1 at $DIR/simplify-locals-fixedpoint.rs:4:51: 4:68
|
||||
Deinit(_1); // scope 1 at $DIR/simplify-locals-fixedpoint.rs:4:30: 4:69
|
||||
(_1.0: std::option::Option<u8>) = move _2; // scope 1 at $DIR/simplify-locals-fixedpoint.rs:4:30: 4:69
|
||||
(_1.1: std::option::Option<T>) = move _3; // scope 1 at $DIR/simplify-locals-fixedpoint.rs:4:30: 4:69
|
||||
StorageDead(_3); // scope 1 at $DIR/simplify-locals-fixedpoint.rs:4:68: 4:69
|
||||
StorageDead(_2); // scope 1 at $DIR/simplify-locals-fixedpoint.rs:4:68: 4:69
|
||||
_5 = discriminant((_1.0: std::option::Option<u8>)); // scope 1 at $DIR/simplify-locals-fixedpoint.rs:4:12: 4:27
|
||||
switchInt(move _5) -> [1_isize: bb1, otherwise: bb3]; // scope 1 at $DIR/simplify-locals-fixedpoint.rs:4:12: 4:27
|
||||
}
|
||||
|
||||
bb1: {
|
||||
_4 = discriminant((_1.1: std::option::Option<T>)); // scope 0 at $DIR/simplify-locals-fixedpoint.rs:4:12: 4:27
|
||||
switchInt(move _4) -> [0_isize: bb2, otherwise: bb3]; // scope 0 at $DIR/simplify-locals-fixedpoint.rs:4:12: 4:27
|
||||
_4 = discriminant((_1.1: std::option::Option<T>)); // scope 1 at $DIR/simplify-locals-fixedpoint.rs:4:12: 4:27
|
||||
switchInt(move _4) -> [0_isize: bb2, otherwise: bb3]; // scope 1 at $DIR/simplify-locals-fixedpoint.rs:4:12: 4:27
|
||||
}
|
||||
|
||||
bb2: {
|
||||
StorageLive(_6); // scope 0 at $DIR/simplify-locals-fixedpoint.rs:4:18: 4:19
|
||||
_6 = (((_1.0: std::option::Option<u8>) as Some).0: u8); // scope 0 at $DIR/simplify-locals-fixedpoint.rs:4:18: 4:19
|
||||
StorageLive(_6); // scope 1 at $DIR/simplify-locals-fixedpoint.rs:4:18: 4:19
|
||||
_6 = (((_1.0: std::option::Option<u8>) as Some).0: u8); // scope 1 at $DIR/simplify-locals-fixedpoint.rs:4:18: 4:19
|
||||
- StorageLive(_7); // scope 0 at $DIR/simplify-locals-fixedpoint.rs:5:12: 5:20
|
||||
- StorageLive(_8); // scope 0 at $DIR/simplify-locals-fixedpoint.rs:5:12: 5:13
|
||||
- _8 = _6; // scope 0 at $DIR/simplify-locals-fixedpoint.rs:5:12: 5:13
|
||||
|
|
|
@ -5,35 +5,35 @@
|
|||
let mut _0: (); // return place in scope 0 at $DIR/unreachable.rs:8:11: 8:11
|
||||
let mut _1: std::option::Option<Empty>; // in scope 0 at $DIR/unreachable.rs:9:23: 9:30
|
||||
let mut _2: isize; // in scope 0 at $DIR/unreachable.rs:9:12: 9:20
|
||||
let _3: Empty; // in scope 0 at $DIR/unreachable.rs:9:17: 9:19
|
||||
let mut _4: i32; // in scope 0 at $DIR/unreachable.rs:10:13: 10:19
|
||||
let _5: (); // in scope 0 at $DIR/unreachable.rs:12:9: 16:10
|
||||
let mut _6: bool; // in scope 0 at $DIR/unreachable.rs:12:12: 12:16
|
||||
let mut _7: !; // in scope 0 at $DIR/unreachable.rs:18:9: 18:21
|
||||
scope 1 {
|
||||
debug _x => _3; // in scope 1 at $DIR/unreachable.rs:9:17: 9:19
|
||||
let _3: Empty; // in scope 1 at $DIR/unreachable.rs:9:17: 9:19
|
||||
}
|
||||
scope 2 {
|
||||
debug _y => _4; // in scope 2 at $DIR/unreachable.rs:10:13: 10:19
|
||||
}
|
||||
|
||||
bb0: {
|
||||
StorageLive(_1); // scope 0 at $DIR/unreachable.rs:9:23: 9:30
|
||||
_1 = empty() -> bb1; // scope 0 at $DIR/unreachable.rs:9:23: 9:30
|
||||
StorageLive(_1); // scope 1 at $DIR/unreachable.rs:9:23: 9:30
|
||||
_1 = empty() -> bb1; // scope 1 at $DIR/unreachable.rs:9:23: 9:30
|
||||
// mir::Constant
|
||||
// + span: $DIR/unreachable.rs:9:23: 9:28
|
||||
// + literal: Const { ty: fn() -> Option<Empty> {empty}, val: Value(Scalar(<ZST>)) }
|
||||
}
|
||||
|
||||
bb1: {
|
||||
_2 = discriminant(_1); // scope 0 at $DIR/unreachable.rs:9:12: 9:20
|
||||
- switchInt(move _2) -> [1_isize: bb2, otherwise: bb6]; // scope 0 at $DIR/unreachable.rs:9:12: 9:20
|
||||
+ goto -> bb2; // scope 0 at $DIR/unreachable.rs:9:12: 9:20
|
||||
_2 = discriminant(_1); // scope 1 at $DIR/unreachable.rs:9:12: 9:20
|
||||
- switchInt(move _2) -> [1_isize: bb2, otherwise: bb6]; // scope 1 at $DIR/unreachable.rs:9:12: 9:20
|
||||
+ goto -> bb2; // scope 1 at $DIR/unreachable.rs:9:12: 9:20
|
||||
}
|
||||
|
||||
bb2: {
|
||||
- StorageLive(_3); // scope 0 at $DIR/unreachable.rs:9:17: 9:19
|
||||
- _3 = move ((_1 as Some).0: Empty); // scope 0 at $DIR/unreachable.rs:9:17: 9:19
|
||||
- StorageLive(_3); // scope 1 at $DIR/unreachable.rs:9:17: 9:19
|
||||
- _3 = move ((_1 as Some).0: Empty); // scope 1 at $DIR/unreachable.rs:9:17: 9:19
|
||||
- StorageLive(_4); // scope 0 at $DIR/unreachable.rs:10:13: 10:19
|
||||
- StorageLive(_5); // scope 2 at $DIR/unreachable.rs:12:9: 16:10
|
||||
- StorageLive(_6); // scope 2 at $DIR/unreachable.rs:12:12: 12:16
|
||||
|
|
|
@ -11,31 +11,31 @@
|
|||
let mut _7: !; // in scope 0 at $DIR/unreachable_diverging.rs:18:9: 18:22
|
||||
scope 1 {
|
||||
debug x => _1; // in scope 1 at $DIR/unreachable_diverging.rs:13:9: 13:10
|
||||
let _4: Empty; // in scope 1 at $DIR/unreachable_diverging.rs:14:17: 14:21
|
||||
scope 2 {
|
||||
debug bomb => _4; // in scope 2 at $DIR/unreachable_diverging.rs:14:17: 14:21
|
||||
let _4: Empty; // in scope 2 at $DIR/unreachable_diverging.rs:14:17: 14:21
|
||||
}
|
||||
}
|
||||
|
||||
bb0: {
|
||||
StorageLive(_1); // scope 0 at $DIR/unreachable_diverging.rs:13:9: 13:10
|
||||
_1 = const true; // scope 0 at $DIR/unreachable_diverging.rs:13:13: 13:17
|
||||
StorageLive(_2); // scope 1 at $DIR/unreachable_diverging.rs:14:25: 14:32
|
||||
_2 = empty() -> bb1; // scope 1 at $DIR/unreachable_diverging.rs:14:25: 14:32
|
||||
StorageLive(_2); // scope 2 at $DIR/unreachable_diverging.rs:14:25: 14:32
|
||||
_2 = empty() -> bb1; // scope 2 at $DIR/unreachable_diverging.rs:14:25: 14:32
|
||||
// mir::Constant
|
||||
// + span: $DIR/unreachable_diverging.rs:14:25: 14:30
|
||||
// + literal: Const { ty: fn() -> Option<Empty> {empty}, val: Value(Scalar(<ZST>)) }
|
||||
}
|
||||
|
||||
bb1: {
|
||||
_3 = discriminant(_2); // scope 1 at $DIR/unreachable_diverging.rs:14:12: 14:22
|
||||
- switchInt(move _3) -> [1_isize: bb2, otherwise: bb6]; // scope 1 at $DIR/unreachable_diverging.rs:14:12: 14:22
|
||||
+ switchInt(move _3) -> [1_isize: bb2, otherwise: bb5]; // scope 1 at $DIR/unreachable_diverging.rs:14:12: 14:22
|
||||
_3 = discriminant(_2); // scope 2 at $DIR/unreachable_diverging.rs:14:12: 14:22
|
||||
- switchInt(move _3) -> [1_isize: bb2, otherwise: bb6]; // scope 2 at $DIR/unreachable_diverging.rs:14:12: 14:22
|
||||
+ switchInt(move _3) -> [1_isize: bb2, otherwise: bb5]; // scope 2 at $DIR/unreachable_diverging.rs:14:12: 14:22
|
||||
}
|
||||
|
||||
bb2: {
|
||||
StorageLive(_4); // scope 1 at $DIR/unreachable_diverging.rs:14:17: 14:21
|
||||
_4 = move ((_2 as Some).0: Empty); // scope 1 at $DIR/unreachable_diverging.rs:14:17: 14:21
|
||||
StorageLive(_4); // scope 2 at $DIR/unreachable_diverging.rs:14:17: 14:21
|
||||
_4 = move ((_2 as Some).0: Empty); // scope 2 at $DIR/unreachable_diverging.rs:14:17: 14:21
|
||||
StorageLive(_5); // scope 1 at $DIR/unreachable_diverging.rs:15:9: 17:10
|
||||
StorageLive(_6); // scope 1 at $DIR/unreachable_diverging.rs:15:12: 15:13
|
||||
_6 = _1; // scope 1 at $DIR/unreachable_diverging.rs:15:12: 15:13
|
||||
|
|
|
@ -13,22 +13,24 @@
|
|||
let mut _8: !; // in scope 0 at $DIR/while_let_loops.rs:7:5: 10:6
|
||||
scope 1 {
|
||||
debug _x => _1; // in scope 1 at $DIR/while_let_loops.rs:6:9: 6:15
|
||||
scope 2 {
|
||||
}
|
||||
}
|
||||
|
||||
bb0: {
|
||||
StorageLive(_1); // scope 0 at $DIR/while_let_loops.rs:6:9: 6:15
|
||||
_1 = const 0_i32; // scope 0 at $DIR/while_let_loops.rs:6:18: 6:19
|
||||
StorageLive(_3); // scope 1 at $DIR/while_let_loops.rs:7:28: 7:32
|
||||
Deinit(_3); // scope 1 at $DIR/while_let_loops.rs:7:28: 7:32
|
||||
discriminant(_3) = 0; // scope 1 at $DIR/while_let_loops.rs:7:28: 7:32
|
||||
- _4 = discriminant(_3); // scope 1 at $DIR/while_let_loops.rs:7:15: 7:25
|
||||
- switchInt(move _4) -> [1_isize: bb1, otherwise: bb3]; // scope 1 at $DIR/while_let_loops.rs:7:15: 7:25
|
||||
+ _4 = const 0_isize; // scope 1 at $DIR/while_let_loops.rs:7:15: 7:25
|
||||
+ switchInt(const 0_isize) -> [1_isize: bb1, otherwise: bb3]; // scope 1 at $DIR/while_let_loops.rs:7:15: 7:25
|
||||
StorageLive(_3); // scope 2 at $DIR/while_let_loops.rs:7:28: 7:32
|
||||
Deinit(_3); // scope 2 at $DIR/while_let_loops.rs:7:28: 7:32
|
||||
discriminant(_3) = 0; // scope 2 at $DIR/while_let_loops.rs:7:28: 7:32
|
||||
- _4 = discriminant(_3); // scope 2 at $DIR/while_let_loops.rs:7:15: 7:25
|
||||
- switchInt(move _4) -> [1_isize: bb1, otherwise: bb3]; // scope 2 at $DIR/while_let_loops.rs:7:15: 7:25
|
||||
+ _4 = const 0_isize; // scope 2 at $DIR/while_let_loops.rs:7:15: 7:25
|
||||
+ switchInt(const 0_isize) -> [1_isize: bb1, otherwise: bb3]; // scope 2 at $DIR/while_let_loops.rs:7:15: 7:25
|
||||
}
|
||||
|
||||
bb1: {
|
||||
switchInt(((_3 as Some).0: u32)) -> [0_u32: bb2, otherwise: bb3]; // scope 1 at $DIR/while_let_loops.rs:7:15: 7:25
|
||||
switchInt(((_3 as Some).0: u32)) -> [0_u32: bb2, otherwise: bb3]; // scope 2 at $DIR/while_let_loops.rs:7:15: 7:25
|
||||
}
|
||||
|
||||
bb2: {
|
||||
|
|
|
@ -5,6 +5,8 @@ fn change_loop_body() -> () {
|
|||
let mut _1: i32; // in scope 0 at $DIR/while_let_loops.rs:6:9: 6:15
|
||||
scope 1 {
|
||||
debug _x => _1; // in scope 1 at $DIR/while_let_loops.rs:6:9: 6:15
|
||||
scope 2 {
|
||||
}
|
||||
}
|
||||
|
||||
bb0: {
|
||||
|
|
Loading…
Add table
Reference in a new issue