diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index eff52c90e81..4ad1c6e6cec 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2004-12-02 Kriang Lerdsuwanakij + + PR c++/18123 + * parser.c (cp_parser_type_specifier): Catch template declaration + of enum. + 2004-12-01 Matt Austern * name-lookup.c (namespace_binding): Omit alias check for global namespace. diff --git a/gcc/cp/parser.c b/gcc/cp/parser.c index 3e25076f075..51b8f100b34 100644 --- a/gcc/cp/parser.c +++ b/gcc/cp/parser.c @@ -9130,7 +9130,15 @@ cp_parser_type_specifier (cp_parser* parser, && cp_lexer_peek_nth_token (parser->lexer, 3)->type == CPP_OPEN_BRACE)) { - type_spec = cp_parser_enum_specifier (parser); + if (parser->num_template_parameter_lists) + { + error ("template declaration of %qs", "enum"); + cp_parser_skip_to_end_of_block_or_statement (parser); + type_spec = error_mark_node; + } + else + type_spec = cp_parser_enum_specifier (parser); + if (declares_class_or_enum) *declares_class_or_enum = 2; if (decl_specs) diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 7842f6326e8..84eae74e3ce 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,9 @@ +2004-12-02 Kriang Lerdsuwanakij + + PR c++/18123 + * g++.dg/parse/enum2.C: New test. + * g++.old-deja/g++.pt/enum5.C: Adjust error location. + 2004-12-02 Nick Clifton * gcc.target/xstormy16: New test directory. diff --git a/gcc/testsuite/g++.dg/parse/enum2.C b/gcc/testsuite/g++.dg/parse/enum2.C new file mode 100644 index 00000000000..f29d3b569d5 --- /dev/null +++ b/gcc/testsuite/g++.dg/parse/enum2.C @@ -0,0 +1,7 @@ +// { dg-do compile } + +// Origin: Volker Reichelt + +// PR c++/18123: ICE pushing tag from invalid template. + +template enum E { e }; // { dg-error "template declaration" } diff --git a/gcc/testsuite/g++.old-deja/g++.pt/enum5.C b/gcc/testsuite/g++.old-deja/g++.pt/enum5.C index a7c5ea3e562..d4eea4f9bff 100644 --- a/gcc/testsuite/g++.old-deja/g++.pt/enum5.C +++ b/gcc/testsuite/g++.old-deja/g++.pt/enum5.C @@ -1,4 +1,4 @@ // { dg-do assemble } -template <> -enum E {e}; // { dg-error "" } template declaration of enum +template <> // { dg-error "" } template declaration of enum +enum E {e};