2019-02-02 09:27:42 +03:00
|
|
|
// Copyright 2018-2019 the Deno authors. All rights reserved. MIT license.
|
2019-03-30 14:45:36 -04:00
|
|
|
import * as msg from "gen/cli/msg_generated";
|
2019-02-02 09:27:42 +03:00
|
|
|
import { sendSync } from "./dispatch";
|
|
|
|
import * as flatbuffers from "./flatbuffers";
|
|
|
|
import { assert } from "./util";
|
|
|
|
|
|
|
|
export class Performance {
|
2019-05-23 19:28:29 +03:00
|
|
|
/** Returns a current time from Deno's start in milliseconds.
|
|
|
|
*
|
|
|
|
* Use the flag --allow-hrtime return a precise value.
|
2019-02-02 09:27:42 +03:00
|
|
|
*
|
|
|
|
* const t = performance.now();
|
|
|
|
* console.log(`${t} ms since start!`);
|
|
|
|
*/
|
|
|
|
now(): number {
|
|
|
|
const builder = flatbuffers.createBuilder();
|
2019-04-07 20:51:43 -04:00
|
|
|
const inner = msg.Now.createNow(builder);
|
2019-02-02 09:27:42 +03:00
|
|
|
const baseRes = sendSync(builder, msg.Any.Now, inner)!;
|
|
|
|
assert(msg.Any.NowRes === baseRes.innerType());
|
|
|
|
const res = new msg.NowRes();
|
|
|
|
assert(baseRes.inner(res) != null);
|
2019-04-08 22:22:40 +02:00
|
|
|
return res.seconds().toFloat64() * 1e3 + res.subsecNanos() / 1e6;
|
2019-02-02 09:27:42 +03:00
|
|
|
}
|
|
|
|
}
|