summaryrefslogtreecommitdiffstats
path: root/js/src/devtools/gc-ubench/benchmarks/pairCyclicWeakMap.js
blob: ac43325b6f03d9b2ea9c9d015a5855bfee026993 (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
/* 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/. */

tests.set(
  "pairCyclicWeakMap",
  (function() {
    var garbage = [];
    var garbageIndex = 0;
    return {
      description: "wm1[k1] = k2; wm2[k2] = k3; wm1[k3] = k4; wm2[k4] = ...",

      defaultGarbagePerFrame: "10K",
      defaultGarbagePiles: "1K",

      load: N => {
        garbage = new Array(N);
      },

      unload: () => {
        garbage = [];
        garbageIndex = 0;
      },

      makeGarbage: M => {
        var wm1 = new WeakMap();
        var wm2 = new WeakMap();
        var initialKey = {};
        var key = initialKey;
        var value = {};
        for (var i = 0; i < M / 2; i++) {
          wm1.set(key, value);
          key = value;
          value = {};
          wm2.set(key, value);
          key = value;
          value = {};
        }
        garbage[garbageIndex++] = [initialKey, wm1, wm2];
        if (garbageIndex == garbage.length) {
          garbageIndex = 0;
        }
      },
    };
  })()
);