mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-06-10 18:10:56 +09:00
LibJS: Convert FinalizationRegistry::cleanup to ThrowCompletionOr
This commit is contained in:
parent
dcc284705b
commit
f324d91106
Notes:
sideshowbarker
2024-07-17 19:38:10 +09:00
Author: https://github.com/davidot
Commit: f324d91106
Pull-request: https://github.com/SerenityOS/serenity/pull/12343
Reviewed-by: https://github.com/linusg
3 changed files with 19 additions and 7 deletions
|
@ -58,18 +58,30 @@ void FinalizationRegistry::remove_dead_cells(Badge<Heap>)
|
|||
}
|
||||
|
||||
// 9.13 CleanupFinalizationRegistry ( finalizationRegistry ), https://tc39.es/ecma262/#sec-cleanup-finalization-registry
|
||||
void FinalizationRegistry::cleanup(FunctionObject* callback)
|
||||
ThrowCompletionOr<void> FinalizationRegistry::cleanup(FunctionObject* callback)
|
||||
{
|
||||
auto& vm = this->vm();
|
||||
// 1. Assert: finalizationRegistry has [[Cells]] and [[CleanupCallback]] internal slots.
|
||||
// Note: Ensured by type.
|
||||
|
||||
// 2. Let callback be finalizationRegistry.[[CleanupCallback]].
|
||||
auto cleanup_callback = callback ?: m_cleanup_callback;
|
||||
|
||||
// 3. While finalizationRegistry.[[Cells]] contains a Record cell such that cell.[[WeakRefTarget]] is empty, an implementation may perform the following steps:
|
||||
for (auto it = m_records.begin(); it != m_records.end(); ++it) {
|
||||
// a. Choose any such cell.
|
||||
if (it->target != nullptr)
|
||||
continue;
|
||||
(void)call(global_object(), *cleanup_callback, js_undefined(), it->held_value);
|
||||
auto cell = *it;
|
||||
|
||||
// b. Remove cell from finalizationRegistry.[[Cells]].
|
||||
it.remove(m_records);
|
||||
if (vm.exception())
|
||||
return;
|
||||
|
||||
// c. Perform ? HostCallJobCallback(callback, undefined, « cell.[[HeldValue]] »).
|
||||
(void)TRY(call(global_object(), *cleanup_callback, js_undefined(), cell.held_value));
|
||||
}
|
||||
|
||||
// 4. Return NormalCompletion(empty).
|
||||
return {};
|
||||
}
|
||||
|
||||
void FinalizationRegistry::visit_edges(Cell::Visitor& visitor)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue