From d04ff41777d999fe5f387f46ec8b9cb22422c513 Mon Sep 17 00:00:00 2001 From: Marek Polacek Date: Wed, 2 Sep 2015 21:00:38 +0000 Subject: re PR c/67432 (Improve error message on empty enum) PR c/67432 * c-parser.c (c_parser_enum_specifier): Give a better error for an empty enum. * gcc.dg/pr67432.c: New test. From-SVN: r227421 --- gcc/c/ChangeLog | 6 ++++++ gcc/c/c-parser.c | 11 ++++++++++- 2 files changed, 16 insertions(+), 1 deletion(-) (limited to 'gcc/c') diff --git a/gcc/c/ChangeLog b/gcc/c/ChangeLog index 1536b1b..47461d1 100644 --- a/gcc/c/ChangeLog +++ b/gcc/c/ChangeLog @@ -1,3 +1,9 @@ +2015-09-02 Marek Polacek + + PR c/67432 + * c-parser.c (c_parser_enum_specifier): Give a better error for + an empty enum. + 2015-08-18 Trevor Saunders * c-aux-info.c, c-parser.c, c-tree.h: Remove useless typedefs. diff --git a/gcc/c/c-parser.c b/gcc/c/c-parser.c index 1a58798..11a2b0f 100644 --- a/gcc/c/c-parser.c +++ b/gcc/c/c-parser.c @@ -2555,7 +2555,16 @@ c_parser_enum_specifier (c_parser *parser) location_t decl_loc, value_loc; if (c_parser_next_token_is_not (parser, CPP_NAME)) { - c_parser_error (parser, "expected identifier"); + /* Give a nicer error for "enum {}". */ + if (c_parser_next_token_is (parser, CPP_CLOSE_BRACE) + && !parser->error) + { + error_at (c_parser_peek_token (parser)->location, + "empty enum is invalid"); + parser->error = true; + } + else + c_parser_error (parser, "expected identifier"); c_parser_skip_until_found (parser, CPP_CLOSE_BRACE, NULL); values = error_mark_node; break; -- cgit v1.1