From: Jason Merrill Date: Thu, 21 Jul 2016 06:05:58 +0000 (-0400) Subject: PR c++/70781 - ICE on ill-formed lambda. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=172f0e1311f23be40aeb4816f77793dc1317612d;p=gcc.git PR c++/70781 - ICE on ill-formed lambda. * parser.c (cp_parser_lambda_expression): Unset OK if there was an error parsing the lambda-declarator. From-SVN: r238563 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 78487eac174..2e8877faef9 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,5 +1,9 @@ 2016-07-21 Jason Merrill + PR c++/70781 + * parser.c (cp_parser_lambda_expression): Unset OK if there was an + error parsing the lambda-declarator. + PR c++/71896 * constexpr.c (cxx_eval_binary_expression): Handle comparison between lowered and unlowered PTRMEM_CST. diff --git a/gcc/cp/parser.c b/gcc/cp/parser.c index 9bdb1089418..b71b9e5ac42 100644 --- a/gcc/cp/parser.c +++ b/gcc/cp/parser.c @@ -9771,10 +9771,12 @@ cp_parser_lambda_expression (cp_parser* parser) ok &= cp_parser_lambda_declarator_opt (parser, lambda_expr); + if (ok && cp_parser_error_occurred (parser)) + ok = false; + if (ok) { - if (!cp_parser_error_occurred (parser) - && cp_lexer_next_token_is (parser->lexer, CPP_OPEN_BRACE) + if (cp_lexer_next_token_is (parser->lexer, CPP_OPEN_BRACE) && cp_parser_start_tentative_firewall (parser)) start = token; cp_parser_lambda_body (parser, lambda_expr); diff --git a/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-ice16.C b/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-ice16.C new file mode 100644 index 00000000000..e94a0b6fa35 --- /dev/null +++ b/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-ice16.C @@ -0,0 +1,8 @@ +// PR c++/70781 +// { dg-do compile { target c++11 } } + +template < typename T > +void foo () +{ + T ([=] (S) { [=] {}; }); // { dg-error "" } +}