summaryrefslogtreecommitdiff
path: root/js/performance.ts
blob: 73378b15c791a9d487ca52d8a28e5cd6d0970da0 (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
// Copyright 2018-2019 the Deno authors. All rights reserved. MIT license.
import * as msg from "gen/msg_generated";
import { sendSync } from "./dispatch";
import * as flatbuffers from "./flatbuffers";
import { assert } from "./util";

export class Performance {
  timeOrigin = 0;

  constructor() {
    this.timeOrigin = new Date().getTime();
  }

  /** Returns a current time from Deno's start
   *
   *       const t = performance.now();
   *       console.log(`${t} ms since start!`);
   */
  now(): number {
    const builder = flatbuffers.createBuilder();
    msg.Now.startNow(builder);
    const inner = msg.Now.endNow(builder);
    const baseRes = sendSync(builder, msg.Any.Now, inner)!;
    assert(msg.Any.NowRes === baseRes.innerType());
    const res = new msg.NowRes();
    assert(baseRes.inner(res) != null);
    return res.time().toFloat64() - this.timeOrigin;
  }
}