diff options
author | Bartek IwaĆczuk <biwanczuk@gmail.com> | 2020-03-11 15:49:53 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-03-11 15:49:53 +0100 |
commit | 2d1b39bef339edb19ae6be5fb2099e685cee93bb (patch) | |
tree | 4e1664f50e079e2f258d86cb0e4a1160fb6b3d7b /cli/js/runtime.ts | |
parent | 99a0c6df79b903e4fe72ce066787039bdede3868 (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.ts | 15 |
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)); } } |