about summary refs log tree commit diff
diff options
context:
space:
mode:
authorMazdak Farrokhzad <twingoow@gmail.com>2019-06-09 06:13:11 +0200
committerMazdak Farrokhzad <twingoow@gmail.com>2019-06-15 19:18:09 +0200
commitce48086293e63532fb33584be2c2ea5d67cd1498 (patch)
tree65aca22248f05c2acbeed9addf695f9f4dadc2cc
parent86c74d3a86c2c001e4c1b9b8876f0ca474ae1a82 (diff)
downloadrust-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.rs21
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);
 }