blob: ac06b2b01028f925fea29944249ebd79cf2a71db (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
// 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
// (under NLL) even when that conservative check goes away.
#![feature(if_let_guard)]
fn main() {
let mut b = &mut true;
match b {
&mut false => {},
ref mut r if { (|| { let bar = &mut *r; **bar = false; })();
//~^ ERROR cannot borrow `r` as mutable, as it is immutable for the pattern guard
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."),
}
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 => {},
_ => {},
}
}
|