rust/src/test/ui/rfc-2008-non-exhaustive/struct.rs
David Wood 3a88cd7778
Implement #[non_exhaustive] on variants.
This commit removes the check that disallows the `#[non_exhaustive]`
attribute from being placed on enum variants and removes the associated
tests.

Further, this commit lowers the visibility of enum variant constructors
when the variant is marked as non-exhaustive.
2019-03-28 22:29:02 +01:00

50 lines
1.6 KiB
Rust

// 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 expected function, found struct `TupleStruct` [E0423]
let ts_explicit = structs::TupleStruct(640, 480);
//~^ ERROR tuple struct `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;
}