mirror of
https://github.com/RGBCube/serenity
synced 2025-07-25 04:17:35 +00:00
LibJS: Remove GlobalObject from VM::throw_completion()
This is a continuation of the previous five commits. A first big step into the direction of no longer having to pass a realm (or currently, a global object) trough layers upon layers of AOs! Unlike the create() APIs we can safely assume that this is only ever called when a running execution context and therefore current realm exists. If not, you can always manually allocate the Error and put it in a Completion :^) In the spec, throw exceptions implicitly use the current realm's intrinsics as well: https://tc39.es/ecma262/#sec-throw-an-exception
This commit is contained in:
parent
5398dcc55e
commit
f3117d46dc
165 changed files with 892 additions and 900 deletions
|
@ -200,7 +200,7 @@ ThrowCompletionOr<String> JSONObject::serialize_json_property(GlobalObject& glob
|
|||
|
||||
// 10. If Type(value) is BigInt, throw a TypeError exception.
|
||||
if (value.is_bigint())
|
||||
return vm.throw_completion<TypeError>(global_object, ErrorType::JsonBigInt);
|
||||
return vm.throw_completion<TypeError>(ErrorType::JsonBigInt);
|
||||
|
||||
// 11. If Type(value) is Object and IsCallable(value) is false, then
|
||||
if (value.is_object() && !value.is_function()) {
|
||||
|
@ -224,7 +224,7 @@ ThrowCompletionOr<String> JSONObject::serialize_json_object(GlobalObject& global
|
|||
{
|
||||
auto& vm = global_object.vm();
|
||||
if (state.seen_objects.contains(&object))
|
||||
return vm.throw_completion<TypeError>(global_object, ErrorType::JsonCircular);
|
||||
return vm.throw_completion<TypeError>(ErrorType::JsonCircular);
|
||||
|
||||
state.seen_objects.set(&object);
|
||||
String previous_indent = state.indent;
|
||||
|
@ -293,7 +293,7 @@ ThrowCompletionOr<String> JSONObject::serialize_json_array(GlobalObject& global_
|
|||
{
|
||||
auto& vm = global_object.vm();
|
||||
if (state.seen_objects.contains(&object))
|
||||
return vm.throw_completion<TypeError>(global_object, ErrorType::JsonCircular);
|
||||
return vm.throw_completion<TypeError>(ErrorType::JsonCircular);
|
||||
|
||||
state.seen_objects.set(&object);
|
||||
String previous_indent = state.indent;
|
||||
|
@ -401,7 +401,7 @@ JS_DEFINE_NATIVE_FUNCTION(JSONObject::parse)
|
|||
|
||||
auto json = JsonValue::from_string(string);
|
||||
if (json.is_error())
|
||||
return vm.throw_completion<SyntaxError>(global_object, ErrorType::JsonMalformed);
|
||||
return vm.throw_completion<SyntaxError>(ErrorType::JsonMalformed);
|
||||
Value unfiltered = parse_json_value(global_object, json.value());
|
||||
if (reviver.is_function()) {
|
||||
auto* root = Object::create(realm, global_object.object_prototype());
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue