rust/tests/ui/moves/move-guard-same-consts.stderr

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

27 lines
990 B
Plaintext
Raw Normal View History

2018-08-08 12:28:26 +00:00
error[E0382]: use of moved value: `x`
2018-12-25 15:56:47 +00:00
--> $DIR/move-guard-same-consts.rs:20:24
2018-08-08 12:28:26 +00:00
|
LL | let x: Box<_> = Box::new(1);
| - move occurs because `x` has type `Box<i32>`, which does not implement the `Copy` trait
...
2018-08-08 12:28:26 +00:00
LL | (1, 2) if take(x) => (),
| - value moved here
2019-03-09 12:03:44 +00:00
LL | (1, 2) if take(x) => (),
2018-08-08 12:28:26 +00:00
| ^ value used here after move
|
note: consider changing this parameter type in function `take` to borrow instead if owning the value isn't necessary
--> $DIR/move-guard-same-consts.rs:25:15
|
LL | fn take<T>(_: T) -> bool { false }
2022-11-03 21:10:08 +00:00
| ---- ^ this parameter takes ownership of the value
| |
| in this function
help: consider cloning the value if the performance cost is acceptable
|
LL | (1, 2) if take(x.clone()) => (),
| ++++++++
2018-08-08 12:28:26 +00:00
error: aborting due to 1 previous error
2018-08-08 12:28:26 +00:00
For more information about this error, try `rustc --explain E0382`.