aboutsummaryrefslogtreecommitdiff
path: root/gcc/cp
diff options
context:
space:
mode:
authorAdam Butcher <adam@jessamine.co.uk>2014-03-08 09:33:03 +0000
committerAdam Butcher <abutcher@gcc.gnu.org>2014-03-08 09:33:03 +0000
commit14e62702520cd5fc0907e1d777ee1ae6dfabd582 (patch)
treea6678262c6c2efdbb57c446e8cc7c23f56d12783 /gcc/cp
parentbd65fc87824ef69e69c6e79cd1323b43b77e0866 (diff)
downloadgcc-14e62702520cd5fc0907e1d777ee1ae6dfabd582.zip
gcc-14e62702520cd5fc0907e1d777ee1ae6dfabd582.tar.gz
gcc-14e62702520cd5fc0907e1d777ee1ae6dfabd582.tar.bz2
re PR c++/60393 ([c++1y] ICE with with invalid functions with auto parameters)
Fix PR c++/60393 PR c++/60393 * parser.c (cp_parser_parameter_declaration_clause): Move generic function template unwinding on error into a more general location, ... (cp_parser_skip_to_end_of_statement): ... here. PR c++/60393 * g++.dg/cpp1y/pr60393.C: New testcase. From-SVN: r208426
Diffstat (limited to 'gcc/cp')
-rw-r--r--gcc/cp/ChangeLog7
-rw-r--r--gcc/cp/parser.c11
2 files changed, 12 insertions, 6 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index 83a3585..07ac2b2 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,3 +1,10 @@
+2014-03-08 Adam Butcher <adam@jessamine.co.uk>
+
+ PR c++/60393
+ * parser.c (cp_parser_parameter_declaration_clause): Move generic
+ function template unwinding on error into a more general location, ...
+ (cp_parser_skip_to_end_of_statement): ... here.
+
2014-03-07 Jason Merrill <jason@redhat.com>
* Make-lang.in (check_g++_parallelize): Split dg.exp.
diff --git a/gcc/cp/parser.c b/gcc/cp/parser.c
index 5725283..64583ba 100644
--- a/gcc/cp/parser.c
+++ b/gcc/cp/parser.c
@@ -3136,6 +3136,10 @@ cp_parser_skip_to_end_of_statement (cp_parser* parser)
{
unsigned nesting_depth = 0;
+ /* Unwind generic function template scope if necessary. */
+ if (parser->fully_implicit_function_template_p)
+ finish_fully_implicit_template (parser, /*member_decl_opt=*/0);
+
while (true)
{
cp_token *token = cp_lexer_peek_token (parser->lexer);
@@ -18242,12 +18246,7 @@ cp_parser_parameter_declaration_clause (cp_parser* parser)
parameter-declaration-list, then the entire
parameter-declaration-clause is erroneous. */
if (is_error)
- {
- /* Unwind generic function template scope if necessary. */
- if (parser->fully_implicit_function_template_p)
- finish_fully_implicit_template (parser, /*member_decl_opt=*/0);
- return NULL;
- }
+ return NULL;
/* Peek at the next token. */
token = cp_lexer_peek_token (parser->lexer);