mirror of
				https://github.com/rust-lang/rust.git
				synced 2025-11-04 06:56:14 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			38 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
			
		
		
	
	
			38 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
// 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() { }
 |