1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-07-27 01:17:35 +00:00

LibJS: Convert FunctionPrototype functions to ThrowCompletionOr

This commit is contained in:
Idan Horowitz 2021-10-29 00:40:06 +03:00
parent c0bb456fd2
commit 2a0c51149d
2 changed files with 32 additions and 40 deletions

View file

@ -29,11 +29,11 @@ void FunctionPrototype::initialize(GlobalObject& global_object)
auto& vm = this->vm(); auto& vm = this->vm();
Object::initialize(global_object); Object::initialize(global_object);
u8 attr = Attribute::Writable | Attribute::Configurable; u8 attr = Attribute::Writable | Attribute::Configurable;
define_old_native_function(vm.names.apply, apply, 2, attr); define_native_function(vm.names.apply, apply, 2, attr);
define_old_native_function(vm.names.bind, bind, 1, attr); define_native_function(vm.names.bind, bind, 1, attr);
define_old_native_function(vm.names.call, call, 1, attr); define_native_function(vm.names.call, call, 1, attr);
define_old_native_function(vm.names.toString, to_string, 0, attr); define_native_function(vm.names.toString, to_string, 0, attr);
define_old_native_function(*vm.well_known_symbol_has_instance(), symbol_has_instance, 1, 0); define_native_function(*vm.well_known_symbol_has_instance(), symbol_has_instance, 1, 0);
define_direct_property(vm.names.length, Value(0), Attribute::Configurable); define_direct_property(vm.names.length, Value(0), Attribute::Configurable);
define_direct_property(vm.names.name, js_string(heap(), ""), Attribute::Configurable); define_direct_property(vm.names.name, js_string(heap(), ""), Attribute::Configurable);
} }
@ -43,30 +43,26 @@ FunctionPrototype::~FunctionPrototype()
} }
// 20.2.3.1 Function.prototype.apply ( thisArg, argArray ), https://tc39.es/ecma262/#sec-function.prototype.apply // 20.2.3.1 Function.prototype.apply ( thisArg, argArray ), https://tc39.es/ecma262/#sec-function.prototype.apply
JS_DEFINE_OLD_NATIVE_FUNCTION(FunctionPrototype::apply) JS_DEFINE_NATIVE_FUNCTION(FunctionPrototype::apply)
{ {
auto* this_object = TRY_OR_DISCARD(vm.this_value(global_object).to_object(global_object)); auto* this_object = TRY(vm.this_value(global_object).to_object(global_object));
if (!this_object->is_function()) { if (!this_object->is_function())
vm.throw_exception<TypeError>(global_object, ErrorType::NotAnObjectOfType, "Function"); return vm.throw_completion<TypeError>(global_object, ErrorType::NotAnObjectOfType, "Function");
return {};
}
auto& function = static_cast<FunctionObject&>(*this_object); auto& function = static_cast<FunctionObject&>(*this_object);
auto this_arg = vm.argument(0); auto this_arg = vm.argument(0);
auto arg_array = vm.argument(1); auto arg_array = vm.argument(1);
if (arg_array.is_nullish()) if (arg_array.is_nullish())
return TRY_OR_DISCARD(vm.call(function, this_arg)); return TRY(vm.call(function, this_arg));
auto arguments = TRY_OR_DISCARD(create_list_from_array_like(global_object, arg_array)); auto arguments = TRY(create_list_from_array_like(global_object, arg_array));
return TRY_OR_DISCARD(vm.call(function, this_arg, move(arguments))); return TRY(vm.call(function, this_arg, move(arguments)));
} }
// 20.2.3.2 Function.prototype.bind ( thisArg, ...args ), https://tc39.es/ecma262/#sec-function.prototype.bind // 20.2.3.2 Function.prototype.bind ( thisArg, ...args ), https://tc39.es/ecma262/#sec-function.prototype.bind
JS_DEFINE_OLD_NATIVE_FUNCTION(FunctionPrototype::bind) JS_DEFINE_NATIVE_FUNCTION(FunctionPrototype::bind)
{ {
auto* this_object = TRY_OR_DISCARD(vm.this_value(global_object).to_object(global_object)); auto* this_object = TRY(vm.this_value(global_object).to_object(global_object));
if (!this_object->is_function()) { if (!this_object->is_function())
vm.throw_exception<TypeError>(global_object, ErrorType::NotAnObjectOfType, "Function"); return vm.throw_completion<TypeError>(global_object, ErrorType::NotAnObjectOfType, "Function");
return {};
}
auto& this_function = static_cast<FunctionObject&>(*this_object); auto& this_function = static_cast<FunctionObject&>(*this_object);
auto bound_this_arg = vm.argument(0); auto bound_this_arg = vm.argument(0);
@ -80,13 +76,11 @@ JS_DEFINE_OLD_NATIVE_FUNCTION(FunctionPrototype::bind)
} }
// 20.2.3.3 Function.prototype.call ( thisArg, ...args ), https://tc39.es/ecma262/#sec-function.prototype.call // 20.2.3.3 Function.prototype.call ( thisArg, ...args ), https://tc39.es/ecma262/#sec-function.prototype.call
JS_DEFINE_OLD_NATIVE_FUNCTION(FunctionPrototype::call) JS_DEFINE_NATIVE_FUNCTION(FunctionPrototype::call)
{ {
auto* this_object = TRY_OR_DISCARD(vm.this_value(global_object).to_object(global_object)); auto* this_object = TRY(vm.this_value(global_object).to_object(global_object));
if (!this_object->is_function()) { if (!this_object->is_function())
vm.throw_exception<TypeError>(global_object, ErrorType::NotAnObjectOfType, "Function"); return vm.throw_completion<TypeError>(global_object, ErrorType::NotAnObjectOfType, "Function");
return {};
}
auto& function = static_cast<FunctionObject&>(*this_object); auto& function = static_cast<FunctionObject&>(*this_object);
auto this_arg = vm.argument(0); auto this_arg = vm.argument(0);
MarkedValueList arguments(vm.heap()); MarkedValueList arguments(vm.heap());
@ -94,17 +88,15 @@ JS_DEFINE_OLD_NATIVE_FUNCTION(FunctionPrototype::call)
for (size_t i = 1; i < vm.argument_count(); ++i) for (size_t i = 1; i < vm.argument_count(); ++i)
arguments.append(vm.argument(i)); arguments.append(vm.argument(i));
} }
return TRY_OR_DISCARD(vm.call(function, this_arg, move(arguments))); return TRY(vm.call(function, this_arg, move(arguments)));
} }
// 20.2.3.5 Function.prototype.toString ( ), https://tc39.es/ecma262/#sec-function.prototype.tostring // 20.2.3.5 Function.prototype.toString ( ), https://tc39.es/ecma262/#sec-function.prototype.tostring
JS_DEFINE_OLD_NATIVE_FUNCTION(FunctionPrototype::to_string) JS_DEFINE_NATIVE_FUNCTION(FunctionPrototype::to_string)
{ {
auto* this_object = TRY_OR_DISCARD(vm.this_value(global_object).to_object(global_object)); auto* this_object = TRY(vm.this_value(global_object).to_object(global_object));
if (!this_object->is_function()) { if (!this_object->is_function())
vm.throw_exception<TypeError>(global_object, ErrorType::NotAnObjectOfType, "Function"); return vm.throw_completion<TypeError>(global_object, ErrorType::NotAnObjectOfType, "Function");
return {};
}
String function_name; String function_name;
String function_parameters; String function_parameters;
String function_body; String function_body;
@ -149,9 +141,9 @@ JS_DEFINE_OLD_NATIVE_FUNCTION(FunctionPrototype::to_string)
} }
// 20.2.3.6 Function.prototype [ @@hasInstance ] ( V ), https://tc39.es/ecma262/#sec-function.prototype-@@hasinstance // 20.2.3.6 Function.prototype [ @@hasInstance ] ( V ), https://tc39.es/ecma262/#sec-function.prototype-@@hasinstance
JS_DEFINE_OLD_NATIVE_FUNCTION(FunctionPrototype::symbol_has_instance) JS_DEFINE_NATIVE_FUNCTION(FunctionPrototype::symbol_has_instance)
{ {
return TRY_OR_DISCARD(ordinary_has_instance(global_object, vm.argument(0), vm.this_value(global_object))); return TRY(ordinary_has_instance(global_object, vm.argument(0), vm.this_value(global_object)));
} }
} }

View file

@ -19,11 +19,11 @@ public:
virtual ~FunctionPrototype() override; virtual ~FunctionPrototype() override;
private: private:
JS_DECLARE_OLD_NATIVE_FUNCTION(apply); JS_DECLARE_NATIVE_FUNCTION(apply);
JS_DECLARE_OLD_NATIVE_FUNCTION(bind); JS_DECLARE_NATIVE_FUNCTION(bind);
JS_DECLARE_OLD_NATIVE_FUNCTION(call); JS_DECLARE_NATIVE_FUNCTION(call);
JS_DECLARE_OLD_NATIVE_FUNCTION(to_string); JS_DECLARE_NATIVE_FUNCTION(to_string);
JS_DECLARE_OLD_NATIVE_FUNCTION(symbol_has_instance); JS_DECLARE_NATIVE_FUNCTION(symbol_has_instance);
}; };
} }