diff options
| author | Mazdak Farrokhzad <twingoow@gmail.com> | 2019-06-09 06:13:11 +0200 |
|---|---|---|
| committer | Mazdak Farrokhzad <twingoow@gmail.com> | 2019-06-15 19:18:09 +0200 |
| commit | ce48086293e63532fb33584be2c2ea5d67cd1498 (patch) | |
| tree | 65aca22248f05c2acbeed9addf695f9f4dadc2cc | |
| parent | 86c74d3a86c2c001e4c1b9b8876f0ca474ae1a82 (diff) | |
| download | rust-ce48086293e63532fb33584be2c2ea5d67cd1498.tar.gz rust-ce48086293e63532fb33584be2c2ea5d67cd1498.zip | |
enum-variant-generic-args-pats-pass: harden + describe.
| -rw-r--r-- | src/test/ui/type-alias-enum-variants/enum-variant-generic-args-pats-pass.rs | 21 |
1 files changed, 20 insertions, 1 deletions
diff --git a/src/test/ui/type-alias-enum-variants/enum-variant-generic-args-pats-pass.rs b/src/test/ui/type-alias-enum-variants/enum-variant-generic-args-pats-pass.rs index faef1fab879..af05dd1b715 100644 --- a/src/test/ui/type-alias-enum-variants/enum-variant-generic-args-pats-pass.rs +++ b/src/test/ui/type-alias-enum-variants/enum-variant-generic-args-pats-pass.rs @@ -1,15 +1,23 @@ // run-pass +// Check that resolving, in the value namespace, to an `enum` variant +// through a type alias is well behaved in the presence of generics. +// We check for situations with: +// 1. a generic type `Alias<T>`, we can type-apply `Alias` when referring to a variant. +// 2. a monotype `AliasFixed` of generic `Enum<T>`, we can refer to variants +// and the type-application of `T` in `AliasFixed` is kept. + #![allow(irrefutable_let_patterns)] #[allow(dead_code)] -enum Enum<T> { TSVariant(T), SVariant { v: T } } +enum Enum<T> { TSVariant(T), SVariant { v: T }, UVariant } type Alias<T> = Enum<T>; type AliasFixed = Enum<()>; macro_rules! is_variant { (TSVariant, $expr:expr) => (is_variant!(@check TSVariant, (_), $expr)); (SVariant, $expr:expr) => (is_variant!(@check SVariant, { v: _ }, $expr)); + (UVariant, $expr:expr) => (is_variant!(@check UVariant, {}, $expr)); (@check $variant:ident, $matcher:tt, $expr:expr) => ( assert!(if let Enum::$variant::<()> $matcher = $expr { true } else { false }, "expr does not have correct type"); @@ -38,4 +46,15 @@ fn main() { is_variant!(SVariant, Alias::<()>::SVariant { v: () }); is_variant!(SVariant, AliasFixed::SVariant { v: () }); + + // Unit variant + + is_variant!(UVariant, Enum::UVariant); + is_variant!(UVariant, Enum::UVariant::<()>); + is_variant!(UVariant, Enum::<()>::UVariant); + + is_variant!(UVariant, Alias::UVariant); + is_variant!(UVariant, Alias::<()>::UVariant); + + is_variant!(UVariant, AliasFixed::UVariant); } |
