blob: 54f53fb5fa74a3bed80ee09e9ad5a8ce6bb5a5a1 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
|
/* 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;
}
|