diff options
| author | Tom Jakubowski <tom@crystae.net> | 2014-11-16 18:13:21 -0800 |
|---|---|---|
| committer | Tom Jakubowski <tom@crystae.net> | 2014-11-16 19:10:47 -0800 |
| commit | 8000482e86808f7e36b8d7e595cea7c712d09a6c (patch) | |
| tree | 12fe025ed9a808307804eb2658f9e2a6173cd9c9 | |
| parent | 0b7b4f075a531eb160becf2818c1e9a63fa10cd3 (diff) | |
| download | rust-8000482e86808f7e36b8d7e595cea7c712d09a6c.tar.gz rust-8000482e86808f7e36b8d7e595cea7c712d09a6c.zip | |
Disallow parsing of struct variants with 0 fields
Make struct variant syntax more consistent with struct syntax and fix an assert in middle::typeck. Fix #19003
| -rw-r--r-- | src/libsyntax/parse/parser.rs | 10 | ||||
| -rw-r--r-- | src/test/compile-fail/struct-variant-no-fields.rs | 13 |
2 files changed, 22 insertions, 1 deletions
diff --git a/src/libsyntax/parse/parser.rs b/src/libsyntax/parse/parser.rs index 50e3483fb15..44b7cc8d181 100644 --- a/src/libsyntax/parse/parser.rs +++ b/src/libsyntax/parse/parser.rs @@ -5175,7 +5175,15 @@ impl<'a> Parser<'a> { if self.eat(&token::OpenDelim(token::Brace)) { // Parse a struct variant. all_nullary = false; - kind = StructVariantKind(self.parse_struct_def()); + let start_span = self.span; + let struct_def = self.parse_struct_def(); + if struct_def.fields.len() == 0 { + self.span_err(start_span, + format!("unit-like struct variant should be written \ + without braces, as `{},`", + token::get_ident(ident)).as_slice()); + } + kind = StructVariantKind(struct_def); } else if self.token == token::OpenDelim(token::Paren) { all_nullary = false; let arg_tys = self.parse_enum_variant_seq( diff --git a/src/test/compile-fail/struct-variant-no-fields.rs b/src/test/compile-fail/struct-variant-no-fields.rs new file mode 100644 index 00000000000..41dbbeefc0a --- /dev/null +++ b/src/test/compile-fail/struct-variant-no-fields.rs @@ -0,0 +1,13 @@ +// Copyright 2014 The Rust Project Developers. See the COPYRIGHT +// file at the top-level directory of this distribution and at +// http://rust-lang.org/COPYRIGHT. +// +// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or +// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license +// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +enum Foo { + Bar {} //~ ERROR unit-like struct variant should be written without braces, as `Bar,` +} |
