Fix arrow function parsing (#5093)

This fixes #5085

JerryScript-DCO-1.0-Signed-off-by: Máté Tokodi mate.tokodi@szteszoftver.hu
This commit is contained in:
Máté Tokodi
2024-02-01 00:34:37 +01:00
committed by GitHub
parent 514fa6735a
commit 52debe8589
2 changed files with 24 additions and 1 deletions
+7 -1
View File
@@ -2829,6 +2829,7 @@ parser_parse_arrow_function (parser_context_t *context_p, /**< context */
JERRY_ASSERT (context_p->token.type == LEXER_ARROW);
lexer_next_token (context_p);
bool next_token_needed = false;
if (context_p->token.type == LEXER_LEFT_BRACE)
{
@@ -2839,7 +2840,7 @@ parser_parse_arrow_function (parser_context_t *context_p, /**< context */
/* Unlike normal function, arrow functions consume their close brace. */
JERRY_ASSERT (context_p->token.type == LEXER_RIGHT_BRACE);
lexer_next_token (context_p);
next_token_needed = true;
}
else
{
@@ -2878,6 +2879,11 @@ parser_parse_arrow_function (parser_context_t *context_p, /**< context */
parser_restore_context (context_p, &saved_context);
if (next_token_needed)
{
lexer_next_token (context_p);
}
return compiled_code_p;
} /* parser_parse_arrow_function */