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 } => {},
| ++++++++
```
20 lines
790 B
Plaintext
20 lines
790 B
Plaintext
error[E0597]: `local_arr` does not live long enough
|
|
--> $DIR/propagate-multiple-requirements.rs:15:14
|
|
|
|
|
LL | let local_arr = other_local_arr;
|
|
| --------- binding `local_arr` declared here
|
|
LL | let mut out: &mut &'static [i32] = &mut (&[1] as _);
|
|
| ------------------- type annotation requires that `local_arr` is borrowed for `'static`
|
|
LL | once(|mut z: &[i32], mut out_val: &mut &[i32]| {
|
|
| ----------------------------------------- value captured here
|
|
...
|
|
LL | z = &local_arr;
|
|
| ^^^^^^^^^ borrowed value does not live long enough
|
|
...
|
|
LL | }
|
|
| - `local_arr` dropped here while still borrowed
|
|
|
|
error: aborting due to 1 previous error
|
|
|
|
For more information about this error, try `rustc --explain E0597`.
|