2018-05-15 21:23:00 +00:00
|
|
|
// Issue 27282: This is a variation on issue-27282-move-ref-mut-into-guard.rs
|
|
|
|
//
|
|
|
|
// It reborrows instead of moving the `ref mut` pattern borrow. This
|
|
|
|
// means that our conservative check for mutation in guards will
|
|
|
|
// reject it. But I want to make sure that we continue to reject it
|
2022-12-21 15:29:35 +00:00
|
|
|
// (under NLL) even when that conservative check goes away.
|
|
|
|
|
|
|
|
#![feature(if_let_guard)]
|
2018-05-15 21:23:00 +00:00
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let mut b = &mut true;
|
|
|
|
match b {
|
|
|
|
&mut false => {},
|
|
|
|
ref mut r if { (|| { let bar = &mut *r; **bar = false; })();
|
2018-07-17 19:29:48 +00:00
|
|
|
//~^ ERROR cannot borrow `r` as mutable, as it is immutable for the pattern guard
|
2018-05-15 21:23:00 +00:00
|
|
|
false } => { &mut *r; },
|
|
|
|
&mut true => { println!("You might think we should get here"); },
|
|
|
|
_ => panic!("surely we could never get here, since rustc warns it is unreachable."),
|
|
|
|
}
|
2022-12-21 15:29:35 +00:00
|
|
|
|
|
|
|
let mut b = &mut true;
|
|
|
|
match b {
|
|
|
|
&mut false => {},
|
|
|
|
ref mut r if let Some(()) = { (|| { let bar = &mut *r; **bar = false; })();
|
|
|
|
//~^ ERROR cannot borrow `r` as mutable, as it is immutable for the pattern guard
|
|
|
|
None } => { &mut *r; },
|
|
|
|
&mut true => {},
|
|
|
|
_ => {},
|
|
|
|
}
|
2018-05-15 21:23:00 +00:00
|
|
|
}
|