When encountering a moved value of a type that isn't `Clone` because of unmet obligations, but where all the unmet predicates reference crate-local types, mention them and suggest cloning, as we do in other cases already:
```
error[E0507]: cannot move out of `foo`, a captured variable in an `Fn` closure
--> f111.rs:14:25
|
13 | fn do_stuff(foo: Option<Foo>) {
| --- captured outer variable
14 | require_fn_trait(|| async {
| -- ^^^^^ `foo` is moved here
| |
| captured by this `Fn` closure
15 | if foo.map_or(false, |f| f.foo()) {
| ---
| |
| variable moved due to use in coroutine
| move occurs because `foo` has type `Option<Foo>`, which does not implement the `Copy` trait
|
note: if `Foo` implemented `Clone`, you could clone the value
--> f111.rs:4:1
|
4 | struct Foo;
| ^^^^^^^^^^ consider implementing `Clone` for this type
...
15 | if foo.map_or(false, |f| f.foo()) {
| --- you could clone this value
```
32 lines
1.2 KiB
Plaintext
32 lines
1.2 KiB
Plaintext
error[E0382]: borrow of moved value: `n`
|
|
--> $DIR/use-after-move-implicity-coerced-object.rs:28:13
|
|
|
|
|
LL | let n: Box<_> = Number { n: 42 }.into();
|
|
| - move occurs because `n` has type `Box<Number>`, which does not implement the `Copy` trait
|
|
LL | let mut l: Box<_> = List { list: Vec::new() }.into();
|
|
LL | l.push(n);
|
|
| - value moved here
|
|
LL |
|
|
LL | let x = n.to_string();
|
|
| ^ value borrowed here after move
|
|
|
|
|
note: consider changing this parameter type in method `push` to borrow instead if owning the value isn't necessary
|
|
--> $DIR/use-after-move-implicity-coerced-object.rs:17:27
|
|
|
|
|
LL | fn push(&mut self, n: Box<dyn ToString + 'static>) {
|
|
| ---- ^^^^^^^^^^^^^^^^^^^^^^^^^^^ this parameter takes ownership of the value
|
|
| |
|
|
| in this method
|
|
note: if `Number` implemented `Clone`, you could clone the value
|
|
--> $DIR/use-after-move-implicity-coerced-object.rs:3:1
|
|
|
|
|
LL | struct Number {
|
|
| ^^^^^^^^^^^^^ consider implementing `Clone` for this type
|
|
...
|
|
LL | l.push(n);
|
|
| - you could clone this value
|
|
|
|
error: aborting due to 1 previous error
|
|
|
|
For more information about this error, try `rustc --explain E0382`.
|