// Various unsuccessful attempts to put the unboxed closure kind // inference into an awkward position that might require fixed point // iteration (basically where inferring the kind of a closure `c` // would require knowing the kind of `c`). I currently believe this is // impossible. fn a() { // This case of recursion wouldn't even require fixed-point // iteration, but it still doesn't work. The weird structure with // the `Option` is to avoid giving any useful hints about the `Fn` // kind via the expected type. let mut factorial: Option<Box<dyn Fn(u32) -> u32>> = None; let f = |x: u32| -> u32 { let g = factorial.as_ref().unwrap(); //~^ ERROR `factorial` does not live long enough if x == 0 {1} else {x * g(x-1)} }; factorial = Some(Box::new(f)); //~^ ERROR cannot assign to `factorial` because it is borrowed } fn b() { let mut factorial: Option<Box<dyn Fn(u32) -> u32 + 'static>> = None; let f = |x: u32| -> u32 { let g = factorial.as_ref().unwrap(); //~^ ERROR `factorial` does not live long enough if x == 0 {1} else {x * g(x-1)} }; factorial = Some(Box::new(f)); //~^ ERROR cannot assign to `factorial` because it is borrowed } fn main() { }