743ce7726d
Previously, this was run as a microtask and this CL changes it to run as a separate task as mandated by the current WeakRef spec. This CL also introduces a FinalizationGroup type to the V8 API representing the JSFinalizationGroup. This has a `Cleanup` function that runs the cleanup callback associated with it. SetHostCleanupFinalizationGroupCallback is added to set the embedder defined HostCleanupFinalizationGroupCallback. ClearKeptObject is exposed on the v8::Isolate to reset the strongly held set of objects. The general workflow is the following: (a) When the GC notices that a given finalization group has dirty cells, it calls HostCleanupFinalizationGroupCallback with the given finalization group. (b) As part of HostCleanupFinalizationGroupCallback, the embedder enqueues a task that at some point later calls FinalizationGroup::Cleanup. (c) At some point in the future, FinalizationGroup::Cleanup is called, which runs the cleanup callback of the finalization group. This patch also includes d8 changes to use these new APIs. Currently, d8 cycles through the enqueued finalization groups after a synchronous turn (and it's microtask checkpoint) and runs the cleanup callbacks. Change-Id: I06eb4da2c103b2792a9c62bc4b98fd4e5c4892fc Bug: v8:8179 Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1655655 Commit-Queue: Sathya Gunasekaran <gsathya@chromium.org> Reviewed-by: Ulan Degenbaev <ulan@chromium.org> Reviewed-by: Hannes Payer <hpayer@chromium.org> Cr-Commit-Position: refs/heads/master@{#62984}
48 lines
1019 B
JavaScript
48 lines
1019 B
JavaScript
// Copyright 2018 the V8 project authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
// Flags: --harmony-weak-refs --expose-gc --noincremental-marking
|
|
|
|
let o1 = {};
|
|
let o2 = {};
|
|
let wr1;
|
|
let wr2;
|
|
(function() {
|
|
wr1 = new WeakRef(o1);
|
|
wr2 = new WeakRef(o2);
|
|
})();
|
|
|
|
// Since the WeakRefs were created during this turn, they're not cleared by GC.
|
|
gc();
|
|
|
|
(function() {
|
|
assertNotEquals(undefined, wr1.deref());
|
|
assertNotEquals(undefined, wr2.deref());
|
|
})();
|
|
|
|
// New task
|
|
setTimeout(function() {
|
|
wr1.deref();
|
|
o1 = null;
|
|
gc(); // deref makes sure we don't clean up wr1
|
|
|
|
// New task
|
|
setTimeout(function() {
|
|
wr2.deref();
|
|
o2 = null;
|
|
gc(); // deref makes sure we don't clean up wr2
|
|
|
|
// New task
|
|
setTimeout(function() {
|
|
assertEquals(undefined, wr1.deref());
|
|
gc();
|
|
|
|
// New task
|
|
setTimeout(function() {
|
|
assertEquals(undefined, wr2.deref());
|
|
}, 0);
|
|
}, 0);
|
|
}, 0);
|
|
}, 0);
|