4aba2c55e6
Start pointing to where bindings were declared when they are captured in closures: ``` error[E0597]: `x` does not live long enough --> $DIR/suggest-return-closure.rs:23:9 | LL | let x = String::new(); | - binding `x` declared here ... LL | |c| { | --- value captured here LL | x.push(c); | ^ borrowed value does not live long enough ... LL | } | -- borrow later used here | | | `x` dropped here while still borrowed ``` Suggest cloning in more cases involving closures: ``` error[E0507]: cannot move out of `foo` in pattern guard --> $DIR/issue-27282-move-ref-mut-into-guard.rs:11:19 | LL | if { (|| { let mut bar = foo; bar.take() })(); false } => {}, | ^^ --- move occurs because `foo` has type `&mut Option<&i32>`, which does not implement the `Copy` trait | | | `foo` is moved here | = note: variables bound in patterns cannot be moved from until after the end of the pattern guard help: consider cloning the value if the performance cost is acceptable | LL | if { (|| { let mut bar = foo.clone(); bar.take() })(); false } => {}, | ++++++++ ```
65 lines
2.6 KiB
Text
65 lines
2.6 KiB
Text
error[E0597]: `factorial` does not live long enough
|
|
--> $DIR/unboxed-closures-failed-recursive-fn-1.rs:15:17
|
|
|
|
|
LL | let mut factorial: Option<Box<dyn Fn(u32) -> u32>> = None;
|
|
| ------------- binding `factorial` declared here
|
|
LL |
|
|
LL | let f = |x: u32| -> u32 {
|
|
| --------------- value captured here
|
|
LL | let g = factorial.as_ref().unwrap();
|
|
| ^^^^^^^^^ borrowed value does not live long enough
|
|
...
|
|
LL | }
|
|
| -
|
|
| |
|
|
| `factorial` dropped here while still borrowed
|
|
| borrow might be used here, when `factorial` is dropped and runs the destructor for type `Option<Box<dyn Fn(u32) -> u32>>`
|
|
|
|
error[E0506]: cannot assign to `factorial` because it is borrowed
|
|
--> $DIR/unboxed-closures-failed-recursive-fn-1.rs:20:5
|
|
|
|
|
LL | let f = |x: u32| -> u32 {
|
|
| --------------- `factorial` is borrowed here
|
|
LL | let g = factorial.as_ref().unwrap();
|
|
| --------- borrow occurs due to use in closure
|
|
...
|
|
LL | factorial = Some(Box::new(f));
|
|
| ^^^^^^^^^
|
|
| |
|
|
| `factorial` is assigned to here but it was already borrowed
|
|
| borrow later used here
|
|
|
|
error[E0597]: `factorial` does not live long enough
|
|
--> $DIR/unboxed-closures-failed-recursive-fn-1.rs:28:17
|
|
|
|
|
LL | let mut factorial: Option<Box<dyn Fn(u32) -> u32 + 'static>> = None;
|
|
| ------------- ----------------------------------------- type annotation requires that `factorial` is borrowed for `'static`
|
|
| |
|
|
| binding `factorial` declared here
|
|
LL |
|
|
LL | let f = |x: u32| -> u32 {
|
|
| --------------- value captured here
|
|
LL | let g = factorial.as_ref().unwrap();
|
|
| ^^^^^^^^^ borrowed value does not live long enough
|
|
...
|
|
LL | }
|
|
| - `factorial` dropped here while still borrowed
|
|
|
|
error[E0506]: cannot assign to `factorial` because it is borrowed
|
|
--> $DIR/unboxed-closures-failed-recursive-fn-1.rs:33:5
|
|
|
|
|
LL | let mut factorial: Option<Box<dyn Fn(u32) -> u32 + 'static>> = None;
|
|
| ----------------------------------------- type annotation requires that `factorial` is borrowed for `'static`
|
|
LL |
|
|
LL | let f = |x: u32| -> u32 {
|
|
| --------------- `factorial` is borrowed here
|
|
LL | let g = factorial.as_ref().unwrap();
|
|
| --------- borrow occurs due to use in closure
|
|
...
|
|
LL | factorial = Some(Box::new(f));
|
|
| ^^^^^^^^^ `factorial` is assigned to here but it was already borrowed
|
|
|
|
error: aborting due to 4 previous errors
|
|
|
|
Some errors have detailed explanations: E0506, E0597.
|
|
For more information about an error, try `rustc --explain E0506`.
|