diff options
| author | cyrgani <ansgar.w.zielke@gmail.com> | 2025-09-22 22:02:24 +0200 |
|---|---|---|
| committer | cyrgani <ansgar.w.zielke@gmail.com> | 2025-09-22 22:02:24 +0200 |
| commit | 60f60127e79672953eb1ccd1ba48a518cd05224d (patch) | |
| tree | 40af81c3b100e3d9a40e930465a3aadddfd21c5b | |
| parent | 9f32ccf35fb877270bc44a86a126440f04d676d0 (diff) | |
| download | rust-60f60127e79672953eb1ccd1ba48a518cd05224d.tar.gz rust-60f60127e79672953eb1ccd1ba48a518cd05224d.zip | |
add regression test for issue 146537
| -rw-r--r-- | tests/ui/suggestions/non_copy_move_out_of_tuple.rs | 8 | ||||
| -rw-r--r-- | tests/ui/suggestions/non_copy_move_out_of_tuple.stderr | 26 |
2 files changed, 34 insertions, 0 deletions
diff --git a/tests/ui/suggestions/non_copy_move_out_of_tuple.rs b/tests/ui/suggestions/non_copy_move_out_of_tuple.rs new file mode 100644 index 00000000000..baf15dba33a --- /dev/null +++ b/tests/ui/suggestions/non_copy_move_out_of_tuple.rs @@ -0,0 +1,8 @@ +// Regression test for #146537. + +struct NonCopy; +fn main() { + let tuple = &(NonCopy,); + let b: NonCopy; + (b,) = *tuple; //~ ERROR: cannot move out of `tuple.0` which is behind a shared reference [E0507] +} diff --git a/tests/ui/suggestions/non_copy_move_out_of_tuple.stderr b/tests/ui/suggestions/non_copy_move_out_of_tuple.stderr new file mode 100644 index 00000000000..62f24324fcc --- /dev/null +++ b/tests/ui/suggestions/non_copy_move_out_of_tuple.stderr @@ -0,0 +1,26 @@ +error[E0507]: cannot move out of `tuple.0` which is behind a shared reference + --> $DIR/non_copy_move_out_of_tuple.rs:7:12 + | +LL | (b,) = *tuple; + | - ^^^^^^ + | | + | data moved here + | move occurs because the place has type `NonCopy`, which does not implement the `Copy` trait + | +note: if `NonCopy` implemented `Clone`, you could clone the value + --> $DIR/non_copy_move_out_of_tuple.rs:3:1 + | +LL | struct NonCopy; + | ^^^^^^^^^^^^^^ consider implementing `Clone` for this type +... +LL | (b,) = *tuple; + | - you could clone this value +help: consider removing the dereference here + | +LL - (b,) = *tuple; +LL + (b,) = tuple; + | + +error: aborting due to 1 previous error + +For more information about this error, try `rustc --explain E0507`. |
