summaryrefslogtreecommitdiff
path: root/cli/js/runtime.ts
diff options
context:
space:
mode:
authorBartek IwaƄczuk <biwanczuk@gmail.com>2020-03-11 15:49:53 +0100
committerGitHub <noreply@github.com>2020-03-11 15:49:53 +0100
commit2d1b39bef339edb19ae6be5fb2099e685cee93bb (patch)
tree4e1664f50e079e2f258d86cb0e4a1160fb6b3d7b /cli/js/runtime.ts
parent99a0c6df79b903e4fe72ce066787039bdede3868 (diff)
reorg: remove dispatch.ts, move signals, factor out web utils (#4316)
- moves signal definition from "cli/js/process.ts" to "cli/js/signals.ts" - removes "cli/js/dispatch.ts" - removes "cli/js/types.ts" - moves web specific utilities to "cli/js/web/util.ts"
Diffstat (limited to 'cli/js/runtime.ts')
-rw-r--r--cli/js/runtime.ts15
1 files changed, 13 insertions, 2 deletions
diff --git a/cli/js/runtime.ts b/cli/js/runtime.ts
index 9a304379f..9d783dc7a 100644
--- a/cli/js/runtime.ts
+++ b/cli/js/runtime.ts
@@ -1,6 +1,7 @@
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
import { core } from "./core.ts";
-import * as dispatch from "./dispatch.ts";
+import * as dispatchMinimal from "./ops/dispatch_minimal.ts";
+import * as dispatchJson from "./ops/dispatch_json.ts";
import { assert } from "./util.ts";
import * as util from "./util.ts";
import { setBuildInfo } from "./build.ts";
@@ -11,12 +12,22 @@ import { Start, start as startOp } from "./ops/runtime.ts";
export let OPS_CACHE: { [name: string]: number };
+function getAsyncHandler(opName: string): (msg: Uint8Array) => void {
+ switch (opName) {
+ case "op_write":
+ case "op_read":
+ return dispatchMinimal.asyncMsgFromRust;
+ default:
+ return dispatchJson.asyncMsgFromRust;
+ }
+}
+
// TODO(bartlomieju): temporary solution, must be fixed when moving
// dispatches to separate crates
export function initOps(): void {
OPS_CACHE = core.ops();
for (const [name, opId] of Object.entries(OPS_CACHE)) {
- core.setAsyncHandler(opId, dispatch.getAsyncHandler(name));
+ core.setAsyncHandler(opId, getAsyncHandler(name));
}
}