Review feedback: Added test with control flow merge of two borrows "before activation"
In reality the currently generated MIR has at least one of the activations in a copy that occurs before the merge. But still, good to have a test, in anticipation of that potentially changing...
This commit is contained in:
parent
b0421fa7de
commit
d654cd3b8b
1 changed files with 27 additions and 0 deletions
|
@ -0,0 +1,27 @@
|
||||||
|
// Copyright 2017 The Rust Project Developers. See the COPYRIGHT
|
||||||
|
// file at the top-level directory of this distribution and at
|
||||||
|
// http://rust-lang.org/COPYRIGHT.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
||||||
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
||||||
|
// option. This file may not be copied, modified, or distributed
|
||||||
|
// except according to those terms.
|
||||||
|
|
||||||
|
// revisions: lxl nll
|
||||||
|
//[lxl]compile-flags: -Z borrowck=mir -Z two-phase-borrows
|
||||||
|
//[nll]compile-flags: -Z borrowck=mir -Z two-phase-borrows -Z nll
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
let mut a = 0;
|
||||||
|
let mut b = 0;
|
||||||
|
let p = if maybe() {
|
||||||
|
&mut a
|
||||||
|
} else {
|
||||||
|
&mut b
|
||||||
|
};
|
||||||
|
use_(p);
|
||||||
|
}
|
||||||
|
|
||||||
|
fn maybe() -> bool { false }
|
||||||
|
fn use_<T>(_: T) { }
|
Loading…
Add table
Reference in a new issue