summaryrefslogtreecommitdiffstats
path: root/tests/ui/rfc-2008-non-exhaustive/struct.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-30 03:57:31 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-30 03:57:31 +0000
commitdc0db358abe19481e475e10c32149b53370f1a1c (patch)
treeab8ce99c4b255ce46f99ef402c27916055b899ee /tests/ui/rfc-2008-non-exhaustive/struct.rs
parentReleasing progress-linux version 1.71.1+dfsg1-2~progress7.99u1. (diff)
downloadrustc-dc0db358abe19481e475e10c32149b53370f1a1c.tar.xz
rustc-dc0db358abe19481e475e10c32149b53370f1a1c.zip
Merging upstream version 1.72.1+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'tests/ui/rfc-2008-non-exhaustive/struct.rs')
-rw-r--r--tests/ui/rfc-2008-non-exhaustive/struct.rs49
1 files changed, 0 insertions, 49 deletions
diff --git a/tests/ui/rfc-2008-non-exhaustive/struct.rs b/tests/ui/rfc-2008-non-exhaustive/struct.rs
deleted file mode 100644
index 07e093c15..000000000
--- a/tests/ui/rfc-2008-non-exhaustive/struct.rs
+++ /dev/null
@@ -1,49 +0,0 @@
-// aux-build:structs.rs
-extern crate structs;
-
-use structs::{NormalStruct, UnitStruct, TupleStruct, FunctionalRecord};
-
-fn main() {
- let fr = FunctionalRecord {
- //~^ ERROR cannot create non-exhaustive struct
- first_field: 1920,
- second_field: 1080,
- ..FunctionalRecord::default()
- };
-
- let ns = NormalStruct { first_field: 640, second_field: 480 };
- //~^ ERROR cannot create non-exhaustive struct
-
- let NormalStruct { first_field, second_field } = ns;
- //~^ ERROR `..` required with struct marked as non-exhaustive
-
- let ts = TupleStruct(640, 480);
- //~^ ERROR cannot initialize a tuple struct which contains private fields [E0423]
-
- let ts_explicit = structs::TupleStruct(640, 480);
- //~^ ERROR tuple struct constructor `TupleStruct` is private [E0603]
-
- let TupleStruct { 0: first_field, 1: second_field } = ts;
- //~^ ERROR `..` required with struct marked as non-exhaustive
-
- let us = UnitStruct;
- //~^ ERROR expected value, found struct `UnitStruct` [E0423]
-
- let us_explicit = structs::UnitStruct;
- //~^ ERROR unit struct `UnitStruct` is private [E0603]
-
- let UnitStruct { } = us;
- //~^ ERROR `..` required with struct marked as non-exhaustive
-}
-
-// Everything below this is expected to compile successfully.
-
-// We only test matching here as we cannot create non-exhaustive
-// structs from another crate. ie. they'll never pass in run-pass tests.
-fn match_structs(ns: NormalStruct, ts: TupleStruct, us: UnitStruct) {
- let NormalStruct { first_field, second_field, .. } = ns;
-
- let TupleStruct { 0: first, 1: second, .. } = ts;
-
- let UnitStruct { .. } = us;
-}