/* This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ // Test-only module in order to register objects later inspected by // the allocation tracker (in the same folder). // // We are going to store a weak reference to the passed objects, // in order to prevent holding them in memory. // Allocation tracker will then print detailed information // about why these objects are still allocated. const objects = []; /** * Request to track why the given object is kept in memory, * later on, when retrieving all the watched object via getAllNodeIds. */ export function track(obj) { // We store a weak reference, so that we do force keeping the object in memory!! objects.push(Cu.getWeakReference(obj)); } /** * Return the NodeId's of all the objects passed via `track()` method. * * NodeId's are used by spidermonkey memory API to designates JS objects in head snapshots. */ export function getAllNodeIds() { // Filter out objects which have been freed already return ( objects .map(weak => weak.get()) .filter(obj => !!obj) // Convert objects from here instead of from allocation tracker in order // to be from the shared system compartment and avoid trying to compute the NodeId // of a wrapper! .map(ChromeUtils.getObjectNodeId) ); } /** * Used by tests to clear all tracked objects */ export function clear() { objects.length = 0; }