mirror of
https://github.com/RGBCube/serenity
synced 2025-05-24 01:05:08 +00:00
LibJS: Implement Reflect.{isExtensible,preventExtensions}()
This commit is contained in:
parent
b958e4f573
commit
c1248a7fd8
3 changed files with 62 additions and 8 deletions
|
@ -211,12 +211,12 @@ Value ReflectObject::has(Interpreter& interpreter)
|
|||
return Value(target->has_property(property_key));
|
||||
}
|
||||
|
||||
Value ReflectObject::is_extensible(Interpreter&)
|
||||
Value ReflectObject::is_extensible(Interpreter& interpreter)
|
||||
{
|
||||
// FIXME: For this to be useful we need one of these:
|
||||
// Object.seal(), Object.freeze(), Reflect.preventExtensions()
|
||||
// For now we just return true, as that's always the case.
|
||||
return Value(true);
|
||||
auto* target = get_target_object_from(interpreter, "isExtensible");
|
||||
if (!target)
|
||||
return {};
|
||||
return Value(target->is_extensible());
|
||||
}
|
||||
|
||||
Value ReflectObject::own_keys(Interpreter& interpreter)
|
||||
|
@ -227,10 +227,12 @@ Value ReflectObject::own_keys(Interpreter& interpreter)
|
|||
return target->get_own_properties(*target, GetOwnPropertyMode::Key);
|
||||
}
|
||||
|
||||
Value ReflectObject::prevent_extensions(Interpreter&)
|
||||
Value ReflectObject::prevent_extensions(Interpreter& interpreter)
|
||||
{
|
||||
// FIXME: Implement me :^)
|
||||
ASSERT_NOT_REACHED();
|
||||
auto* target = get_target_object_from(interpreter, "preventExtensions");
|
||||
if (!target)
|
||||
return {};
|
||||
return Value(target->prevent_extensions());
|
||||
}
|
||||
|
||||
Value ReflectObject::set(Interpreter& interpreter)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue