mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-09-11 12:06:07 +00:00
LibJS/Bytecode: Don't choke on MemberExpression with PrivateIdentifier
This commit is contained in:
parent
d063f35afd
commit
8a3e350321
Notes:
sideshowbarker
2024-07-17 06:51:40 +09:00
Author: https://github.com/awesomekling
Commit: 8a3e350321
Pull-request: https://github.com/SerenityOS/serenity/pull/19408
Issue: https://github.com/SerenityOS/serenity/issues/15210
2 changed files with 8 additions and 1 deletions
|
@ -3289,6 +3289,8 @@ DeprecatedString MemberExpression::to_string_approximation() const
|
|||
object_string = static_cast<Identifier const&>(*m_object).string();
|
||||
if (is_computed())
|
||||
return DeprecatedString::formatted("{}[<computed>]", object_string);
|
||||
if (is<PrivateIdentifier>(*m_property))
|
||||
return DeprecatedString::formatted("{}.{}", object_string, verify_cast<PrivateIdentifier>(*m_property).string());
|
||||
return DeprecatedString::formatted("{}.{}", object_string, verify_cast<Identifier>(*m_property).string());
|
||||
}
|
||||
|
||||
|
|
|
@ -1357,7 +1357,12 @@ Bytecode::CodeGenerationErrorOr<void> CallExpression::generate_bytecode(Bytecode
|
|||
TRY(member_expression.property().generate_bytecode(generator));
|
||||
generator.emit<Bytecode::Op::GetByValue>(this_reg);
|
||||
} else {
|
||||
auto identifier_table_ref = generator.intern_identifier(verify_cast<Identifier>(member_expression.property()).string());
|
||||
auto identifier_table_ref = [&] {
|
||||
if (is<PrivateIdentifier>(member_expression.property()))
|
||||
return generator.intern_identifier(verify_cast<PrivateIdentifier>(member_expression.property()).string());
|
||||
return generator.intern_identifier(verify_cast<Identifier>(member_expression.property()).string());
|
||||
}();
|
||||
|
||||
generator.emit<Bytecode::Op::GetById>(identifier_table_ref);
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue