diff options
author | Bartek IwaĆczuk <biwanczuk@gmail.com> | 2019-11-14 18:10:25 +0100 |
---|---|---|
committer | Ry Dahl <ry@tinyclouds.org> | 2019-11-14 12:10:25 -0500 |
commit | 8b90b8e88325d28fe41d8312ea91417b6e66a12e (patch) | |
tree | a80d85de86353e05a5e59fe8b9890635dcbf200c /cli/ops/dispatch_minimal.rs | |
parent | 38ffe8886db104068af07cd5efe3d83f42da8ed6 (diff) |
refactor: per-worker resource table, take 2 (#3342)
- removes global `RESOURCE_TABLE` - resource tables are now created per `Worker`
in `State`
- renames `CliResource` to `StreamResource` and moves all logic related
to it to `cli/ops/io.rs`
- removes `cli/resources.rs`
- adds `state` argument to `op_read` and `op_write` and consequently adds
`stateful_minimal_op` to `State`
- IMPORTANT NOTE: workers don't have access to process stdio - this is
caused by fact that dropping worker would close stdout for process
(because it's constructed from raw handle, which closes underlying file
descriptor on drop)
Diffstat (limited to 'cli/ops/dispatch_minimal.rs')
-rw-r--r-- | cli/ops/dispatch_minimal.rs | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/cli/ops/dispatch_minimal.rs b/cli/ops/dispatch_minimal.rs index c19521bf1..355a24634 100644 --- a/cli/ops/dispatch_minimal.rs +++ b/cli/ops/dispatch_minimal.rs @@ -15,7 +15,6 @@ use deno::PinnedBuf; use futures::Future; pub type MinimalOp = dyn Future<Item = i32, Error = ErrBox> + Send; -pub type Dispatcher = fn(i32, Option<PinnedBuf>) -> Box<MinimalOp>; #[derive(Copy, Clone, Debug, PartialEq)] // This corresponds to RecordMinimal on the TS side. @@ -112,9 +111,10 @@ fn test_parse_min_record() { assert_eq!(parse_min_record(&buf), None); } -pub fn minimal_op( - d: Dispatcher, -) -> impl Fn(&[u8], Option<PinnedBuf>) -> CoreOp { +pub fn minimal_op<D>(d: D) -> impl Fn(&[u8], Option<PinnedBuf>) -> CoreOp +where + D: Fn(i32, Option<PinnedBuf>) -> Box<MinimalOp>, +{ move |control: &[u8], zero_copy: Option<PinnedBuf>| { let mut record = match parse_min_record(control) { Some(r) => r, |