From ab6e5f9776002660095b2eb7d29c683215d018d7 Mon Sep 17 00:00:00 2001 From: jason Date: Tue, 19 Jun 2018 00:38:38 +0000 Subject: [PATCH] Use a range for LAMBDA_EXPR_LOCATION. * parser.c (cp_parser_lambda_expression): Use a range for LAMBDA_EXPR_LOCATION. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@261727 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/cp/ChangeLog | 3 +++ gcc/cp/parser.c | 6 ++++++ 2 files changed, 9 insertions(+) diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index a6714762675..3e3b6103832 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,5 +1,8 @@ 2018-06-18 Jason Merrill + * parser.c (cp_parser_lambda_expression): Use a range for + LAMBDA_EXPR_LOCATION. + PR c++/86200 - ICE with unexpanded pack in lambda parameter. * pt.c (find_parameter_packs_r) [LAMBDA_EXPR]: Also look into the function type. diff --git a/gcc/cp/parser.c b/gcc/cp/parser.c index edb0ef8025e..ae9267e6d83 100644 --- a/gcc/cp/parser.c +++ b/gcc/cp/parser.c @@ -10198,6 +10198,12 @@ cp_parser_lambda_expression (cp_parser* parser) /* And now that we're done, push proxies for an enclosing lambda. */ insert_pending_capture_proxies (); + /* Update the lambda expression to a range. */ + cp_token *end_tok = cp_lexer_previous_token (parser->lexer); + LAMBDA_EXPR_LOCATION (lambda_expr) = make_location (token->location, + token->location, + end_tok->location); + if (ok) lambda_expr = build_lambda_object (lambda_expr); else -- 2.11.4.GIT