// 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() { }