diff options
author | Mark Mitchell <mark@codesourcery.com> | 2004-12-22 03:34:55 +0000 |
---|---|---|
committer | Mark Mitchell <mmitchel@gcc.gnu.org> | 2004-12-22 03:34:55 +0000 |
commit | 943e3eded2ab29d35a266cb0d7bfcbda9d96e038 (patch) | |
tree | 3c4219827d7473d470169c52b58780a7e3078422 /gcc/cp/parser.c | |
parent | be99edf8839b914004bc3f96f5acdc515198db86 (diff) | |
download | gcc-943e3eded2ab29d35a266cb0d7bfcbda9d96e038.zip gcc-943e3eded2ab29d35a266cb0d7bfcbda9d96e038.tar.gz gcc-943e3eded2ab29d35a266cb0d7bfcbda9d96e038.tar.bz2 |
re PR c++/18378 (ICE when returning a copy of a packed member)
PR c++/18378
* call.c (convert_like_real): Do not permit the use of a copy
constructor to copy a packed field.
PR c++/17413
* decl.c (grokdeclarator): Return error_mark_node, not
void_type_node, to indicate errors.
* parser.c (cp_parser_template_parameter_list): Robustify.
(cp_parser_template_parameter): Likewise.
PR c++/19034
* tree.c (cp_tree_equal): Handle OVERLOAD.
PR c++/18378
* g++.dg/ext/packed8.C: New test.
PR c++/13268
* g++.dg/template/crash31.C: New test.
PR c++/19034
* g++.dg/template/crash30.C: New test.
From-SVN: r92486
Diffstat (limited to 'gcc/cp/parser.c')
-rw-r--r-- | gcc/cp/parser.c | 28 |
1 files changed, 16 insertions, 12 deletions
diff --git a/gcc/cp/parser.c b/gcc/cp/parser.c index dc650d4..5654f11 100644 --- a/gcc/cp/parser.c +++ b/gcc/cp/parser.c @@ -8016,9 +8016,10 @@ cp_parser_template_parameter_list (cp_parser* parser) /* Parse the template-parameter. */ parameter = cp_parser_template_parameter (parser, &is_non_type); /* Add it to the list. */ - parameter_list = process_template_parm (parameter_list, - parameter, - is_non_type); + if (parameter != error_mark_node) + parameter_list = process_template_parm (parameter_list, + parameter, + is_non_type); /* Peek at the next token. */ token = cp_lexer_peek_token (parser->lexer); /* If it's not a `,', we're done. */ @@ -8037,15 +8038,17 @@ cp_parser_template_parameter_list (cp_parser* parser) type-parameter parameter-declaration - Returns a TREE_LIST. The TREE_VALUE represents the parameter. The - TREE_PURPOSE is the default value, if any. *IS_NON_TYPE is set to - true iff this parameter is a non-type parameter. */ + If all goes well, returns a TREE_LIST. The TREE_VALUE represents + the parameter. The TREE_PURPOSE is the default value, if any. + Returns ERROR_MARK_NODE on failure. *IS_NON_TYPE is set to true + iff this parameter is a non-type parameter. */ static tree cp_parser_template_parameter (cp_parser* parser, bool *is_non_type) { cp_token *token; cp_parameter_declarator *parameter_declarator; + tree parm; /* Assume it is a type parameter or a template parameter. */ *is_non_type = false; @@ -8094,12 +8097,13 @@ cp_parser_template_parameter (cp_parser* parser, bool *is_non_type) parameter_declarator = cp_parser_parameter_declaration (parser, /*template_parm_p=*/true, /*parenthesized_p=*/NULL); - return (build_tree_list - (parameter_declarator->default_argument, - grokdeclarator (parameter_declarator->declarator, - ¶meter_declarator->decl_specifiers, - PARM, /*initialized=*/0, - /*attrlist=*/NULL))); + parm = grokdeclarator (parameter_declarator->declarator, + ¶meter_declarator->decl_specifiers, + PARM, /*initialized=*/0, + /*attrlist=*/NULL); + if (parm == error_mark_node) + return error_mark_node; + return build_tree_list (parameter_declarator->default_argument, parm); } /* Parse a type-parameter. |