mirror of
https://github.com/RGBCube/serenity
synced 2025-07-27 05:07:45 +00:00
LibJS: Let Error prototypes inherit from PrototypeObject
This commit is contained in:
parent
89c82abf1f
commit
e106d5ecf4
2 changed files with 16 additions and 23 deletions
|
@ -1,6 +1,6 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2020, Andreas Kling <kling@serenityos.org>
|
* Copyright (c) 2020, Andreas Kling <kling@serenityos.org>
|
||||||
* Copyright (c) 2021, Linus Groh <linusg@serenityos.org>
|
* Copyright (c) 2021-2022, Linus Groh <linusg@serenityos.org>
|
||||||
*
|
*
|
||||||
* SPDX-License-Identifier: BSD-2-Clause
|
* SPDX-License-Identifier: BSD-2-Clause
|
||||||
*/
|
*/
|
||||||
|
@ -16,7 +16,7 @@
|
||||||
namespace JS {
|
namespace JS {
|
||||||
|
|
||||||
ErrorPrototype::ErrorPrototype(GlobalObject& global_object)
|
ErrorPrototype::ErrorPrototype(GlobalObject& global_object)
|
||||||
: Object(*global_object.object_prototype())
|
: PrototypeObject(*global_object.object_prototype())
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -37,18 +37,15 @@ void ErrorPrototype::initialize(GlobalObject& global_object)
|
||||||
// 20.5.3.4 Error.prototype.toString ( ), https://tc39.es/ecma262/#sec-error.prototype.tostring
|
// 20.5.3.4 Error.prototype.toString ( ), https://tc39.es/ecma262/#sec-error.prototype.tostring
|
||||||
JS_DEFINE_NATIVE_FUNCTION(ErrorPrototype::to_string)
|
JS_DEFINE_NATIVE_FUNCTION(ErrorPrototype::to_string)
|
||||||
{
|
{
|
||||||
auto this_value = vm.this_value(global_object);
|
auto* this_object = TRY(PrototypeObject::this_object(global_object));
|
||||||
if (!this_value.is_object())
|
|
||||||
return vm.throw_completion<TypeError>(global_object, ErrorType::NotAnObject, this_value.to_string_without_side_effects());
|
|
||||||
auto& this_object = this_value.as_object();
|
|
||||||
|
|
||||||
String name = "Error";
|
String name = "Error";
|
||||||
auto name_property = TRY(this_object.get(vm.names.name));
|
auto name_property = TRY(this_object->get(vm.names.name));
|
||||||
if (!name_property.is_undefined())
|
if (!name_property.is_undefined())
|
||||||
name = TRY(name_property.to_string(global_object));
|
name = TRY(name_property.to_string(global_object));
|
||||||
|
|
||||||
String message = "";
|
String message = "";
|
||||||
auto message_property = TRY(this_object.get(vm.names.message));
|
auto message_property = TRY(this_object->get(vm.names.message));
|
||||||
if (!message_property.is_undefined())
|
if (!message_property.is_undefined())
|
||||||
message = TRY(message_property.to_string(global_object));
|
message = TRY(message_property.to_string(global_object));
|
||||||
|
|
||||||
|
@ -61,21 +58,15 @@ JS_DEFINE_NATIVE_FUNCTION(ErrorPrototype::to_string)
|
||||||
|
|
||||||
JS_DEFINE_NATIVE_FUNCTION(ErrorPrototype::stack)
|
JS_DEFINE_NATIVE_FUNCTION(ErrorPrototype::stack)
|
||||||
{
|
{
|
||||||
auto this_value = vm.this_value(global_object);
|
auto* error = TRY(typed_this_value(global_object));
|
||||||
if (!this_value.is_object())
|
|
||||||
return vm.throw_completion<TypeError>(global_object, ErrorType::NotAnObject, this_value.to_string_without_side_effects());
|
|
||||||
auto& this_object = this_value.as_object();
|
|
||||||
|
|
||||||
if (!is<Error>(this_object))
|
|
||||||
return vm.throw_completion<TypeError>(global_object, ErrorType::NotAnObjectOfType, "Error");
|
|
||||||
|
|
||||||
String name = "Error";
|
String name = "Error";
|
||||||
auto name_property = TRY(this_object.get(vm.names.name));
|
auto name_property = TRY(error->get(vm.names.name));
|
||||||
if (!name_property.is_undefined())
|
if (!name_property.is_undefined())
|
||||||
name = TRY(name_property.to_string(global_object));
|
name = TRY(name_property.to_string(global_object));
|
||||||
|
|
||||||
String message = "";
|
String message = "";
|
||||||
auto message_property = TRY(this_object.get(vm.names.message));
|
auto message_property = TRY(error->get(vm.names.message));
|
||||||
if (!message_property.is_undefined())
|
if (!message_property.is_undefined())
|
||||||
message = TRY(message_property.to_string(global_object));
|
message = TRY(message_property.to_string(global_object));
|
||||||
|
|
||||||
|
@ -84,12 +75,12 @@ JS_DEFINE_NATIVE_FUNCTION(ErrorPrototype::stack)
|
||||||
header = String::formatted("{}: {}", name, message);
|
header = String::formatted("{}: {}", name, message);
|
||||||
|
|
||||||
return js_string(vm,
|
return js_string(vm,
|
||||||
String::formatted("{}\n{}", header, static_cast<Error&>(this_object).stack_string()));
|
String::formatted("{}\n{}", header, error->stack_string()));
|
||||||
}
|
}
|
||||||
|
|
||||||
#define __JS_ENUMERATE(ClassName, snake_name, PrototypeName, ConstructorName, ArrayType) \
|
#define __JS_ENUMERATE(ClassName, snake_name, PrototypeName, ConstructorName, ArrayType) \
|
||||||
PrototypeName::PrototypeName(GlobalObject& global_object) \
|
PrototypeName::PrototypeName(GlobalObject& global_object) \
|
||||||
: Object(*global_object.error_prototype()) \
|
: PrototypeObject(*global_object.error_prototype()) \
|
||||||
{ \
|
{ \
|
||||||
} \
|
} \
|
||||||
\
|
\
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2020, Andreas Kling <kling@serenityos.org>
|
* Copyright (c) 2020, Andreas Kling <kling@serenityos.org>
|
||||||
|
* Copyright (c) 2021-2022, Linus Groh <linusg@serenityos.org>
|
||||||
*
|
*
|
||||||
* SPDX-License-Identifier: BSD-2-Clause
|
* SPDX-License-Identifier: BSD-2-Clause
|
||||||
*/
|
*/
|
||||||
|
@ -7,11 +8,12 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <LibJS/Runtime/Error.h>
|
#include <LibJS/Runtime/Error.h>
|
||||||
|
#include <LibJS/Runtime/PrototypeObject.h>
|
||||||
|
|
||||||
namespace JS {
|
namespace JS {
|
||||||
|
|
||||||
class ErrorPrototype final : public Object {
|
class ErrorPrototype final : public PrototypeObject<ErrorPrototype, Error> {
|
||||||
JS_OBJECT(ErrorPrototype, Object);
|
JS_PROTOTYPE_OBJECT(ErrorPrototype, Error, Error);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
explicit ErrorPrototype(GlobalObject&);
|
explicit ErrorPrototype(GlobalObject&);
|
||||||
|
@ -24,8 +26,8 @@ private:
|
||||||
};
|
};
|
||||||
|
|
||||||
#define DECLARE_NATIVE_ERROR_PROTOTYPE(ClassName, snake_name, PrototypeName, ConstructorName) \
|
#define DECLARE_NATIVE_ERROR_PROTOTYPE(ClassName, snake_name, PrototypeName, ConstructorName) \
|
||||||
class PrototypeName final : public Object { \
|
class PrototypeName final : public PrototypeObject<PrototypeName, ClassName> { \
|
||||||
JS_OBJECT(PrototypeName, Object); \
|
JS_PROTOTYPE_OBJECT(PrototypeName, ClassName, ClassName); \
|
||||||
\
|
\
|
||||||
public: \
|
public: \
|
||||||
explicit PrototypeName(GlobalObject&); \
|
explicit PrototypeName(GlobalObject&); \
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue