2022-06-27 22:43:23 +00:00
|
|
|
error[E0507]: cannot move out of `*cb` which is behind a mutable reference
|
|
|
|
--> $DIR/suggest-as-ref-on-mut-closure.rs:7:5
|
|
|
|
|
|
|
|
|
LL | cb.map(|cb| cb());
|
2023-06-22 20:30:23 +00:00
|
|
|
| ^^ -------------- `*cb` moved due to this method call
|
|
|
|
| |
|
2022-08-16 03:02:04 +00:00
|
|
|
| help: consider calling `.as_ref()` or `.as_mut()` to borrow the type's contents
|
2022-06-27 22:43:23 +00:00
|
|
|
| move occurs because `*cb` has type `Option<&mut dyn FnMut()>`, which does not implement the `Copy` trait
|
|
|
|
|
|
2022-12-12 12:07:09 +00:00
|
|
|
note: `Option::<T>::map` takes ownership of the receiver `self`, which moves `*cb`
|
2022-06-27 22:43:23 +00:00
|
|
|
--> $SRC_DIR/core/src/option.rs:LL:COL
|
|
|
|
|
|
|
|
error[E0596]: cannot borrow `*cb` as mutable, as it is behind a `&` reference
|
|
|
|
--> $DIR/suggest-as-ref-on-mut-closure.rs:12:26
|
|
|
|
|
|
|
|
|
LL | cb.as_ref().map(|cb| cb());
|
|
|
|
| -- ^^ `cb` is a `&` reference, so the data it refers to cannot be borrowed as mutable
|
|
|
|
| |
|
2022-06-28 03:23:24 +00:00
|
|
|
| consider changing this binding's type to be: `&mut &mut dyn FnMut()`
|
2022-06-27 22:43:23 +00:00
|
|
|
|
|
|
|
error: aborting due to 2 previous errors
|
|
|
|
|
|
|
|
Some errors have detailed explanations: E0507, E0596.
|
|
|
|
For more information about an error, try `rustc --explain E0507`.
|