mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-05-19 17:42:52 +00:00
LibJS: Use IteratorStepValue in ECMA-262
This is an editorial change in the ECMA-262 spec. See:
12d3687
Note they have not yet updated all potential consumers to use this new
AO.
This commit is contained in:
parent
2b96e732dd
commit
18847fca50
Notes:
sideshowbarker
2024-07-17 05:09:48 +09:00
Author: https://github.com/trflynn89
Commit: 18847fca50
Pull-request: https://github.com/SerenityOS/serenity/pull/23041
9 changed files with 80 additions and 156 deletions
|
@ -197,11 +197,11 @@ JS_DEFINE_NATIVE_FUNCTION(ArrayConstructor::from)
|
|||
// ii. Let Pk be ! ToString(𝔽(k)).
|
||||
auto property_key = PropertyKey { k };
|
||||
|
||||
// iii. Let next be ? IteratorStep(iteratorRecord).
|
||||
auto next = TRY(iterator_step(vm, iterator));
|
||||
// iii. Let next be ? IteratorStepValue(iteratorRecord).
|
||||
auto next = TRY(iterator_step_value(vm, iterator));
|
||||
|
||||
// iv. If next is false, then
|
||||
if (!next) {
|
||||
// iv. If next is DONE, then
|
||||
if (!next.has_value()) {
|
||||
// 1. Perform ? Set(A, "length", 𝔽(k), true).
|
||||
TRY(array->set(vm.names.length, Value(k), Object::ShouldThrowExceptions::Yes));
|
||||
|
||||
|
@ -209,34 +209,31 @@ JS_DEFINE_NATIVE_FUNCTION(ArrayConstructor::from)
|
|||
return array;
|
||||
}
|
||||
|
||||
// v. Let nextValue be ? IteratorValue(next).
|
||||
auto next_value = TRY(iterator_value(vm, *next));
|
||||
|
||||
Value mapped_value;
|
||||
|
||||
// vi. If mapping is true, then
|
||||
// v. If mapping is true, then
|
||||
if (mapfn) {
|
||||
// 1. Let mappedValue be Completion(Call(mapfn, thisArg, « nextValue, 𝔽(k) »)).
|
||||
auto mapped_value_or_error = JS::call(vm, *mapfn, this_arg, next_value, Value(k));
|
||||
auto mapped_value_or_error = JS::call(vm, *mapfn, this_arg, next.release_value(), Value(k));
|
||||
|
||||
// 2. IfAbruptCloseIterator(mappedValue, iteratorRecord).
|
||||
if (mapped_value_or_error.is_error())
|
||||
return *TRY(iterator_close(vm, iterator, mapped_value_or_error.release_error()));
|
||||
mapped_value = mapped_value_or_error.release_value();
|
||||
}
|
||||
// vii. Else, let mappedValue be nextValue.
|
||||
// vi. Else, let mappedValue be nextValue.
|
||||
else {
|
||||
mapped_value = next_value;
|
||||
mapped_value = next.release_value();
|
||||
}
|
||||
|
||||
// viii. Let defineStatus be Completion(CreateDataPropertyOrThrow(A, Pk, mappedValue)).
|
||||
// vii. Let defineStatus be Completion(CreateDataPropertyOrThrow(A, Pk, mappedValue)).
|
||||
auto result_or_error = array->create_data_property_or_throw(property_key, mapped_value);
|
||||
|
||||
// IfAbruptCloseIterator(defineStatus, iteratorRecord).
|
||||
// viii. IfAbruptCloseIterator(defineStatus, iteratorRecord).
|
||||
if (result_or_error.is_error())
|
||||
return *TRY(iterator_close(vm, iterator, result_or_error.release_error()));
|
||||
|
||||
// x. Set k to k + 1.
|
||||
// ix. Set k to k + 1.
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue