about summary refs log tree commit diff
path: root/compiler/rustc_parse/src/parser
diff options
context:
space:
mode:
authorObei Sideg <obei.sideg@gmail.com>2022-07-27 02:07:07 +0300
committerObei Sideg <obei.sideg@gmail.com>2022-07-29 13:56:54 +0300
commit254b89d209eccf4b5a5fd835db1089e1a814eef9 (patch)
tree5656eb10974fee34b7a1d6d16d103e0fdf42cfb1 /compiler/rustc_parse/src/parser
parentc11207ec89b856164bba03b8ecfe07b0b234ed21 (diff)
downloadrust-254b89d209eccf4b5a5fd835db1089e1a814eef9.tar.gz
rust-254b89d209eccf4b5a5fd835db1089e1a814eef9.zip
Recover from c++ style `enum struct`
new error message: `enum` and `struct` are mutually exclusive
new suggestion: replace `enum struct` with `enum`
Diffstat (limited to 'compiler/rustc_parse/src/parser')
-rw-r--r--compiler/rustc_parse/src/parser/item.rs19
1 files changed, 19 insertions, 0 deletions
diff --git a/compiler/rustc_parse/src/parser/item.rs b/compiler/rustc_parse/src/parser/item.rs
index 87bc0d9762e..58203a6fbe3 100644
--- a/compiler/rustc_parse/src/parser/item.rs
+++ b/compiler/rustc_parse/src/parser/item.rs
@@ -1216,6 +1216,25 @@ impl<'a> Parser<'a> {
 
     /// Parses an enum declaration.
     fn parse_item_enum(&mut self) -> PResult<'a, ItemInfo> {
+        if self.token.is_keyword(kw::Struct) {
+            let mut err = self.struct_span_err(
+                self.prev_token.span.to(self.token.span),
+                "`enum` and `struct` are mutually exclusive",
+            );
+            err.span_suggestion(
+                self.prev_token.span.to(self.token.span),
+                "replace `enum struct` with",
+                "enum",
+                Applicability::MachineApplicable,
+            );
+            if self.look_ahead(1, |t| t.is_ident()) {
+                self.bump();
+                err.emit();
+            } else {
+                return Err(err);
+            }
+        }
+
         let id = self.parse_ident()?;
         let mut generics = self.parse_generics()?;
         generics.where_clause = self.parse_where_clause()?;