0
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2024-10-30 09:08:00 -04:00
denoland-deno/js/dispatch.ts

93 lines
2.7 KiB
TypeScript
Raw Normal View History

// Copyright 2018 the Deno authors. All rights reserved. MIT license.
import { libdeno } from "./libdeno";
import * as flatbuffers from "./flatbuffers";
2018-10-03 21:18:23 -04:00
import * as msg from "gen/msg_generated";
import * as errors from "./errors";
import * as util from "./util";
2018-09-22 03:59:26 -04:00
import { maybePushTrace } from "./trace";
let nextCmdId = 0;
2018-10-03 21:18:23 -04:00
const promiseTable = new Map<number, util.Resolvable<msg.Base>>();
2018-10-02 20:47:40 -04:00
let fireTimers: () => void;
export function setFireTimersCallback(fn: () => void) {
fireTimers = fn;
}
export function handleAsyncMsgFromRust(ui8: Uint8Array) {
2018-10-02 20:47:40 -04:00
// If a the buffer is empty, recv() on the native side timed out and we
// did not receive a message.
if (ui8.length) {
const bb = new flatbuffers.ByteBuffer(ui8);
2018-10-03 21:18:23 -04:00
const base = msg.Base.getRootAsBase(bb);
2018-10-02 20:47:40 -04:00
const cmdId = base.cmdId();
const promise = promiseTable.get(cmdId);
util.assert(promise != null, `Expecting promise in table. ${cmdId}`);
promiseTable.delete(cmdId);
const err = errors.maybeError(base);
if (err != null) {
promise!.reject(err);
} else {
promise!.resolve(base);
}
}
2018-10-02 20:47:40 -04:00
// Fire timers that have become runnable.
fireTimers();
}
// @internal
export function sendAsync(
builder: flatbuffers.Builder,
2018-10-03 21:18:23 -04:00
innerType: msg.Any,
inner: flatbuffers.Offset,
data?: ArrayBufferView
2018-10-03 21:18:23 -04:00
): Promise<msg.Base> {
maybePushTrace(innerType, false); // add to trace if tracing
const [cmdId, resBuf] = sendInternal(builder, innerType, inner, data, false);
util.assert(resBuf == null);
2018-10-03 21:18:23 -04:00
const promise = util.createResolvable<msg.Base>();
promiseTable.set(cmdId, promise);
return promise;
}
// @internal
export function sendSync(
builder: flatbuffers.Builder,
2018-10-03 21:18:23 -04:00
innerType: msg.Any,
inner: flatbuffers.Offset,
data?: ArrayBufferView
2018-10-03 21:18:23 -04:00
): null | msg.Base {
maybePushTrace(innerType, true); // add to trace if tracing
const [cmdId, resBuf] = sendInternal(builder, innerType, inner, data, true);
util.assert(cmdId >= 0);
if (resBuf == null) {
return null;
} else {
const u8 = new Uint8Array(resBuf!);
const bb = new flatbuffers.ByteBuffer(u8);
2018-10-03 21:18:23 -04:00
const baseRes = msg.Base.getRootAsBase(bb);
errors.maybeThrowError(baseRes);
return baseRes;
}
}
function sendInternal(
builder: flatbuffers.Builder,
2018-10-03 21:18:23 -04:00
innerType: msg.Any,
inner: flatbuffers.Offset,
data: undefined | ArrayBufferView,
sync = true
): [number, null | Uint8Array] {
const cmdId = nextCmdId++;
2018-10-03 21:18:23 -04:00
msg.Base.startBase(builder);
msg.Base.addInner(builder, inner);
msg.Base.addInnerType(builder, innerType);
msg.Base.addSync(builder, sync);
msg.Base.addCmdId(builder, cmdId);
builder.finish(msg.Base.endBase(builder));
const res = libdeno.send(builder.asUint8Array(), data);
builder.inUse = false;
return [cmdId, res];
}