]> git.lizzy.rs Git - rust.git/commitdiff
accept union inside enum if not followed by identifier
authorKamlesh Kumar <kamleshbhalui@gmail.com>
Fri, 6 Dec 2019 05:22:28 +0000 (10:52 +0530)
committerKamlesh Kumar <kamleshbhalui@gmail.com>
Fri, 6 Dec 2019 05:22:28 +0000 (10:52 +0530)
src/librustc_parse/parser/item.rs
src/test/ui/enum/union-in-enum.rs [new file with mode: 0644]

index ccf78e6402b3c06c789384c4f763c5a85640d25f..c3e5b39635f03530c14a878cf80486c3bbee8db2 100644 (file)
@@ -1727,9 +1727,10 @@ fn report_invalid_macro_expansion_item(&self) {
     /// Checks if current token is one of tokens which cannot be nested like `kw::Enum`. In case
     /// it is, we try to parse the item and report error about nested types.
     fn recover_nested_adt_item(&mut self, keyword: Symbol) -> PResult<'a, bool> {
-        if self.token.is_keyword(kw::Enum) ||
+        if (self.token.is_keyword(kw::Enum) ||
             self.token.is_keyword(kw::Struct) ||
-            self.token.is_keyword(kw::Union)
+            self.token.is_keyword(kw::Union))
+           && self.look_ahead(1, |t| t.is_ident())
         {
             let kw_token = self.token.clone();
             let kw_str = pprust::token_to_string(&kw_token);
diff --git a/src/test/ui/enum/union-in-enum.rs b/src/test/ui/enum/union-in-enum.rs
new file mode 100644 (file)
index 0000000..048913e
--- /dev/null
@@ -0,0 +1,13 @@
+// This test checks that the union keyword
+// is accepted as the name of an enum variant
+// when not followed by an identifier
+// This special case exists because `union` is a contextual keyword.
+
+#![allow(warnings)]
+
+// check-pass
+
+enum A { union }
+enum B { union {} }
+enum C { union() }
+fn main(){}