diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-17 12:19:03 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-17 12:19:03 +0000 |
commit | 64d98f8ee037282c35007b64c2649055c56af1db (patch) | |
tree | 5492bcf97fce41ee1c0b1cc2add283f3e66cdab0 /src/test/ui/unsafe/union_destructure.rs | |
parent | Adding debian version 1.67.1+dfsg1-1. (diff) | |
download | rustc-64d98f8ee037282c35007b64c2649055c56af1db.tar.xz rustc-64d98f8ee037282c35007b64c2649055c56af1db.zip |
Merging upstream version 1.68.2+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/test/ui/unsafe/union_destructure.rs')
-rw-r--r-- | src/test/ui/unsafe/union_destructure.rs | 51 |
1 files changed, 0 insertions, 51 deletions
diff --git a/src/test/ui/unsafe/union_destructure.rs b/src/test/ui/unsafe/union_destructure.rs deleted file mode 100644 index 6c88344b5..000000000 --- a/src/test/ui/unsafe/union_destructure.rs +++ /dev/null @@ -1,51 +0,0 @@ -// run-pass -// revisions: mir thir -// [thir]compile-flags: -Z thir-unsafeck - -#[derive(Copy, Clone)] -#[allow(dead_code)] -struct Pie { - slices: u8, - size: u8, -} - -union Foo { - #[allow(dead_code)] - bar: i8, - baz: Pie -} - -fn main() { - let u = Foo { bar: 5 }; - let (Some(Foo { bar: _ }) | None) = Some(u); - let u = Foo { bar: 6 }; - let (Some(Foo { bar: _ }) | Some(Foo { bar: _ }) | None) = Some(u); - unsafe { - let u = Foo { bar: 7 }; - let (Foo { bar } | Foo { bar }) = u; - assert_eq!(bar, 7) - } - let u = Foo { bar: 8 }; - match Some(u) { - Some(Foo { bar: _ }) => 3, - None => 4, - }; - - let u = Foo { bar: 9 }; - unsafe { //[mir]~ WARNING unnecessary `unsafe` block - match u { - Foo { baz: Pie { .. } } => {}, - }; - } - let u = Foo { bar: 10 }; - unsafe { //[mir]~ WARNING unnecessary `unsafe` block - match u { - Foo { baz: Pie { slices: _, size: _ } } => {}, - }; - } - - let u = Foo { bar: 11 }; - match u { - Foo { baz: _ } => {}, - }; -} |