mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-01-24 10:12:25 -05:00
LibJS: Fix Object::delete_property() with numeric string property
- We have to check if the property name is a string before calling as_string() on it - We can't as_number() the same property name but have to use the parsed index number Fixes #3950.
This commit is contained in:
parent
8d96f428ef
commit
0bb66890c8
Notes:
sideshowbarker
2024-07-19 01:32:50 +09:00
Author: https://github.com/linusg Commit: https://github.com/SerenityOS/serenity/commit/0bb66890c88 Pull-request: https://github.com/SerenityOS/serenity/pull/3952 Issue: https://github.com/SerenityOS/serenity/issues/3950 Reviewed-by: https://github.com/awesomekling
2 changed files with 9 additions and 3 deletions
|
@ -631,9 +631,12 @@ Value Object::delete_property(const PropertyName& property_name)
|
|||
|
||||
if (property_name.is_number())
|
||||
return Value(m_indexed_properties.remove(property_name.as_number()));
|
||||
int property_index = property_name.as_string().to_int().value_or(-1);
|
||||
if (property_index >= 0)
|
||||
return Value(m_indexed_properties.remove(property_name.as_number()));
|
||||
|
||||
if (property_name.is_string()) {
|
||||
i32 property_index = property_name.as_string().to_int().value_or(-1);
|
||||
if (property_index >= 0)
|
||||
return Value(m_indexed_properties.remove(property_index));
|
||||
}
|
||||
|
||||
auto metadata = shape().lookup(property_name.to_string_or_symbol());
|
||||
if (!metadata.has_value())
|
||||
|
|
|
@ -46,6 +46,9 @@ test("deleting array indices", () => {
|
|||
expect(a.hasOwnProperty(1)).toBeFalse();
|
||||
expect(a.hasOwnProperty(2)).toBeFalse();
|
||||
expect(Object.getOwnPropertyNames(a)).toHaveLength(1);
|
||||
|
||||
expect(delete a["42"]).toBeTrue();
|
||||
expect(Object.getOwnPropertyNames(a)).toHaveLength(1);
|
||||
});
|
||||
|
||||
test("deleting non-configurable property", () => {
|
||||
|
|
Loading…
Add table
Reference in a new issue