| // Tests that a closure which requires mutable access to the referent |
| // of an `&mut` requires a "unique" borrow -- that is, the variable to |
| // be borrowed (here, `x`) will not be borrowed *mutably*, but |
| // may be *immutable*, but we cannot allow |
| // multiple borrows. |
| |
| |
| |
| fn get(x: &isize) -> isize { |
| *x |
| } |
| |
| fn set(x: &mut isize) -> isize { |
| *x |
| } |
| |
| fn a(x: &mut isize) { |
| let c1 = || get(x); |
| let c2 = || get(x); |
| c1(); |
| c2(); |
| } |
| |
| fn b(x: &mut isize) { |
| let c1 = || get(x); |
| let c2 = || set(x); //~ ERROR closure requires unique access to `x` |
| c1; |
| } |
| |
| fn c(x: &mut isize) { |
| let c1 = || get(x); |
| let c2 = || { get(x); set(x); }; //~ ERROR closure requires unique access to `x` |
| c1; |
| } |
| |
| fn d(x: &mut isize) { |
| let c1 = || set(x); |
| let c2 = || set(x); //~ ERROR two closures require unique access to `x` at the same time |
| c1; |
| } |
| |
| // This test was originally encoded in the form shown as `fn f` below. |
| // However, since MIR-borrowck and thus NLL takes more control-flow information |
| // into account, it was necessary to change the test in order to witness the |
| // same (expected) error under both AST-borrowck and NLL. |
| fn e(x: &'static mut isize) { |
| let c1 = |y: &'static mut isize| x = y; //~ ERROR closure cannot assign to immutable argument |
| c1; |
| } |
| |
| fn f(x: &'static mut isize) { |
| let c1 = || x = panic!(); //~ ERROR closure cannot assign to immutable argument |
| c1; |
| } |
| |
| fn main() { |
| } |