LibJS: Don't use presence of function params to identify function scope

Instead, we can just use the scope type to determine if a scope is a
function scope.

This fixes using `this` for parameter default values in arrow functions
crashing. This happened by `uses_this_from_environment` was not set in
`set_uses_this`, as it didn't think it was in a function scope whilst
parsing parameters.

Fixes closing modal dialogs causing a crash on https://www.ikea.com/

No test262 diff.

Reverts the functional part of 08cfd5f, because it was a workaround for
this issue.
This commit is contained in:
Luke Wilde 2025-06-17 15:38:31 +01:00 committed by Jelle Raaijmakers
parent 26105b8b11
commit f12b6b258f
Notes: github-actions[bot] 2025-06-17 18:50:01 +00:00
2 changed files with 22 additions and 3 deletions

View file

@ -223,7 +223,7 @@ public:
ScopePusher const* last_function_scope() const
{
for (auto scope_ptr = this; scope_ptr; scope_ptr = scope_ptr->m_parent_scope) {
if (scope_ptr->m_function_parameters)
if (scope_ptr->m_type == ScopeType::Function || scope_ptr->m_type == ScopeType::ClassStaticInit)
return scope_ptr;
}
return nullptr;
@ -1560,8 +1560,6 @@ NonnullRefPtr<ClassExpression const> Parser::parse_class_expression(bool expect_
{
ScopePusher static_init_scope = ScopePusher::static_init_block_scope(*this, *static_init_block);
static_init_scope.set_function_parameters(FunctionParameters::empty());
parse_statement_list(static_init_block);
}