diff options
author | Idan Horowitz <idan.horowitz@gmail.com> | 2021-06-12 17:38:34 +0300 |
---|---|---|
committer | Linus Groh <mail@linusgroh.de> | 2021-06-12 18:39:23 +0100 |
commit | 7eba63a8a30aa155c13bd2b475294c3f327fa9a1 (patch) | |
tree | 9b73a27dbc7e1f47d800d151879672985cda3c71 /Userland/Libraries/LibJS/Runtime/WeakRefConstructor.cpp | |
parent | 6913f06b6f8c58be771caa5af155d775e570aa73 (diff) | |
download | serenity-7eba63a8a30aa155c13bd2b475294c3f327fa9a1.zip |
LibJS: Add the WeakRef built-in object
Diffstat (limited to 'Userland/Libraries/LibJS/Runtime/WeakRefConstructor.cpp')
-rw-r--r-- | Userland/Libraries/LibJS/Runtime/WeakRefConstructor.cpp | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/Userland/Libraries/LibJS/Runtime/WeakRefConstructor.cpp b/Userland/Libraries/LibJS/Runtime/WeakRefConstructor.cpp new file mode 100644 index 0000000000..6940580ecc --- /dev/null +++ b/Userland/Libraries/LibJS/Runtime/WeakRefConstructor.cpp @@ -0,0 +1,52 @@ +/* + * Copyright (c) 2021, Idan Horowitz <idan.horowitz@serenityos.org> + * + * SPDX-License-Identifier: BSD-2-Clause + */ + +#include <LibJS/Runtime/Error.h> +#include <LibJS/Runtime/GlobalObject.h> +#include <LibJS/Runtime/WeakRef.h> +#include <LibJS/Runtime/WeakRefConstructor.h> + +namespace JS { + +WeakRefConstructor::WeakRefConstructor(GlobalObject& global_object) + : NativeFunction(vm().names.WeakRef, *global_object.function_prototype()) +{ +} + +void WeakRefConstructor::initialize(GlobalObject& global_object) +{ + auto& vm = this->vm(); + NativeFunction::initialize(global_object); + define_property(vm.names.prototype, global_object.weak_ref_prototype(), 0); + define_property(vm.names.length, Value(1), Attribute::Configurable); +} + +WeakRefConstructor::~WeakRefConstructor() +{ +} + +Value WeakRefConstructor::call() +{ + auto& vm = this->vm(); + vm.throw_exception<TypeError>(global_object(), ErrorType::ConstructorWithoutNew, vm.names.WeakRef); + return {}; +} + +// 26.1.1.1 WeakRef ( target ), https://tc39.es/ecma262/#sec-weak-ref-target +Value WeakRefConstructor::construct(Function&) +{ + auto& vm = this->vm(); + auto target = vm.argument(0); + if (!target.is_object()) { + vm.throw_exception<TypeError>(global_object(), ErrorType::NotAnObject, target.to_string_without_side_effects()); + return {}; + } + + // FIXME: Use OrdinaryCreateFromConstructor(newTarget, "%WeakRef.prototype%") + return WeakRef::create(global_object(), &target.as_object()); +} + +} |