From b9c1533fa97c3088c082239744b23de5029f28cd Mon Sep 17 00:00:00 2001 From: Vadim Zhestikov Date: Fri, 26 May 2023 19:43:24 -0700 Subject: [PATCH] Fixed parsing of for-in loops. This fixes parsing for input like: for (a(b * in d) ; The issue was introduced in 283ae119d121 (0.7.9). --- src/njs_parser.c | 33 +++++++++++++++++++++++++-------- src/test/njs_unit_test.c | 6 ++++++ 2 files changed, 31 insertions(+), 8 deletions(-) diff --git a/src/njs_parser.c b/src/njs_parser.c index a9b8f924..5bf7316e 100644 --- a/src/njs_parser.c +++ b/src/njs_parser.c @@ -294,7 +294,10 @@ static njs_int_t njs_parser_while_after(njs_parser_t *parser, static njs_int_t njs_parser_iteration_statement_for(njs_parser_t *parser, njs_lexer_token_t *token, njs_queue_link_t *current); -static njs_int_t njs_parser_for_left_hand_side_expression_map( +static njs_int_t njs_parser_for_expression_map_continue( + njs_parser_t *parser, njs_lexer_token_t *token, + njs_queue_link_t *current); +static njs_int_t njs_parser_for_expression_map_reparse( njs_parser_t *parser, njs_lexer_token_t *token, njs_queue_link_t *current); static njs_int_t njs_parser_expression_continue_op(njs_parser_t *parser, @@ -5488,12 +5491,10 @@ njs_parser_iteration_statement_for(njs_parser_t *parser, static njs_int_t -njs_parser_for_left_hand_side_expression_map(njs_parser_t *parser, +njs_parser_for_expression_map_reparse(njs_parser_t *parser, njs_lexer_token_t *token, njs_queue_link_t *current) { - njs_int_t operation; - njs_str_t *text; - njs_parser_node_t *node; + njs_str_t *text; if (parser->node == NULL) { njs_lexer_in_fail_set(parser->lexer, 1); @@ -5514,9 +5515,20 @@ njs_parser_for_left_hand_side_expression_map(njs_parser_t *parser, return njs_parser_after(parser, current, text, 1, njs_parser_for_var_in_of_expression); - } + return njs_parser_stack_pop(parser); +} + + +static njs_int_t +njs_parser_for_expression_map_continue(njs_parser_t *parser, + njs_lexer_token_t *token, njs_queue_link_t *current) +{ + njs_int_t operation; + njs_str_t *text; + njs_parser_node_t *node; + if (token->type != NJS_TOKEN_IN) { njs_lexer_in_fail_set(parser->lexer, 1); @@ -5575,7 +5587,6 @@ njs_parser_for_left_hand_side_expression_map(njs_parser_t *parser, return njs_parser_after(parser, current, node, 0, njs_parser_for_in_statement_statement); } - } @@ -5766,8 +5777,14 @@ njs_parser_iteration_statement_for_map(njs_parser_t *parser, *text = token->text; + ret = njs_parser_after(parser, current, text, 1, + njs_parser_for_expression_map_continue); + if (ret != NJS_OK) { + return NJS_ERROR; + } + return njs_parser_after(parser, current, text, 0, - njs_parser_for_left_hand_side_expression_map); + njs_parser_for_expression_map_reparse); } expression_after: diff --git a/src/test/njs_unit_test.c b/src/test/njs_unit_test.c index f8a83e40..16deae14 100644 --- a/src/test/njs_unit_test.c +++ b/src/test/njs_unit_test.c @@ -2963,6 +2963,12 @@ static njs_unit_test_t njs_test[] = { njs_str("for(A?{,"), njs_str("SyntaxError: Unexpected token \",\" in 1") }, + { njs_str("for(Symbol(A=>A+ in 'A') P/$"), + njs_str("SyntaxError: Unexpected token \"in\" in 1") }, + + { njs_str("for (a(b * in d) ;"), + njs_str("SyntaxError: Unexpected token \"in\" in 1") }, + /* switch. */ { njs_str("switch"), -- 2.47.3