|  | #![feature(fn_traits)] | 
|  |  | 
|  | // Ensure that invoking a closure counts as a unique immutable borrow | 
|  |  | 
|  | type Fn<'a> = Box<dyn FnMut() + 'a>; | 
|  |  | 
|  | struct Test<'a> { | 
|  | f: Box<dyn FnMut() + 'a> | 
|  | } | 
|  |  | 
|  | fn call<F>(mut f: F) where F: FnMut(Fn) { | 
|  | f(Box::new(|| { | 
|  | //~^ ERROR: cannot borrow `f` as mutable more than once | 
|  | f((Box::new(|| {}))) | 
|  | })); | 
|  | } | 
|  |  | 
|  | fn test1() { | 
|  | call(|mut a| { | 
|  | a.call_mut(()); | 
|  | }); | 
|  | } | 
|  |  | 
|  | fn test2<F>(f: &F) where F: FnMut() { | 
|  | (*f)(); | 
|  | //~^ ERROR cannot borrow `*f` as mutable, as it is behind a `&` reference | 
|  | } | 
|  |  | 
|  | fn test3<F>(f: &mut F) where F: FnMut() { | 
|  | (*f)(); | 
|  | } | 
|  |  | 
|  | fn test4(f: &Test) { | 
|  | f.f.call_mut(()) | 
|  | //~^ ERROR: cannot borrow `f.f` as mutable, as it is behind a `&` reference | 
|  | } | 
|  |  | 
|  | fn test5(f: &mut Test) { | 
|  | f.f.call_mut(()) | 
|  | } | 
|  |  | 
|  | fn test6() { | 
|  | let mut f = || {}; | 
|  | (|| { | 
|  | f(); | 
|  | })(); | 
|  | } | 
|  |  | 
|  | fn test7() { | 
|  | fn foo<F>(_: F) where F: FnMut(Box<dyn FnMut(isize)>, isize) {} | 
|  | let s = String::new();  // Capture to make f !Copy | 
|  | let mut f = move |g: Box<dyn FnMut(isize)>, b: isize| { | 
|  | let _ = s.len(); | 
|  | }; | 
|  | f(Box::new(|a| { | 
|  | //~^ ERROR cannot move out of `f` because it is borrowed | 
|  | foo(f); | 
|  | //~^ ERROR cannot move out of `f`, a captured variable in an `FnMut` closure | 
|  | }), 3); | 
|  | } | 
|  |  | 
|  | fn main() {} |