1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-12 00:54:02 -05:00

refactor(ops): remove variadic buffers (#9944)

This commit is contained in:
Aaron O'Mullan 2021-04-02 15:47:57 +02:00 committed by GitHub
parent adf5761090
commit 058579da56
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
49 changed files with 332 additions and 385 deletions

1
Cargo.lock generated
View file

@ -576,7 +576,6 @@ dependencies = [
"serde", "serde",
"serde_json", "serde_json",
"serde_v8", "serde_v8",
"smallvec",
"tokio", "tokio",
"url", "url",
] ]

View file

@ -30,7 +30,7 @@ struct ApplySourceMap {
fn op_apply_source_map( fn op_apply_source_map(
state: &mut OpState, state: &mut OpState,
args: Value, args: Value,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let args: ApplySourceMap = serde_json::from_value(args)?; let args: ApplySourceMap = serde_json::from_value(args)?;
@ -56,7 +56,7 @@ fn op_apply_source_map(
fn op_format_diagnostic( fn op_format_diagnostic(
_state: &mut OpState, _state: &mut OpState,
args: Value, args: Value,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let diagnostic: Diagnostics = serde_json::from_value(args)?; let diagnostic: Diagnostics = serde_json::from_value(args)?;
Ok(json!(diagnostic.to_string())) Ok(json!(diagnostic.to_string()))

View file

@ -7,7 +7,6 @@ use deno_core::error::AnyError;
use deno_core::json_op_async; use deno_core::json_op_async;
use deno_core::json_op_sync; use deno_core::json_op_sync;
use deno_core::serde_json::Value; use deno_core::serde_json::Value;
use deno_core::BufVec;
use deno_core::JsRuntime; use deno_core::JsRuntime;
use deno_core::OpState; use deno_core::OpState;
use deno_core::ZeroCopyBuf; use deno_core::ZeroCopyBuf;
@ -18,7 +17,7 @@ use std::rc::Rc;
pub fn reg_json_async<F, R>(rt: &mut JsRuntime, name: &'static str, op_fn: F) pub fn reg_json_async<F, R>(rt: &mut JsRuntime, name: &'static str, op_fn: F)
where where
F: Fn(Rc<RefCell<OpState>>, Value, BufVec) -> R + 'static, F: Fn(Rc<RefCell<OpState>>, Value, Option<ZeroCopyBuf>) -> R + 'static,
R: Future<Output = Result<Value, AnyError>> + 'static, R: Future<Output = Result<Value, AnyError>> + 'static,
{ {
rt.register_op(name, metrics_op(name, json_op_async(op_fn))); rt.register_op(name, metrics_op(name, json_op_async(op_fn)));
@ -26,7 +25,7 @@ where
pub fn reg_json_sync<F>(rt: &mut JsRuntime, name: &'static str, op_fn: F) pub fn reg_json_sync<F>(rt: &mut JsRuntime, name: &'static str, op_fn: F)
where where
F: Fn(&mut OpState, Value, &mut [ZeroCopyBuf]) -> Result<Value, AnyError> F: Fn(&mut OpState, Value, Option<ZeroCopyBuf>) -> Result<Value, AnyError>
+ 'static, + 'static,
{ {
rt.register_op(name, metrics_op(name, json_op_sync(op_fn))); rt.register_op(name, metrics_op(name, json_op_sync(op_fn)));

View file

@ -17,8 +17,8 @@ use deno_core::resolve_url_or_path;
use deno_core::serde_json; use deno_core::serde_json;
use deno_core::serde_json::json; use deno_core::serde_json::json;
use deno_core::serde_json::Value; use deno_core::serde_json::Value;
use deno_core::BufVec;
use deno_core::OpState; use deno_core::OpState;
use deno_core::ZeroCopyBuf;
use deno_runtime::permissions::Permissions; use deno_runtime::permissions::Permissions;
use serde::Deserialize; use serde::Deserialize;
use std::cell::RefCell; use std::cell::RefCell;
@ -54,7 +54,7 @@ struct EmitArgs {
async fn op_emit( async fn op_emit(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: Value, args: Value,
_data: BufVec, _data: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
deno_runtime::ops::check_unstable2(&state, "Deno.emit"); deno_runtime::ops::check_unstable2(&state, "Deno.emit");
let args: EmitArgs = serde_json::from_value(args)?; let args: EmitArgs = serde_json::from_value(args)?;

View file

@ -25,7 +25,6 @@ rusty_v8 = "0.21.0"
serde = { version = "1.0.123", features = ["derive"] } serde = { version = "1.0.123", features = ["derive"] }
serde_json = { version = "1.0.62", features = ["preserve_order"] } serde_json = { version = "1.0.62", features = ["preserve_order"] }
serde_v8 = { version = "0.1.0", path = "../serde_v8" } serde_v8 = { version = "0.1.0", path = "../serde_v8" }
smallvec = "1.6.1"
url = { version = "2.2.0", features = ["serde"] } url = { version = "2.2.0", features = ["serde"] }
[[example]] [[example]]

View file

@ -59,6 +59,10 @@ pub fn resource_unavailable() -> AnyError {
) )
} }
pub fn null_opbuf() -> AnyError {
type_error("expected non-null op buffer arg")
}
/// A simple error type that lets the creator specify both the error message and /// A simple error type that lets the creator specify both the error message and
/// the error class name. This type is private; externally it only ever appears /// the error class name. This type is private; externally it only ever appears
/// wrapped in an `AnyError`. To retrieve the error class name from a wrapped /// wrapped in an `AnyError`. To retrieve the error class name from a wrapped

View file

@ -35,7 +35,7 @@ fn main() {
} }
// Write the contents of every buffer to stdout // Write the contents of every buffer to stdout
for buf in zero_copy { if let Some(buf) = zero_copy {
out.write_all(&buf).unwrap(); out.write_all(&buf).unwrap();
} }

View file

@ -1,8 +1,8 @@
// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license. // Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.
use deno_core::error::bad_resource_id; use deno_core::error::bad_resource_id;
use deno_core::error::null_opbuf;
use deno_core::error::AnyError; use deno_core::error::AnyError;
use deno_core::AsyncRefCell; use deno_core::AsyncRefCell;
use deno_core::BufVec;
use deno_core::CancelHandle; use deno_core::CancelHandle;
use deno_core::CancelTryFuture; use deno_core::CancelTryFuture;
use deno_core::JsRuntime; use deno_core::JsRuntime;
@ -122,7 +122,7 @@ fn create_js_runtime() -> JsRuntime {
fn op_listen( fn op_listen(
state: &mut OpState, state: &mut OpState,
_rid: ResourceId, _rid: ResourceId,
_bufs: &mut [ZeroCopyBuf], _bufs: Option<ZeroCopyBuf>,
) -> Result<u32, AnyError> { ) -> Result<u32, AnyError> {
log::debug!("listen"); log::debug!("listen");
let addr = "127.0.0.1:4544".parse::<SocketAddr>().unwrap(); let addr = "127.0.0.1:4544".parse::<SocketAddr>().unwrap();
@ -136,7 +136,7 @@ fn op_listen(
fn op_close( fn op_close(
state: &mut OpState, state: &mut OpState,
rid: ResourceId, rid: ResourceId,
_bufs: &mut [ZeroCopyBuf], _bufs: Option<ZeroCopyBuf>,
) -> Result<u32, AnyError> { ) -> Result<u32, AnyError> {
log::debug!("close rid={}", rid); log::debug!("close rid={}", rid);
state state
@ -149,7 +149,7 @@ fn op_close(
async fn op_accept( async fn op_accept(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
rid: ResourceId, rid: ResourceId,
_bufs: BufVec, _bufs: Option<ZeroCopyBuf>,
) -> Result<u32, AnyError> { ) -> Result<u32, AnyError> {
log::debug!("accept rid={}", rid); log::debug!("accept rid={}", rid);
@ -166,9 +166,9 @@ async fn op_accept(
async fn op_read( async fn op_read(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
rid: ResourceId, rid: ResourceId,
mut bufs: BufVec, buf: Option<ZeroCopyBuf>,
) -> Result<u32, AnyError> { ) -> Result<u32, AnyError> {
assert_eq!(bufs.len(), 1, "Invalid number of arguments"); let mut buf = buf.ok_or_else(null_opbuf)?;
log::debug!("read rid={}", rid); log::debug!("read rid={}", rid);
let stream = state let stream = state
@ -176,16 +176,16 @@ async fn op_read(
.resource_table .resource_table
.get::<TcpStream>(rid) .get::<TcpStream>(rid)
.ok_or_else(bad_resource_id)?; .ok_or_else(bad_resource_id)?;
let nread = stream.read(&mut bufs[0]).await?; let nread = stream.read(&mut buf).await?;
Ok(nread as u32) Ok(nread as u32)
} }
async fn op_write( async fn op_write(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
rid: ResourceId, rid: ResourceId,
bufs: BufVec, buf: Option<ZeroCopyBuf>,
) -> Result<u32, AnyError> { ) -> Result<u32, AnyError> {
assert_eq!(bufs.len(), 1, "Invalid number of arguments"); let buf = buf.ok_or_else(null_opbuf)?;
log::debug!("write rid={}", rid); log::debug!("write rid={}", rid);
let stream = state let stream = state
@ -193,7 +193,7 @@ async fn op_write(
.resource_table .resource_table
.get::<TcpStream>(rid) .get::<TcpStream>(rid)
.ok_or_else(bad_resource_id)?; .ok_or_else(bad_resource_id)?;
let nwritten = stream.write(&bufs[0]).await?; let nwritten = stream.write(&buf).await?;
Ok(nwritten as u32) Ok(nwritten as u32)
} }

View file

@ -1,8 +1,8 @@
// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license. // Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.
use deno_core::error::bad_resource_id; use deno_core::error::bad_resource_id;
use deno_core::error::null_opbuf;
use deno_core::error::AnyError; use deno_core::error::AnyError;
use deno_core::AsyncRefCell; use deno_core::AsyncRefCell;
use deno_core::BufVec;
use deno_core::CancelHandle; use deno_core::CancelHandle;
use deno_core::CancelTryFuture; use deno_core::CancelTryFuture;
use deno_core::JsRuntime; use deno_core::JsRuntime;
@ -122,7 +122,7 @@ fn create_js_runtime() -> JsRuntime {
fn op_listen( fn op_listen(
state: &mut OpState, state: &mut OpState,
_args: (), _args: (),
_bufs: &mut [ZeroCopyBuf], _bufs: Option<ZeroCopyBuf>,
) -> Result<ResourceId, AnyError> { ) -> Result<ResourceId, AnyError> {
log::debug!("listen"); log::debug!("listen");
let addr = "127.0.0.1:4544".parse::<SocketAddr>().unwrap(); let addr = "127.0.0.1:4544".parse::<SocketAddr>().unwrap();
@ -136,7 +136,7 @@ fn op_listen(
fn op_close( fn op_close(
state: &mut OpState, state: &mut OpState,
rid: ResourceId, rid: ResourceId,
_buf: &mut [ZeroCopyBuf], _buf: Option<ZeroCopyBuf>,
) -> Result<(), AnyError> { ) -> Result<(), AnyError> {
log::debug!("close rid={}", rid); log::debug!("close rid={}", rid);
state state
@ -149,7 +149,7 @@ fn op_close(
async fn op_accept( async fn op_accept(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
rid: ResourceId, rid: ResourceId,
_bufs: BufVec, _buf: Option<ZeroCopyBuf>,
) -> Result<ResourceId, AnyError> { ) -> Result<ResourceId, AnyError> {
log::debug!("accept rid={}", rid); log::debug!("accept rid={}", rid);
@ -166,9 +166,9 @@ async fn op_accept(
async fn op_read( async fn op_read(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
rid: ResourceId, rid: ResourceId,
mut bufs: BufVec, buf: Option<ZeroCopyBuf>,
) -> Result<usize, AnyError> { ) -> Result<usize, AnyError> {
assert_eq!(bufs.len(), 1, "Invalid number of arguments"); let mut buf = buf.ok_or_else(null_opbuf)?;
log::debug!("read rid={}", rid); log::debug!("read rid={}", rid);
let stream = state let stream = state
@ -176,16 +176,16 @@ async fn op_read(
.resource_table .resource_table
.get::<TcpStream>(rid) .get::<TcpStream>(rid)
.ok_or_else(bad_resource_id)?; .ok_or_else(bad_resource_id)?;
let nread = stream.read(&mut bufs[0]).await?; let nread = stream.read(&mut buf).await?;
Ok(nread) Ok(nread)
} }
async fn op_write( async fn op_write(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
rid: ResourceId, rid: ResourceId,
bufs: BufVec, buf: Option<ZeroCopyBuf>,
) -> Result<usize, AnyError> { ) -> Result<usize, AnyError> {
assert_eq!(bufs.len(), 1, "Invalid number of arguments"); let buf = buf.ok_or_else(null_opbuf)?;
log::debug!("write rid={}", rid); log::debug!("write rid={}", rid);
let stream = state let stream = state
@ -193,7 +193,7 @@ async fn op_write(
.resource_table .resource_table
.get::<TcpStream>(rid) .get::<TcpStream>(rid)
.ok_or_else(bad_resource_id)?; .ok_or_else(bad_resource_id)?;
let nwritten = stream.write(&bufs[0]).await?; let nwritten = stream.write(&buf).await?;
Ok(nwritten) Ok(nwritten)
} }

View file

@ -79,7 +79,6 @@ pub use crate::runtime::JsErrorCreateFn;
pub use crate::runtime::JsRuntime; pub use crate::runtime::JsRuntime;
pub use crate::runtime::RuntimeOptions; pub use crate::runtime::RuntimeOptions;
pub use crate::runtime::Snapshot; pub use crate::runtime::Snapshot;
pub use crate::zero_copy_buf::BufVec;
pub use crate::zero_copy_buf::ZeroCopyBuf; pub use crate::zero_copy_buf::ZeroCopyBuf;
pub fn v8_version() -> &'static str { pub fn v8_version() -> &'static str {

View file

@ -191,7 +191,7 @@ impl Default for OpTable {
pub fn op_resources( pub fn op_resources(
state: &mut OpState, state: &mut OpState,
_args: Value, _args: Value,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let serialized_resources: HashMap<u32, String> = state let serialized_resources: HashMap<u32, String> = state
.resource_table .resource_table
@ -207,7 +207,7 @@ pub fn op_resources(
pub fn op_close( pub fn op_close(
state: &mut OpState, state: &mut OpState,
args: Value, args: Value,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let rid = args let rid = args
.get("rid") .get("rid")

View file

@ -1,10 +1,8 @@
// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license. // Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.
use crate::error::type_error;
use crate::error::AnyError; use crate::error::AnyError;
use crate::futures::future::FutureExt; use crate::futures::future::FutureExt;
use crate::serialize_op_result; use crate::serialize_op_result;
use crate::BufVec;
use crate::Op; use crate::Op;
use crate::OpFn; use crate::OpFn;
use crate::OpPayload; use crate::OpPayload;
@ -66,26 +64,13 @@ impl ValueOrVector for u32 {
/// A more complete example is available in the examples directory. /// A more complete example is available in the examples directory.
pub fn bin_op_sync<F, R>(op_fn: F) -> Box<OpFn> pub fn bin_op_sync<F, R>(op_fn: F) -> Box<OpFn>
where where
F: Fn(&mut OpState, u32, &mut [ZeroCopyBuf]) -> Result<R, AnyError> + 'static, F:
Fn(&mut OpState, u32, Option<ZeroCopyBuf>) -> Result<R, AnyError> + 'static,
R: ValueOrVector, R: ValueOrVector,
{ {
Box::new(move |state, payload, buf| -> Op { Box::new(move |state, payload, buf| -> Op {
let min_arg: u32 = payload.deserialize().unwrap(); let min_arg: u32 = payload.deserialize().unwrap();
// For sig compat map Option<ZeroCopyBuf> to BufVec let result = op_fn(&mut state.borrow_mut(), min_arg, buf);
let mut bufs: BufVec = match buf {
Some(b) => vec![b],
None => vec![],
}
.into();
// Bin op buffer arg assert
if bufs.is_empty() {
return Op::Sync(serialize_bin_result::<u32>(
Err(type_error("bin-ops require a non-null buffer arg")),
state,
));
}
let result = op_fn(&mut state.borrow_mut(), min_arg, &mut bufs);
Op::Sync(serialize_bin_result(result, state)) Op::Sync(serialize_bin_result(result, state))
}) })
} }
@ -138,7 +123,7 @@ where
/// A more complete example is available in the examples directory. /// A more complete example is available in the examples directory.
pub fn bin_op_async<F, R, RV>(op_fn: F) -> Box<OpFn> pub fn bin_op_async<F, R, RV>(op_fn: F) -> Box<OpFn>
where where
F: Fn(Rc<RefCell<OpState>>, u32, BufVec) -> R + 'static, F: Fn(Rc<RefCell<OpState>>, u32, Option<ZeroCopyBuf>) -> R + 'static,
R: Future<Output = Result<RV, AnyError>> + 'static, R: Future<Output = Result<RV, AnyError>> + 'static,
RV: ValueOrVector, RV: ValueOrVector,
{ {
@ -148,21 +133,7 @@ where
b: Option<ZeroCopyBuf>| b: Option<ZeroCopyBuf>|
-> Op { -> Op {
let min_arg: u32 = p.deserialize().unwrap(); let min_arg: u32 = p.deserialize().unwrap();
// For sig compat map Option<ZeroCopyBuf> to BufVec let fut = op_fn(state.clone(), min_arg, b)
let bufs: BufVec = match b {
Some(b) => vec![b],
None => vec![],
}
.into();
// Bin op buffer arg assert
if bufs.is_empty() {
return Op::Sync(serialize_bin_result::<u32>(
Err(type_error("bin-ops require a non-null buffer arg")),
state,
));
}
let fut = op_fn(state.clone(), min_arg, bufs)
.map(move |result| serialize_bin_result(result, state)); .map(move |result| serialize_bin_result(result, state));
let temp = Box::pin(fut); let temp = Box::pin(fut);
Op::Async(temp) Op::Async(temp)

View file

@ -2,7 +2,6 @@
use crate::error::AnyError; use crate::error::AnyError;
use crate::serialize_op_result; use crate::serialize_op_result;
use crate::BufVec;
use crate::Op; use crate::Op;
use crate::OpFn; use crate::OpFn;
use crate::OpPayload; use crate::OpPayload;
@ -39,21 +38,14 @@ use std::rc::Rc;
/// A more complete example is available in the examples directory. /// A more complete example is available in the examples directory.
pub fn json_op_sync<F, V, R>(op_fn: F) -> Box<OpFn> pub fn json_op_sync<F, V, R>(op_fn: F) -> Box<OpFn>
where where
F: Fn(&mut OpState, V, &mut [ZeroCopyBuf]) -> Result<R, AnyError> + 'static, F: Fn(&mut OpState, V, Option<ZeroCopyBuf>) -> Result<R, AnyError> + 'static,
V: DeserializeOwned, V: DeserializeOwned,
R: Serialize + 'static, R: Serialize + 'static,
{ {
Box::new(move |state, payload, buf: Option<ZeroCopyBuf>| -> Op { Box::new(move |state, payload, buf| -> Op {
// For sig compat map Option<ZeroCopyBuf> to BufVec
let mut bufs: BufVec = match buf {
Some(b) => vec![b],
None => vec![],
}
.into();
let result = payload let result = payload
.deserialize() .deserialize()
.and_then(|args| op_fn(&mut state.borrow_mut(), args, &mut bufs)); .and_then(|args| op_fn(&mut state.borrow_mut(), args, buf));
Op::Sync(serialize_op_result(result, state)) Op::Sync(serialize_op_result(result, state))
}) })
} }
@ -84,26 +76,20 @@ where
/// A more complete example is available in the examples directory. /// A more complete example is available in the examples directory.
pub fn json_op_async<F, V, R, RV>(op_fn: F) -> Box<OpFn> pub fn json_op_async<F, V, R, RV>(op_fn: F) -> Box<OpFn>
where where
F: Fn(Rc<RefCell<OpState>>, V, BufVec) -> R + 'static, F: Fn(Rc<RefCell<OpState>>, V, Option<ZeroCopyBuf>) -> R + 'static,
V: DeserializeOwned, V: DeserializeOwned,
R: Future<Output = Result<RV, AnyError>> + 'static, R: Future<Output = Result<RV, AnyError>> + 'static,
RV: Serialize + 'static, RV: Serialize + 'static,
{ {
let try_dispatch_op = move |state: Rc<RefCell<OpState>>, let try_dispatch_op = move |state: Rc<RefCell<OpState>>,
p: OpPayload, p: OpPayload,
b: Option<ZeroCopyBuf>| buf: Option<ZeroCopyBuf>|
-> Result<Op, AnyError> { -> Result<Op, AnyError> {
// For sig compat map Option<ZeroCopyBuf> to BufVec
let bufs: BufVec = match b {
Some(b) => vec![b],
None => vec![],
}
.into();
// Parse args // Parse args
let args = p.deserialize()?; let args = p.deserialize()?;
use crate::futures::FutureExt; use crate::futures::FutureExt;
let fut = op_fn(state.clone(), args, bufs) let fut = op_fn(state.clone(), args, buf)
.map(move |result| serialize_op_result(result, state)); .map(move |result| serialize_op_result(result, state));
Ok(Op::Async(Box::pin(fut))) Ok(Op::Async(Box::pin(fut)))
}; };

View file

@ -15,7 +15,7 @@ pub use crate::ZeroCopyBuf;
pub type InitFn = fn(&mut dyn Interface); pub type InitFn = fn(&mut dyn Interface);
pub type DispatchOpFn = fn(&mut dyn Interface, &mut [ZeroCopyBuf]) -> Op; pub type DispatchOpFn = fn(&mut dyn Interface, Option<ZeroCopyBuf>) -> Op;
pub trait Interface { pub trait Interface {
fn register_op(&mut self, name: &str, dispatcher: DispatchOpFn) -> OpId; fn register_op(&mut self, name: &str, dispatcher: DispatchOpFn) -> OpId;

View file

@ -2,12 +2,9 @@
use crate::bindings; use crate::bindings;
use rusty_v8 as v8; use rusty_v8 as v8;
use smallvec::SmallVec;
use std::ops::Deref; use std::ops::Deref;
use std::ops::DerefMut; use std::ops::DerefMut;
pub type BufVec = SmallVec<[ZeroCopyBuf; 2]>;
/// A ZeroCopyBuf encapsulates a slice that's been borrowed from a JavaScript /// A ZeroCopyBuf encapsulates a slice that's been borrowed from a JavaScript
/// ArrayBuffer object. JavaScript objects can normally be garbage collected, /// ArrayBuffer object. JavaScript objects can normally be garbage collected,
/// but the existence of a ZeroCopyBuf inhibits this until it is dropped. It /// but the existence of a ZeroCopyBuf inhibits this until it is dropped. It

View file

@ -2,6 +2,7 @@
#![deny(warnings)] #![deny(warnings)]
use deno_core::error::null_opbuf;
use deno_core::error::AnyError; use deno_core::error::AnyError;
use deno_core::serde_json::json; use deno_core::serde_json::json;
use deno_core::serde_json::Value; use deno_core::serde_json::Value;
@ -29,15 +30,15 @@ pub fn init(isolate: &mut JsRuntime) {
pub fn op_crypto_get_random_values( pub fn op_crypto_get_random_values(
state: &mut OpState, state: &mut OpState,
_args: Value, _args: Value,
zero_copy: &mut [ZeroCopyBuf], zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
assert_eq!(zero_copy.len(), 1); let mut zero_copy = zero_copy.ok_or_else(null_opbuf)?;
let maybe_seeded_rng = state.try_borrow_mut::<StdRng>(); let maybe_seeded_rng = state.try_borrow_mut::<StdRng>();
if let Some(seeded_rng) = maybe_seeded_rng { if let Some(seeded_rng) = maybe_seeded_rng {
seeded_rng.fill(&mut *zero_copy[0]); seeded_rng.fill(&mut *zero_copy);
} else { } else {
let mut rng = thread_rng(); let mut rng = thread_rng();
rng.fill(&mut *zero_copy[0]); rng.fill(&mut *zero_copy);
} }
Ok(json!({})) Ok(json!({}))

View file

@ -4,6 +4,7 @@
use deno_core::error::bad_resource_id; use deno_core::error::bad_resource_id;
use deno_core::error::generic_error; use deno_core::error::generic_error;
use deno_core::error::null_opbuf;
use deno_core::error::type_error; use deno_core::error::type_error;
use deno_core::error::AnyError; use deno_core::error::AnyError;
use deno_core::futures::Future; use deno_core::futures::Future;
@ -13,7 +14,6 @@ use deno_core::serde_json::json;
use deno_core::serde_json::Value; use deno_core::serde_json::Value;
use deno_core::url::Url; use deno_core::url::Url;
use deno_core::AsyncRefCell; use deno_core::AsyncRefCell;
use deno_core::BufVec;
use deno_core::CancelFuture; use deno_core::CancelFuture;
use deno_core::CancelHandle; use deno_core::CancelHandle;
use deno_core::CancelTryFuture; use deno_core::CancelTryFuture;
@ -124,7 +124,7 @@ pub struct FetchArgs {
pub fn op_fetch<FP>( pub fn op_fetch<FP>(
state: &mut OpState, state: &mut OpState,
args: FetchArgs, args: FetchArgs,
data: &mut [ZeroCopyBuf], data: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> ) -> Result<Value, AnyError>
where where
FP: FetchPermissions + 'static, FP: FetchPermissions + 'static,
@ -165,8 +165,8 @@ where
let mut request = client.request(method, url); let mut request = client.request(method, url);
let maybe_request_body_rid = if args.has_body { let maybe_request_body_rid = if args.has_body {
match data.len() { match data {
0 => { None => {
// If no body is passed, we return a writer for streaming the body. // If no body is passed, we return a writer for streaming the body.
let (tx, rx) = mpsc::channel::<std::io::Result<Vec<u8>>>(1); let (tx, rx) = mpsc::channel::<std::io::Result<Vec<u8>>>(1);
request = request.body(Body::wrap_stream(ReceiverStream::new(rx))); request = request.body(Body::wrap_stream(ReceiverStream::new(rx)));
@ -179,12 +179,11 @@ where
Some(request_body_rid) Some(request_body_rid)
} }
1 => { Some(data) => {
// If a body is passed, we use it, and don't return a body for streaming. // If a body is passed, we use it, and don't return a body for streaming.
request = request.body(Vec::from(&*data[0])); request = request.body(Vec::from(&*data));
None None
} }
_ => panic!("Invalid number of arguments"),
} }
} else { } else {
None None
@ -217,7 +216,7 @@ pub struct FetchSendArgs {
pub async fn op_fetch_send( pub async fn op_fetch_send(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: FetchSendArgs, args: FetchSendArgs,
_data: BufVec, _data: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let request = state let request = state
.borrow_mut() .borrow_mut()
@ -285,14 +284,11 @@ pub struct FetchRequestWriteArgs {
pub async fn op_fetch_request_write( pub async fn op_fetch_request_write(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: FetchRequestWriteArgs, args: FetchRequestWriteArgs,
data: BufVec, data: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let rid = args.rid; let rid = args.rid;
let data = data.ok_or_else(null_opbuf)?;
let buf = match data.len() { let buf = Vec::from(&*data);
1 => Vec::from(&*data[0]),
_ => panic!("Invalid number of arguments"),
};
let resource = state let resource = state
.borrow() .borrow()
@ -315,13 +311,10 @@ pub struct FetchResponseReadArgs {
pub async fn op_fetch_response_read( pub async fn op_fetch_response_read(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: FetchResponseReadArgs, args: FetchResponseReadArgs,
data: BufVec, data: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let rid = args.rid; let rid = args.rid;
let data = data.ok_or_else(null_opbuf)?;
if data.len() != 1 {
panic!("Invalid number of arguments");
}
let resource = state let resource = state
.borrow() .borrow()
@ -330,7 +323,7 @@ pub async fn op_fetch_response_read(
.ok_or_else(bad_resource_id)?; .ok_or_else(bad_resource_id)?;
let mut reader = RcRef::map(&resource, |r| &r.reader).borrow_mut().await; let mut reader = RcRef::map(&resource, |r| &r.reader).borrow_mut().await;
let cancel = RcRef::map(resource, |r| &r.cancel); let cancel = RcRef::map(resource, |r| &r.cancel);
let mut buf = data[0].clone(); let mut buf = data.clone();
let read = reader.read(&mut buf).try_or_cancel(cancel).await?; let read = reader.read(&mut buf).try_or_cancel(cancel).await?;
Ok(json!({ "read": read })) Ok(json!({ "read": read }))
} }
@ -397,7 +390,7 @@ pub struct CreateHttpClientOptions {
pub fn op_create_http_client<FP>( pub fn op_create_http_client<FP>(
state: &mut OpState, state: &mut OpState,
args: CreateHttpClientOptions, args: CreateHttpClientOptions,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> ) -> Result<Value, AnyError>
where where
FP: FetchPermissions + 'static, FP: FetchPermissions + 'static,

View file

@ -39,7 +39,7 @@ pub struct UrlParseArgs {
pub fn op_url_parse( pub fn op_url_parse(
_state: &mut deno_core::OpState, _state: &mut deno_core::OpState,
args: UrlParseArgs, args: UrlParseArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let base_url = args let base_url = args
.base_href .base_href
@ -120,7 +120,7 @@ pub fn op_url_parse(
pub fn op_url_parse_search_params( pub fn op_url_parse_search_params(
_state: &mut deno_core::OpState, _state: &mut deno_core::OpState,
args: String, args: String,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let search_params: Vec<_> = form_urlencoded::parse(args.as_bytes()) let search_params: Vec<_> = form_urlencoded::parse(args.as_bytes())
.into_iter() .into_iter()
@ -131,7 +131,7 @@ pub fn op_url_parse_search_params(
pub fn op_url_stringify_search_params( pub fn op_url_stringify_search_params(
_state: &mut deno_core::OpState, _state: &mut deno_core::OpState,
args: Vec<(String, String)>, args: Vec<(String, String)>,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let search = form_urlencoded::Serializer::new(String::new()) let search = form_urlencoded::Serializer::new(String::new())
.extend_pairs(args) .extend_pairs(args)

View file

@ -82,7 +82,7 @@ pub struct CreateBindGroupLayoutArgs {
pub fn op_webgpu_create_bind_group_layout( pub fn op_webgpu_create_bind_group_layout(
state: &mut OpState, state: &mut OpState,
args: CreateBindGroupLayoutArgs, args: CreateBindGroupLayoutArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let instance = state.borrow::<super::Instance>(); let instance = state.borrow::<super::Instance>();
let device_resource = state let device_resource = state
@ -224,7 +224,7 @@ pub struct CreatePipelineLayoutArgs {
pub fn op_webgpu_create_pipeline_layout( pub fn op_webgpu_create_pipeline_layout(
state: &mut OpState, state: &mut OpState,
args: CreatePipelineLayoutArgs, args: CreatePipelineLayoutArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let instance = state.borrow::<super::Instance>(); let instance = state.borrow::<super::Instance>();
let device_resource = state let device_resource = state
@ -287,7 +287,7 @@ pub struct CreateBindGroupArgs {
pub fn op_webgpu_create_bind_group( pub fn op_webgpu_create_bind_group(
state: &mut OpState, state: &mut OpState,
args: CreateBindGroupArgs, args: CreateBindGroupArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let instance = state.borrow::<super::Instance>(); let instance = state.borrow::<super::Instance>();
let device_resource = state let device_resource = state

View file

@ -1,14 +1,15 @@
// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license. // Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.
use deno_core::error::bad_resource_id; use deno_core::error::bad_resource_id;
use deno_core::error::null_opbuf;
use deno_core::error::AnyError; use deno_core::error::AnyError;
use deno_core::futures::channel::oneshot; use deno_core::futures::channel::oneshot;
use deno_core::serde_json::json; use deno_core::serde_json::json;
use deno_core::serde_json::Value; use deno_core::serde_json::Value;
use deno_core::OpState; use deno_core::OpState;
use deno_core::Resource;
use deno_core::ResourceId; use deno_core::ResourceId;
use deno_core::ZeroCopyBuf; use deno_core::ZeroCopyBuf;
use deno_core::{BufVec, Resource};
use serde::Deserialize; use serde::Deserialize;
use std::borrow::Cow; use std::borrow::Cow;
use std::cell::RefCell; use std::cell::RefCell;
@ -45,7 +46,7 @@ pub struct CreateBufferArgs {
pub fn op_webgpu_create_buffer( pub fn op_webgpu_create_buffer(
state: &mut OpState, state: &mut OpState,
args: CreateBufferArgs, args: CreateBufferArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let instance = state.borrow::<super::Instance>(); let instance = state.borrow::<super::Instance>();
let device_resource = state let device_resource = state
@ -88,7 +89,7 @@ pub struct BufferGetMapAsyncArgs {
pub async fn op_webgpu_buffer_get_map_async( pub async fn op_webgpu_buffer_get_map_async(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: BufferGetMapAsyncArgs, args: BufferGetMapAsyncArgs,
_bufs: BufVec, _bufs: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let (sender, receiver) = oneshot::channel::<Result<(), AnyError>>(); let (sender, receiver) = oneshot::channel::<Result<(), AnyError>>();
@ -177,8 +178,9 @@ pub struct BufferGetMappedRangeArgs {
pub fn op_webgpu_buffer_get_mapped_range( pub fn op_webgpu_buffer_get_mapped_range(
state: &mut OpState, state: &mut OpState,
args: BufferGetMappedRangeArgs, args: BufferGetMappedRangeArgs,
zero_copy: &mut [ZeroCopyBuf], zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let mut zero_copy = zero_copy.ok_or_else(null_opbuf)?;
let instance = state.borrow::<super::Instance>(); let instance = state.borrow::<super::Instance>();
let buffer_resource = state let buffer_resource = state
.resource_table .resource_table
@ -196,7 +198,7 @@ pub fn op_webgpu_buffer_get_mapped_range(
let slice = unsafe { let slice = unsafe {
std::slice::from_raw_parts_mut(slice_pointer, args.size as usize) std::slice::from_raw_parts_mut(slice_pointer, args.size as usize)
}; };
zero_copy[0].copy_from_slice(slice); zero_copy.copy_from_slice(slice);
let rid = state let rid = state
.resource_table .resource_table
@ -217,7 +219,7 @@ pub struct BufferUnmapArgs {
pub fn op_webgpu_buffer_unmap( pub fn op_webgpu_buffer_unmap(
state: &mut OpState, state: &mut OpState,
args: BufferUnmapArgs, args: BufferUnmapArgs,
zero_copy: &mut [ZeroCopyBuf], zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let mapped_resource = state let mapped_resource = state
.resource_table .resource_table
@ -233,7 +235,7 @@ pub fn op_webgpu_buffer_unmap(
let slice_pointer = mapped_resource.0; let slice_pointer = mapped_resource.0;
let size = mapped_resource.1; let size = mapped_resource.1;
if let Some(buffer) = zero_copy.get(0) { if let Some(buffer) = zero_copy {
let slice = unsafe { std::slice::from_raw_parts_mut(slice_pointer, size) }; let slice = unsafe { std::slice::from_raw_parts_mut(slice_pointer, size) };
slice.copy_from_slice(&buffer); slice.copy_from_slice(&buffer);
} }

View file

@ -1,6 +1,7 @@
// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license. // Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.
use deno_core::error::bad_resource_id; use deno_core::error::bad_resource_id;
use deno_core::error::null_opbuf;
use deno_core::error::AnyError; use deno_core::error::AnyError;
use deno_core::serde_json::json; use deno_core::serde_json::json;
use deno_core::serde_json::Value; use deno_core::serde_json::Value;
@ -44,7 +45,7 @@ pub struct CreateRenderBundleEncoderArgs {
pub fn op_webgpu_create_render_bundle_encoder( pub fn op_webgpu_create_render_bundle_encoder(
state: &mut OpState, state: &mut OpState,
args: CreateRenderBundleEncoderArgs, args: CreateRenderBundleEncoderArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let device_resource = state let device_resource = state
.resource_table .resource_table
@ -100,7 +101,7 @@ pub struct RenderBundleEncoderFinishArgs {
pub fn op_webgpu_render_bundle_encoder_finish( pub fn op_webgpu_render_bundle_encoder_finish(
state: &mut OpState, state: &mut OpState,
args: RenderBundleEncoderFinishArgs, args: RenderBundleEncoderFinishArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let render_bundle_encoder_resource = state let render_bundle_encoder_resource = state
.resource_table .resource_table
@ -143,8 +144,10 @@ pub struct RenderBundleEncoderSetBindGroupArgs {
pub fn op_webgpu_render_bundle_encoder_set_bind_group( pub fn op_webgpu_render_bundle_encoder_set_bind_group(
state: &mut OpState, state: &mut OpState,
args: RenderBundleEncoderSetBindGroupArgs, args: RenderBundleEncoderSetBindGroupArgs,
zero_copy: &mut [ZeroCopyBuf], zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let zero_copy = zero_copy.ok_or_else(null_opbuf)?;
let bind_group_resource = state let bind_group_resource = state
.resource_table .resource_table
.get::<super::binding::WebGpuBindGroup>(args.bind_group) .get::<super::binding::WebGpuBindGroup>(args.bind_group)
@ -170,7 +173,7 @@ pub fn op_webgpu_render_bundle_encoder_set_bind_group(
); );
}, },
None => { None => {
let (prefix, data, suffix) = unsafe { zero_copy[0].align_to::<u32>() }; let (prefix, data, suffix) = unsafe { zero_copy.align_to::<u32>() };
assert!(prefix.is_empty()); assert!(prefix.is_empty());
assert!(suffix.is_empty()); assert!(suffix.is_empty());
unsafe { unsafe {
@ -198,7 +201,7 @@ pub struct RenderBundleEncoderPushDebugGroupArgs {
pub fn op_webgpu_render_bundle_encoder_push_debug_group( pub fn op_webgpu_render_bundle_encoder_push_debug_group(
state: &mut OpState, state: &mut OpState,
args: RenderBundleEncoderPushDebugGroupArgs, args: RenderBundleEncoderPushDebugGroupArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let render_bundle_encoder_resource = state let render_bundle_encoder_resource = state
.resource_table .resource_table
@ -225,7 +228,7 @@ pub struct RenderBundleEncoderPopDebugGroupArgs {
pub fn op_webgpu_render_bundle_encoder_pop_debug_group( pub fn op_webgpu_render_bundle_encoder_pop_debug_group(
state: &mut OpState, state: &mut OpState,
args: RenderBundleEncoderPopDebugGroupArgs, args: RenderBundleEncoderPopDebugGroupArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let render_bundle_encoder_resource = state let render_bundle_encoder_resource = state
.resource_table .resource_table
@ -251,7 +254,7 @@ pub struct RenderBundleEncoderInsertDebugMarkerArgs {
pub fn op_webgpu_render_bundle_encoder_insert_debug_marker( pub fn op_webgpu_render_bundle_encoder_insert_debug_marker(
state: &mut OpState, state: &mut OpState,
args: RenderBundleEncoderInsertDebugMarkerArgs, args: RenderBundleEncoderInsertDebugMarkerArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let render_bundle_encoder_resource = state let render_bundle_encoder_resource = state
.resource_table .resource_table
@ -279,7 +282,7 @@ pub struct RenderBundleEncoderSetPipelineArgs {
pub fn op_webgpu_render_bundle_encoder_set_pipeline( pub fn op_webgpu_render_bundle_encoder_set_pipeline(
state: &mut OpState, state: &mut OpState,
args: RenderBundleEncoderSetPipelineArgs, args: RenderBundleEncoderSetPipelineArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let render_pipeline_resource = state let render_pipeline_resource = state
.resource_table .resource_table
@ -311,7 +314,7 @@ pub struct RenderBundleEncoderSetIndexBufferArgs {
pub fn op_webgpu_render_bundle_encoder_set_index_buffer( pub fn op_webgpu_render_bundle_encoder_set_index_buffer(
state: &mut OpState, state: &mut OpState,
args: RenderBundleEncoderSetIndexBufferArgs, args: RenderBundleEncoderSetIndexBufferArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let buffer_resource = state let buffer_resource = state
.resource_table .resource_table
@ -348,7 +351,7 @@ pub struct RenderBundleEncoderSetVertexBufferArgs {
pub fn op_webgpu_render_bundle_encoder_set_vertex_buffer( pub fn op_webgpu_render_bundle_encoder_set_vertex_buffer(
state: &mut OpState, state: &mut OpState,
args: RenderBundleEncoderSetVertexBufferArgs, args: RenderBundleEncoderSetVertexBufferArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let buffer_resource = state let buffer_resource = state
.resource_table .resource_table
@ -383,7 +386,7 @@ pub struct RenderBundleEncoderDrawArgs {
pub fn op_webgpu_render_bundle_encoder_draw( pub fn op_webgpu_render_bundle_encoder_draw(
state: &mut OpState, state: &mut OpState,
args: RenderBundleEncoderDrawArgs, args: RenderBundleEncoderDrawArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let render_bundle_encoder_resource = state let render_bundle_encoder_resource = state
.resource_table .resource_table
@ -415,7 +418,7 @@ pub struct RenderBundleEncoderDrawIndexedArgs {
pub fn op_webgpu_render_bundle_encoder_draw_indexed( pub fn op_webgpu_render_bundle_encoder_draw_indexed(
state: &mut OpState, state: &mut OpState,
args: RenderBundleEncoderDrawIndexedArgs, args: RenderBundleEncoderDrawIndexedArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let render_bundle_encoder_resource = state let render_bundle_encoder_resource = state
.resource_table .resource_table
@ -445,7 +448,7 @@ pub struct RenderBundleEncoderDrawIndirectArgs {
pub fn op_webgpu_render_bundle_encoder_draw_indirect( pub fn op_webgpu_render_bundle_encoder_draw_indirect(
state: &mut OpState, state: &mut OpState,
args: RenderBundleEncoderDrawIndirectArgs, args: RenderBundleEncoderDrawIndirectArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let buffer_resource = state let buffer_resource = state
.resource_table .resource_table

View file

@ -50,7 +50,7 @@ pub struct CreateCommandEncoderArgs {
pub fn op_webgpu_create_command_encoder( pub fn op_webgpu_create_command_encoder(
state: &mut OpState, state: &mut OpState,
args: CreateCommandEncoderArgs, args: CreateCommandEncoderArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let instance = state.borrow::<super::Instance>(); let instance = state.borrow::<super::Instance>();
let device_resource = state let device_resource = state
@ -116,7 +116,7 @@ pub struct CommandEncoderBeginRenderPassArgs {
pub fn op_webgpu_command_encoder_begin_render_pass( pub fn op_webgpu_command_encoder_begin_render_pass(
state: &mut OpState, state: &mut OpState,
args: CommandEncoderBeginRenderPassArgs, args: CommandEncoderBeginRenderPassArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let command_encoder_resource = state let command_encoder_resource = state
.resource_table .resource_table
@ -251,7 +251,7 @@ pub struct CommandEncoderBeginComputePassArgs {
pub fn op_webgpu_command_encoder_begin_compute_pass( pub fn op_webgpu_command_encoder_begin_compute_pass(
state: &mut OpState, state: &mut OpState,
args: CommandEncoderBeginComputePassArgs, args: CommandEncoderBeginComputePassArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let command_encoder_resource = state let command_encoder_resource = state
.resource_table .resource_table
@ -292,7 +292,7 @@ pub struct CommandEncoderCopyBufferToBufferArgs {
pub fn op_webgpu_command_encoder_copy_buffer_to_buffer( pub fn op_webgpu_command_encoder_copy_buffer_to_buffer(
state: &mut OpState, state: &mut OpState,
args: CommandEncoderCopyBufferToBufferArgs, args: CommandEncoderCopyBufferToBufferArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let instance = state.borrow::<super::Instance>(); let instance = state.borrow::<super::Instance>();
let command_encoder_resource = state let command_encoder_resource = state
@ -361,7 +361,7 @@ pub struct CommandEncoderCopyBufferToTextureArgs {
pub fn op_webgpu_command_encoder_copy_buffer_to_texture( pub fn op_webgpu_command_encoder_copy_buffer_to_texture(
state: &mut OpState, state: &mut OpState,
args: CommandEncoderCopyBufferToTextureArgs, args: CommandEncoderCopyBufferToTextureArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let instance = state.borrow::<super::Instance>(); let instance = state.borrow::<super::Instance>();
let command_encoder_resource = state let command_encoder_resource = state
@ -424,7 +424,7 @@ pub struct CommandEncoderCopyTextureToBufferArgs {
pub fn op_webgpu_command_encoder_copy_texture_to_buffer( pub fn op_webgpu_command_encoder_copy_texture_to_buffer(
state: &mut OpState, state: &mut OpState,
args: CommandEncoderCopyTextureToBufferArgs, args: CommandEncoderCopyTextureToBufferArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let instance = state.borrow::<super::Instance>(); let instance = state.borrow::<super::Instance>();
let command_encoder_resource = state let command_encoder_resource = state
@ -486,7 +486,7 @@ pub struct CommandEncoderCopyTextureToTextureArgs {
pub fn op_webgpu_command_encoder_copy_texture_to_texture( pub fn op_webgpu_command_encoder_copy_texture_to_texture(
state: &mut OpState, state: &mut OpState,
args: CommandEncoderCopyTextureToTextureArgs, args: CommandEncoderCopyTextureToTextureArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let instance = state.borrow::<super::Instance>(); let instance = state.borrow::<super::Instance>();
let command_encoder_resource = state let command_encoder_resource = state
@ -550,7 +550,7 @@ pub struct CommandEncoderPushDebugGroupArgs {
pub fn op_webgpu_command_encoder_push_debug_group( pub fn op_webgpu_command_encoder_push_debug_group(
state: &mut OpState, state: &mut OpState,
args: CommandEncoderPushDebugGroupArgs, args: CommandEncoderPushDebugGroupArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let instance = state.borrow::<super::Instance>(); let instance = state.borrow::<super::Instance>();
let command_encoder_resource = state let command_encoder_resource = state
@ -575,7 +575,7 @@ pub struct CommandEncoderPopDebugGroupArgs {
pub fn op_webgpu_command_encoder_pop_debug_group( pub fn op_webgpu_command_encoder_pop_debug_group(
state: &mut OpState, state: &mut OpState,
args: CommandEncoderPopDebugGroupArgs, args: CommandEncoderPopDebugGroupArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let instance = state.borrow::<super::Instance>(); let instance = state.borrow::<super::Instance>();
let command_encoder_resource = state let command_encoder_resource = state
@ -599,7 +599,7 @@ pub struct CommandEncoderInsertDebugMarkerArgs {
pub fn op_webgpu_command_encoder_insert_debug_marker( pub fn op_webgpu_command_encoder_insert_debug_marker(
state: &mut OpState, state: &mut OpState,
args: CommandEncoderInsertDebugMarkerArgs, args: CommandEncoderInsertDebugMarkerArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let instance = state.borrow::<super::Instance>(); let instance = state.borrow::<super::Instance>();
let command_encoder_resource = state let command_encoder_resource = state
@ -627,7 +627,7 @@ pub struct CommandEncoderWriteTimestampArgs {
pub fn op_webgpu_command_encoder_write_timestamp( pub fn op_webgpu_command_encoder_write_timestamp(
state: &mut OpState, state: &mut OpState,
args: CommandEncoderWriteTimestampArgs, args: CommandEncoderWriteTimestampArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let instance = state.borrow::<super::Instance>(); let instance = state.borrow::<super::Instance>();
let command_encoder_resource = state let command_encoder_resource = state
@ -665,7 +665,7 @@ pub struct CommandEncoderResolveQuerySetArgs {
pub fn op_webgpu_command_encoder_resolve_query_set( pub fn op_webgpu_command_encoder_resolve_query_set(
state: &mut OpState, state: &mut OpState,
args: CommandEncoderResolveQuerySetArgs, args: CommandEncoderResolveQuerySetArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let instance = state.borrow::<super::Instance>(); let instance = state.borrow::<super::Instance>();
let command_encoder_resource = state let command_encoder_resource = state
@ -706,7 +706,7 @@ pub struct CommandEncoderFinishArgs {
pub fn op_webgpu_command_encoder_finish( pub fn op_webgpu_command_encoder_finish(
state: &mut OpState, state: &mut OpState,
args: CommandEncoderFinishArgs, args: CommandEncoderFinishArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let command_encoder_resource = state let command_encoder_resource = state
.resource_table .resource_table

View file

@ -1,6 +1,7 @@
// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license. // Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.
use deno_core::error::bad_resource_id; use deno_core::error::bad_resource_id;
use deno_core::error::null_opbuf;
use deno_core::error::AnyError; use deno_core::error::AnyError;
use deno_core::serde_json::json; use deno_core::serde_json::json;
use deno_core::serde_json::Value; use deno_core::serde_json::Value;
@ -32,7 +33,7 @@ pub struct ComputePassSetPipelineArgs {
pub fn op_webgpu_compute_pass_set_pipeline( pub fn op_webgpu_compute_pass_set_pipeline(
state: &mut OpState, state: &mut OpState,
args: ComputePassSetPipelineArgs, args: ComputePassSetPipelineArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let compute_pipeline_resource = state let compute_pipeline_resource = state
.resource_table .resource_table
@ -63,7 +64,7 @@ pub struct ComputePassDispatchArgs {
pub fn op_webgpu_compute_pass_dispatch( pub fn op_webgpu_compute_pass_dispatch(
state: &mut OpState, state: &mut OpState,
args: ComputePassDispatchArgs, args: ComputePassDispatchArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let compute_pass_resource = state let compute_pass_resource = state
.resource_table .resource_table
@ -91,7 +92,7 @@ pub struct ComputePassDispatchIndirectArgs {
pub fn op_webgpu_compute_pass_dispatch_indirect( pub fn op_webgpu_compute_pass_dispatch_indirect(
state: &mut OpState, state: &mut OpState,
args: ComputePassDispatchIndirectArgs, args: ComputePassDispatchIndirectArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let buffer_resource = state let buffer_resource = state
.resource_table .resource_table
@ -122,7 +123,7 @@ pub struct ComputePassBeginPipelineStatisticsQueryArgs {
pub fn op_webgpu_compute_pass_begin_pipeline_statistics_query( pub fn op_webgpu_compute_pass_begin_pipeline_statistics_query(
state: &mut OpState, state: &mut OpState,
args: ComputePassBeginPipelineStatisticsQueryArgs, args: ComputePassBeginPipelineStatisticsQueryArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let compute_pass_resource = state let compute_pass_resource = state
.resource_table .resource_table
@ -153,7 +154,7 @@ pub struct ComputePassEndPipelineStatisticsQueryArgs {
pub fn op_webgpu_compute_pass_end_pipeline_statistics_query( pub fn op_webgpu_compute_pass_end_pipeline_statistics_query(
state: &mut OpState, state: &mut OpState,
args: ComputePassEndPipelineStatisticsQueryArgs, args: ComputePassEndPipelineStatisticsQueryArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let compute_pass_resource = state let compute_pass_resource = state
.resource_table .resource_table
@ -180,7 +181,7 @@ pub struct ComputePassWriteTimestampArgs {
pub fn op_webgpu_compute_pass_write_timestamp( pub fn op_webgpu_compute_pass_write_timestamp(
state: &mut OpState, state: &mut OpState,
args: ComputePassWriteTimestampArgs, args: ComputePassWriteTimestampArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let compute_pass_resource = state let compute_pass_resource = state
.resource_table .resource_table
@ -212,7 +213,7 @@ pub struct ComputePassEndPassArgs {
pub fn op_webgpu_compute_pass_end_pass( pub fn op_webgpu_compute_pass_end_pass(
state: &mut OpState, state: &mut OpState,
args: ComputePassEndPassArgs, args: ComputePassEndPassArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let command_encoder_resource = state let command_encoder_resource = state
.resource_table .resource_table
@ -252,7 +253,7 @@ pub struct ComputePassSetBindGroupArgs {
pub fn op_webgpu_compute_pass_set_bind_group( pub fn op_webgpu_compute_pass_set_bind_group(
state: &mut OpState, state: &mut OpState,
args: ComputePassSetBindGroupArgs, args: ComputePassSetBindGroupArgs,
zero_copy: &mut [ZeroCopyBuf], zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let bind_group_resource = state let bind_group_resource = state
.resource_table .resource_table
@ -271,7 +272,8 @@ pub fn op_webgpu_compute_pass_set_bind_group(
match args.dynamic_offsets_data { match args.dynamic_offsets_data {
Some(data) => data.as_ptr(), Some(data) => data.as_ptr(),
None => { None => {
let (prefix, data, suffix) = zero_copy[0].align_to::<u32>(); let zero_copy = zero_copy.ok_or_else(null_opbuf)?;
let (prefix, data, suffix) = zero_copy.align_to::<u32>();
assert!(prefix.is_empty()); assert!(prefix.is_empty());
assert!(suffix.is_empty()); assert!(suffix.is_empty());
data[args.dynamic_offsets_data_start..].as_ptr() data[args.dynamic_offsets_data_start..].as_ptr()
@ -294,7 +296,7 @@ pub struct ComputePassPushDebugGroupArgs {
pub fn op_webgpu_compute_pass_push_debug_group( pub fn op_webgpu_compute_pass_push_debug_group(
state: &mut OpState, state: &mut OpState,
args: ComputePassPushDebugGroupArgs, args: ComputePassPushDebugGroupArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let compute_pass_resource = state let compute_pass_resource = state
.resource_table .resource_table
@ -322,7 +324,7 @@ pub struct ComputePassPopDebugGroupArgs {
pub fn op_webgpu_compute_pass_pop_debug_group( pub fn op_webgpu_compute_pass_pop_debug_group(
state: &mut OpState, state: &mut OpState,
args: ComputePassPopDebugGroupArgs, args: ComputePassPopDebugGroupArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let compute_pass_resource = state let compute_pass_resource = state
.resource_table .resource_table
@ -346,7 +348,7 @@ pub struct ComputePassInsertDebugMarkerArgs {
pub fn op_webgpu_compute_pass_insert_debug_marker( pub fn op_webgpu_compute_pass_insert_debug_marker(
state: &mut OpState, state: &mut OpState,
args: ComputePassInsertDebugMarkerArgs, args: ComputePassInsertDebugMarkerArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let compute_pass_resource = state let compute_pass_resource = state
.resource_table .resource_table

View file

@ -7,9 +7,9 @@ use deno_core::error::{bad_resource_id, not_supported};
use deno_core::serde_json::json; use deno_core::serde_json::json;
use deno_core::serde_json::Value; use deno_core::serde_json::Value;
use deno_core::OpState; use deno_core::OpState;
use deno_core::Resource;
use deno_core::ResourceId; use deno_core::ResourceId;
use deno_core::ZeroCopyBuf; use deno_core::ZeroCopyBuf;
use deno_core::{BufVec, Resource};
use serde::Deserialize; use serde::Deserialize;
use std::borrow::Cow; use std::borrow::Cow;
use std::cell::RefCell; use std::cell::RefCell;
@ -194,7 +194,7 @@ pub struct RequestAdapterArgs {
pub async fn op_webgpu_request_adapter( pub async fn op_webgpu_request_adapter(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: RequestAdapterArgs, args: RequestAdapterArgs,
_bufs: BufVec, _bufs: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let mut state = state.borrow_mut(); let mut state = state.borrow_mut();
check_unstable(&state, "navigator.gpu.requestAdapter"); check_unstable(&state, "navigator.gpu.requestAdapter");
@ -299,7 +299,7 @@ pub struct RequestDeviceArgs {
pub async fn op_webgpu_request_device( pub async fn op_webgpu_request_device(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: RequestDeviceArgs, args: RequestDeviceArgs,
_bufs: BufVec, _bufs: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let mut state = state.borrow_mut(); let mut state = state.borrow_mut();
let adapter_resource = state let adapter_resource = state
@ -472,7 +472,7 @@ pub struct CreateQuerySetArgs {
pub fn op_webgpu_create_query_set( pub fn op_webgpu_create_query_set(
state: &mut OpState, state: &mut OpState,
args: CreateQuerySetArgs, args: CreateQuerySetArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let device_resource = state let device_resource = state
.resource_table .resource_table

View file

@ -162,7 +162,7 @@ pub struct CreateComputePipelineArgs {
pub fn op_webgpu_create_compute_pipeline( pub fn op_webgpu_create_compute_pipeline(
state: &mut OpState, state: &mut OpState,
args: CreateComputePipelineArgs, args: CreateComputePipelineArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let instance = state.borrow::<super::Instance>(); let instance = state.borrow::<super::Instance>();
let device_resource = state let device_resource = state
@ -229,7 +229,7 @@ pub struct ComputePipelineGetBindGroupLayoutArgs {
pub fn op_webgpu_compute_pipeline_get_bind_group_layout( pub fn op_webgpu_compute_pipeline_get_bind_group_layout(
state: &mut OpState, state: &mut OpState,
args: ComputePipelineGetBindGroupLayoutArgs, args: ComputePipelineGetBindGroupLayoutArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let instance = state.borrow::<super::Instance>(); let instance = state.borrow::<super::Instance>();
let compute_pipeline_resource = state let compute_pipeline_resource = state
@ -366,7 +366,7 @@ pub struct CreateRenderPipelineArgs {
pub fn op_webgpu_create_render_pipeline( pub fn op_webgpu_create_render_pipeline(
state: &mut OpState, state: &mut OpState,
args: CreateRenderPipelineArgs, args: CreateRenderPipelineArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let instance = state.borrow::<super::Instance>(); let instance = state.borrow::<super::Instance>();
let device_resource = state let device_resource = state
@ -617,7 +617,7 @@ pub struct RenderPipelineGetBindGroupLayoutArgs {
pub fn op_webgpu_render_pipeline_get_bind_group_layout( pub fn op_webgpu_render_pipeline_get_bind_group_layout(
state: &mut OpState, state: &mut OpState,
args: RenderPipelineGetBindGroupLayoutArgs, args: RenderPipelineGetBindGroupLayoutArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let instance = state.borrow::<super::Instance>(); let instance = state.borrow::<super::Instance>();
let render_pipeline_resource = state let render_pipeline_resource = state

View file

@ -1,6 +1,7 @@
// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license. // Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.
use deno_core::error::bad_resource_id; use deno_core::error::bad_resource_id;
use deno_core::error::null_opbuf;
use deno_core::error::AnyError; use deno_core::error::AnyError;
use deno_core::serde_json::json; use deno_core::serde_json::json;
use deno_core::serde_json::Value; use deno_core::serde_json::Value;
@ -23,7 +24,7 @@ pub struct QueueSubmitArgs {
pub fn op_webgpu_queue_submit( pub fn op_webgpu_queue_submit(
state: &mut OpState, state: &mut OpState,
args: QueueSubmitArgs, args: QueueSubmitArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let instance = state.borrow::<super::Instance>(); let instance = state.borrow::<super::Instance>();
let queue_resource = state let queue_resource = state
@ -69,8 +70,9 @@ pub struct QueueWriteBufferArgs {
pub fn op_webgpu_write_buffer( pub fn op_webgpu_write_buffer(
state: &mut OpState, state: &mut OpState,
args: QueueWriteBufferArgs, args: QueueWriteBufferArgs,
zero_copy: &mut [ZeroCopyBuf], zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let zero_copy = zero_copy.ok_or_else(null_opbuf)?;
let instance = state.borrow::<super::Instance>(); let instance = state.borrow::<super::Instance>();
let buffer_resource = state let buffer_resource = state
.resource_table .resource_table
@ -84,8 +86,8 @@ pub fn op_webgpu_write_buffer(
let queue = queue_resource.0; let queue = queue_resource.0;
let data = match args.size { let data = match args.size {
Some(size) => &zero_copy[0][args.data_offset..(args.data_offset + size)], Some(size) => &zero_copy[args.data_offset..(args.data_offset + size)],
None => &zero_copy[0][args.data_offset..], None => &zero_copy[args.data_offset..],
}; };
let maybe_err = gfx_select!(queue => instance.queue_write_buffer( let maybe_err = gfx_select!(queue => instance.queue_write_buffer(
queue, queue,
@ -110,8 +112,9 @@ pub struct QueueWriteTextureArgs {
pub fn op_webgpu_write_texture( pub fn op_webgpu_write_texture(
state: &mut OpState, state: &mut OpState,
args: QueueWriteTextureArgs, args: QueueWriteTextureArgs,
zero_copy: &mut [ZeroCopyBuf], zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let zero_copy = zero_copy.ok_or_else(null_opbuf)?;
let instance = state.borrow::<super::Instance>(); let instance = state.borrow::<super::Instance>();
let texture_resource = state let texture_resource = state
.resource_table .resource_table
@ -144,7 +147,7 @@ pub fn op_webgpu_write_texture(
let maybe_err = gfx_select!(queue => instance.queue_write_texture( let maybe_err = gfx_select!(queue => instance.queue_write_texture(
queue, queue,
&destination, &destination,
&*zero_copy[0], &*zero_copy,
&data_layout, &data_layout,
&wgpu_types::Extent3d { &wgpu_types::Extent3d {
width: args.size.width.unwrap_or(1), width: args.size.width.unwrap_or(1),

View file

@ -1,6 +1,7 @@
// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license. // Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.
use deno_core::error::bad_resource_id; use deno_core::error::bad_resource_id;
use deno_core::error::null_opbuf;
use deno_core::error::AnyError; use deno_core::error::AnyError;
use deno_core::serde_json::json; use deno_core::serde_json::json;
use deno_core::serde_json::Value; use deno_core::serde_json::Value;
@ -37,7 +38,7 @@ pub struct RenderPassSetViewportArgs {
pub fn op_webgpu_render_pass_set_viewport( pub fn op_webgpu_render_pass_set_viewport(
state: &mut OpState, state: &mut OpState,
args: RenderPassSetViewportArgs, args: RenderPassSetViewportArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let render_pass_resource = state let render_pass_resource = state
.resource_table .resource_table
@ -70,7 +71,7 @@ pub struct RenderPassSetScissorRectArgs {
pub fn op_webgpu_render_pass_set_scissor_rect( pub fn op_webgpu_render_pass_set_scissor_rect(
state: &mut OpState, state: &mut OpState,
args: RenderPassSetScissorRectArgs, args: RenderPassSetScissorRectArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let render_pass_resource = state let render_pass_resource = state
.resource_table .resource_table
@ -107,7 +108,7 @@ pub struct RenderPassSetBlendColorArgs {
pub fn op_webgpu_render_pass_set_blend_color( pub fn op_webgpu_render_pass_set_blend_color(
state: &mut OpState, state: &mut OpState,
args: RenderPassSetBlendColorArgs, args: RenderPassSetBlendColorArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let render_pass_resource = state let render_pass_resource = state
.resource_table .resource_table
@ -137,7 +138,7 @@ pub struct RenderPassSetStencilReferenceArgs {
pub fn op_webgpu_render_pass_set_stencil_reference( pub fn op_webgpu_render_pass_set_stencil_reference(
state: &mut OpState, state: &mut OpState,
args: RenderPassSetStencilReferenceArgs, args: RenderPassSetStencilReferenceArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let render_pass_resource = state let render_pass_resource = state
.resource_table .resource_table
@ -163,7 +164,7 @@ pub struct RenderPassBeginPipelineStatisticsQueryArgs {
pub fn op_webgpu_render_pass_begin_pipeline_statistics_query( pub fn op_webgpu_render_pass_begin_pipeline_statistics_query(
state: &mut OpState, state: &mut OpState,
args: RenderPassBeginPipelineStatisticsQueryArgs, args: RenderPassBeginPipelineStatisticsQueryArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let render_pass_resource = state let render_pass_resource = state
.resource_table .resource_table
@ -194,7 +195,7 @@ pub struct RenderPassEndPipelineStatisticsQueryArgs {
pub fn op_webgpu_render_pass_end_pipeline_statistics_query( pub fn op_webgpu_render_pass_end_pipeline_statistics_query(
state: &mut OpState, state: &mut OpState,
args: RenderPassEndPipelineStatisticsQueryArgs, args: RenderPassEndPipelineStatisticsQueryArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let render_pass_resource = state let render_pass_resource = state
.resource_table .resource_table
@ -221,7 +222,7 @@ pub struct RenderPassWriteTimestampArgs {
pub fn op_webgpu_render_pass_write_timestamp( pub fn op_webgpu_render_pass_write_timestamp(
state: &mut OpState, state: &mut OpState,
args: RenderPassWriteTimestampArgs, args: RenderPassWriteTimestampArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let render_pass_resource = state let render_pass_resource = state
.resource_table .resource_table
@ -253,7 +254,7 @@ pub struct RenderPassExecuteBundlesArgs {
pub fn op_webgpu_render_pass_execute_bundles( pub fn op_webgpu_render_pass_execute_bundles(
state: &mut OpState, state: &mut OpState,
args: RenderPassExecuteBundlesArgs, args: RenderPassExecuteBundlesArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let mut render_bundle_ids = vec![]; let mut render_bundle_ids = vec![];
@ -291,7 +292,7 @@ pub struct RenderPassEndPassArgs {
pub fn op_webgpu_render_pass_end_pass( pub fn op_webgpu_render_pass_end_pass(
state: &mut OpState, state: &mut OpState,
args: RenderPassEndPassArgs, args: RenderPassEndPassArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let command_encoder_resource = state let command_encoder_resource = state
.resource_table .resource_table
@ -326,8 +327,9 @@ pub struct RenderPassSetBindGroupArgs {
pub fn op_webgpu_render_pass_set_bind_group( pub fn op_webgpu_render_pass_set_bind_group(
state: &mut OpState, state: &mut OpState,
args: RenderPassSetBindGroupArgs, args: RenderPassSetBindGroupArgs,
zero_copy: &mut [ZeroCopyBuf], zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let zero_copy = zero_copy.ok_or_else(null_opbuf)?;
let bind_group_resource = state let bind_group_resource = state
.resource_table .resource_table
.get::<super::binding::WebGpuBindGroup>(args.bind_group) .get::<super::binding::WebGpuBindGroup>(args.bind_group)
@ -353,7 +355,7 @@ pub fn op_webgpu_render_pass_set_bind_group(
); );
}, },
None => { None => {
let (prefix, data, suffix) = unsafe { zero_copy[0].align_to::<u32>() }; let (prefix, data, suffix) = unsafe { zero_copy.align_to::<u32>() };
assert!(prefix.is_empty()); assert!(prefix.is_empty());
assert!(suffix.is_empty()); assert!(suffix.is_empty());
unsafe { unsafe {
@ -381,7 +383,7 @@ pub struct RenderPassPushDebugGroupArgs {
pub fn op_webgpu_render_pass_push_debug_group( pub fn op_webgpu_render_pass_push_debug_group(
state: &mut OpState, state: &mut OpState,
args: RenderPassPushDebugGroupArgs, args: RenderPassPushDebugGroupArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let render_pass_resource = state let render_pass_resource = state
.resource_table .resource_table
@ -409,7 +411,7 @@ pub struct RenderPassPopDebugGroupArgs {
pub fn op_webgpu_render_pass_pop_debug_group( pub fn op_webgpu_render_pass_pop_debug_group(
state: &mut OpState, state: &mut OpState,
args: RenderPassPopDebugGroupArgs, args: RenderPassPopDebugGroupArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let render_pass_resource = state let render_pass_resource = state
.resource_table .resource_table
@ -433,7 +435,7 @@ pub struct RenderPassInsertDebugMarkerArgs {
pub fn op_webgpu_render_pass_insert_debug_marker( pub fn op_webgpu_render_pass_insert_debug_marker(
state: &mut OpState, state: &mut OpState,
args: RenderPassInsertDebugMarkerArgs, args: RenderPassInsertDebugMarkerArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let render_pass_resource = state let render_pass_resource = state
.resource_table .resource_table
@ -462,7 +464,7 @@ pub struct RenderPassSetPipelineArgs {
pub fn op_webgpu_render_pass_set_pipeline( pub fn op_webgpu_render_pass_set_pipeline(
state: &mut OpState, state: &mut OpState,
args: RenderPassSetPipelineArgs, args: RenderPassSetPipelineArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let render_pipeline_resource = state let render_pipeline_resource = state
.resource_table .resource_table
@ -494,7 +496,7 @@ pub struct RenderPassSetIndexBufferArgs {
pub fn op_webgpu_render_pass_set_index_buffer( pub fn op_webgpu_render_pass_set_index_buffer(
state: &mut OpState, state: &mut OpState,
args: RenderPassSetIndexBufferArgs, args: RenderPassSetIndexBufferArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let buffer_resource = state let buffer_resource = state
.resource_table .resource_table
@ -528,7 +530,7 @@ pub struct RenderPassSetVertexBufferArgs {
pub fn op_webgpu_render_pass_set_vertex_buffer( pub fn op_webgpu_render_pass_set_vertex_buffer(
state: &mut OpState, state: &mut OpState,
args: RenderPassSetVertexBufferArgs, args: RenderPassSetVertexBufferArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let buffer_resource = state let buffer_resource = state
.resource_table .resource_table
@ -563,7 +565,7 @@ pub struct RenderPassDrawArgs {
pub fn op_webgpu_render_pass_draw( pub fn op_webgpu_render_pass_draw(
state: &mut OpState, state: &mut OpState,
args: RenderPassDrawArgs, args: RenderPassDrawArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let render_pass_resource = state let render_pass_resource = state
.resource_table .resource_table
@ -595,7 +597,7 @@ pub struct RenderPassDrawIndexedArgs {
pub fn op_webgpu_render_pass_draw_indexed( pub fn op_webgpu_render_pass_draw_indexed(
state: &mut OpState, state: &mut OpState,
args: RenderPassDrawIndexedArgs, args: RenderPassDrawIndexedArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let render_pass_resource = state let render_pass_resource = state
.resource_table .resource_table
@ -625,7 +627,7 @@ pub struct RenderPassDrawIndirectArgs {
pub fn op_webgpu_render_pass_draw_indirect( pub fn op_webgpu_render_pass_draw_indirect(
state: &mut OpState, state: &mut OpState,
args: RenderPassDrawIndirectArgs, args: RenderPassDrawIndirectArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let buffer_resource = state let buffer_resource = state
.resource_table .resource_table
@ -656,7 +658,7 @@ pub struct RenderPassDrawIndexedIndirectArgs {
pub fn op_webgpu_render_pass_draw_indexed_indirect( pub fn op_webgpu_render_pass_draw_indexed_indirect(
state: &mut OpState, state: &mut OpState,
args: RenderPassDrawIndexedIndirectArgs, args: RenderPassDrawIndexedIndirectArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let buffer_resource = state let buffer_resource = state
.resource_table .resource_table

View file

@ -82,7 +82,7 @@ pub struct CreateSamplerArgs {
pub fn op_webgpu_create_sampler( pub fn op_webgpu_create_sampler(
state: &mut OpState, state: &mut OpState,
args: CreateSamplerArgs, args: CreateSamplerArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let instance = state.borrow::<super::Instance>(); let instance = state.borrow::<super::Instance>();
let device_resource = state let device_resource = state

View file

@ -1,6 +1,7 @@
// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license. // Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.
use deno_core::error::bad_resource_id; use deno_core::error::bad_resource_id;
use deno_core::error::null_opbuf;
use deno_core::error::AnyError; use deno_core::error::AnyError;
use deno_core::serde_json::json; use deno_core::serde_json::json;
use deno_core::serde_json::Value; use deno_core::serde_json::Value;
@ -31,7 +32,7 @@ pub struct CreateShaderModuleArgs {
pub fn op_webgpu_create_shader_module( pub fn op_webgpu_create_shader_module(
state: &mut OpState, state: &mut OpState,
args: CreateShaderModuleArgs, args: CreateShaderModuleArgs,
zero_copy: &mut [ZeroCopyBuf], zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let instance = state.borrow::<super::Instance>(); let instance = state.borrow::<super::Instance>();
let device_resource = state let device_resource = state
@ -45,10 +46,15 @@ pub fn op_webgpu_create_shader_module(
wgpu_core::pipeline::ShaderModuleSource::Wgsl(Cow::from(code)) wgpu_core::pipeline::ShaderModuleSource::Wgsl(Cow::from(code))
} }
None => wgpu_core::pipeline::ShaderModuleSource::SpirV(Cow::from(unsafe { None => wgpu_core::pipeline::ShaderModuleSource::SpirV(Cow::from(unsafe {
let (prefix, data, suffix) = zero_copy[0].align_to::<u32>(); match &zero_copy {
Some(zero_copy) => {
let (prefix, data, suffix) = zero_copy.align_to::<u32>();
assert!(prefix.is_empty()); assert!(prefix.is_empty());
assert!(suffix.is_empty()); assert!(suffix.is_empty());
data data
}
None => return Err(null_opbuf()),
}
})), })),
}; };

View file

@ -147,7 +147,7 @@ pub struct CreateTextureArgs {
pub fn op_webgpu_create_texture( pub fn op_webgpu_create_texture(
state: &mut OpState, state: &mut OpState,
args: CreateTextureArgs, args: CreateTextureArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let instance = state.borrow::<super::Instance>(); let instance = state.borrow::<super::Instance>();
let device_resource = state let device_resource = state
@ -209,7 +209,7 @@ pub struct CreateTextureViewArgs {
pub fn op_webgpu_create_texture_view( pub fn op_webgpu_create_texture_view(
state: &mut OpState, state: &mut OpState,
args: CreateTextureViewArgs, args: CreateTextureViewArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let instance = state.borrow::<super::Instance>(); let instance = state.borrow::<super::Instance>();
let texture_resource = state let texture_resource = state

View file

@ -1,6 +1,7 @@
// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license. // Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.
use deno_core::error::bad_resource_id; use deno_core::error::bad_resource_id;
use deno_core::error::null_opbuf;
use deno_core::error::type_error; use deno_core::error::type_error;
use deno_core::error::AnyError; use deno_core::error::AnyError;
use deno_core::futures::stream::SplitSink; use deno_core::futures::stream::SplitSink;
@ -11,7 +12,6 @@ use deno_core::serde_json::json;
use deno_core::serde_json::Value; use deno_core::serde_json::Value;
use deno_core::url; use deno_core::url;
use deno_core::AsyncRefCell; use deno_core::AsyncRefCell;
use deno_core::BufVec;
use deno_core::CancelFuture; use deno_core::CancelFuture;
use deno_core::CancelHandle; use deno_core::CancelHandle;
use deno_core::JsRuntime; use deno_core::JsRuntime;
@ -94,7 +94,7 @@ pub struct CheckPermissionArgs {
pub fn op_ws_check_permission<WP>( pub fn op_ws_check_permission<WP>(
state: &mut OpState, state: &mut OpState,
args: CheckPermissionArgs, args: CheckPermissionArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> ) -> Result<Value, AnyError>
where where
WP: WebSocketPermissions + 'static, WP: WebSocketPermissions + 'static,
@ -116,7 +116,7 @@ pub struct CreateArgs {
pub async fn op_ws_create<WP>( pub async fn op_ws_create<WP>(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: CreateArgs, args: CreateArgs,
_bufs: BufVec, _bufs: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> ) -> Result<Value, AnyError>
where where
WP: WebSocketPermissions + 'static, WP: WebSocketPermissions + 'static,
@ -223,11 +223,11 @@ pub struct SendArgs {
pub async fn op_ws_send( pub async fn op_ws_send(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: SendArgs, args: SendArgs,
bufs: BufVec, buf: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let msg = match args.kind.as_str() { let msg = match args.kind.as_str() {
"text" => Message::Text(args.text.unwrap()), "text" => Message::Text(args.text.unwrap()),
"binary" => Message::Binary(bufs[0].to_vec()), "binary" => Message::Binary(buf.ok_or_else(null_opbuf)?.to_vec()),
"pong" => Message::Pong(vec![]), "pong" => Message::Pong(vec![]),
_ => unreachable!(), _ => unreachable!(),
}; };
@ -254,7 +254,7 @@ pub struct CloseArgs {
pub async fn op_ws_close( pub async fn op_ws_close(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: CloseArgs, args: CloseArgs,
_bufs: BufVec, _bufs: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let rid = args.rid; let rid = args.rid;
let msg = Message::Close(args.code.map(|c| CloseFrame { let msg = Message::Close(args.code.map(|c| CloseFrame {
@ -284,7 +284,7 @@ pub struct NextEventArgs {
pub async fn op_ws_next_event( pub async fn op_ws_next_event(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: NextEventArgs, args: NextEventArgs,
_bufs: BufVec, _bufs: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let resource = state let resource = state
.borrow_mut() .borrow_mut()

View file

@ -10,7 +10,6 @@ use deno_core::error::AnyError;
use deno_core::serde_json; use deno_core::serde_json;
use deno_core::serde_json::json; use deno_core::serde_json::json;
use deno_core::serde_json::Value; use deno_core::serde_json::Value;
use deno_core::BufVec;
use deno_core::OpState; use deno_core::OpState;
use deno_core::RcRef; use deno_core::RcRef;
use deno_core::ResourceId; use deno_core::ResourceId;
@ -183,7 +182,7 @@ fn open_helper(
fn op_open_sync( fn op_open_sync(
state: &mut OpState, state: &mut OpState,
args: OpenArgs, args: OpenArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let (path, open_options) = open_helper(state, args)?; let (path, open_options) = open_helper(state, args)?;
let std_file = open_options.open(path)?; let std_file = open_options.open(path)?;
@ -196,7 +195,7 @@ fn op_open_sync(
async fn op_open_async( async fn op_open_async(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: OpenArgs, args: OpenArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let (path, open_options) = open_helper(&mut state.borrow_mut(), args)?; let (path, open_options) = open_helper(&mut state.borrow_mut(), args)?;
let tokio_file = tokio::fs::OpenOptions::from(open_options) let tokio_file = tokio::fs::OpenOptions::from(open_options)
@ -235,7 +234,7 @@ fn seek_helper(args: SeekArgs) -> Result<(u32, SeekFrom), AnyError> {
fn op_seek_sync( fn op_seek_sync(
state: &mut OpState, state: &mut OpState,
args: SeekArgs, args: SeekArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let (rid, seek_from) = seek_helper(args)?; let (rid, seek_from) = seek_helper(args)?;
let pos = StdFileResource::with(state, rid, |r| match r { let pos = StdFileResource::with(state, rid, |r| match r {
@ -250,7 +249,7 @@ fn op_seek_sync(
async fn op_seek_async( async fn op_seek_async(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: SeekArgs, args: SeekArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let (rid, seek_from) = seek_helper(args)?; let (rid, seek_from) = seek_helper(args)?;
@ -281,7 +280,7 @@ pub struct FdatasyncArgs {
fn op_fdatasync_sync( fn op_fdatasync_sync(
state: &mut OpState, state: &mut OpState,
args: FdatasyncArgs, args: FdatasyncArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let rid = args.rid; let rid = args.rid;
StdFileResource::with(state, rid, |r| match r { StdFileResource::with(state, rid, |r| match r {
@ -294,7 +293,7 @@ fn op_fdatasync_sync(
async fn op_fdatasync_async( async fn op_fdatasync_async(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: FdatasyncArgs, args: FdatasyncArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let rid = args.rid; let rid = args.rid;
@ -325,7 +324,7 @@ pub struct FsyncArgs {
fn op_fsync_sync( fn op_fsync_sync(
state: &mut OpState, state: &mut OpState,
args: FsyncArgs, args: FsyncArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let rid = args.rid; let rid = args.rid;
StdFileResource::with(state, rid, |r| match r { StdFileResource::with(state, rid, |r| match r {
@ -338,7 +337,7 @@ fn op_fsync_sync(
async fn op_fsync_async( async fn op_fsync_async(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: FsyncArgs, args: FsyncArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let rid = args.rid; let rid = args.rid;
@ -369,7 +368,7 @@ pub struct FstatArgs {
fn op_fstat_sync( fn op_fstat_sync(
state: &mut OpState, state: &mut OpState,
args: FstatArgs, args: FstatArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
super::check_unstable(state, "Deno.fstat"); super::check_unstable(state, "Deno.fstat");
let metadata = StdFileResource::with(state, args.rid, |r| match r { let metadata = StdFileResource::with(state, args.rid, |r| match r {
@ -382,7 +381,7 @@ fn op_fstat_sync(
async fn op_fstat_async( async fn op_fstat_async(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: FstatArgs, args: FstatArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
super::check_unstable2(&state, "Deno.fstat"); super::check_unstable2(&state, "Deno.fstat");
@ -415,7 +414,7 @@ pub struct UmaskArgs {
fn op_umask( fn op_umask(
state: &mut OpState, state: &mut OpState,
args: UmaskArgs, args: UmaskArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
super::check_unstable(state, "Deno.umask"); super::check_unstable(state, "Deno.umask");
// TODO implement umask for Windows // TODO implement umask for Windows
@ -452,7 +451,7 @@ pub struct ChdirArgs {
fn op_chdir( fn op_chdir(
state: &mut OpState, state: &mut OpState,
args: ChdirArgs, args: ChdirArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let d = PathBuf::from(&args.directory); let d = PathBuf::from(&args.directory);
state.borrow::<Permissions>().read.check(&d)?; state.borrow::<Permissions>().read.check(&d)?;
@ -471,7 +470,7 @@ pub struct MkdirArgs {
fn op_mkdir_sync( fn op_mkdir_sync(
state: &mut OpState, state: &mut OpState,
args: MkdirArgs, args: MkdirArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let path = Path::new(&args.path).to_path_buf(); let path = Path::new(&args.path).to_path_buf();
let mode = args.mode.unwrap_or(0o777) & 0o777; let mode = args.mode.unwrap_or(0o777) & 0o777;
@ -491,7 +490,7 @@ fn op_mkdir_sync(
async fn op_mkdir_async( async fn op_mkdir_async(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: MkdirArgs, args: MkdirArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let path = Path::new(&args.path).to_path_buf(); let path = Path::new(&args.path).to_path_buf();
let mode = args.mode.unwrap_or(0o777) & 0o777; let mode = args.mode.unwrap_or(0o777) & 0o777;
@ -527,7 +526,7 @@ pub struct ChmodArgs {
fn op_chmod_sync( fn op_chmod_sync(
state: &mut OpState, state: &mut OpState,
args: ChmodArgs, args: ChmodArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let path = Path::new(&args.path).to_path_buf(); let path = Path::new(&args.path).to_path_buf();
let mode = args.mode & 0o777; let mode = args.mode & 0o777;
@ -553,7 +552,7 @@ fn op_chmod_sync(
async fn op_chmod_async( async fn op_chmod_async(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: ChmodArgs, args: ChmodArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let path = Path::new(&args.path).to_path_buf(); let path = Path::new(&args.path).to_path_buf();
let mode = args.mode & 0o777; let mode = args.mode & 0o777;
@ -595,7 +594,7 @@ pub struct ChownArgs {
fn op_chown_sync( fn op_chown_sync(
state: &mut OpState, state: &mut OpState,
args: ChownArgs, args: ChownArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let path = Path::new(&args.path).to_path_buf(); let path = Path::new(&args.path).to_path_buf();
state.borrow::<Permissions>().write.check(&path)?; state.borrow::<Permissions>().write.check(&path)?;
@ -623,7 +622,7 @@ fn op_chown_sync(
async fn op_chown_async( async fn op_chown_async(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: ChownArgs, args: ChownArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let path = Path::new(&args.path).to_path_buf(); let path = Path::new(&args.path).to_path_buf();
@ -665,7 +664,7 @@ pub struct RemoveArgs {
fn op_remove_sync( fn op_remove_sync(
state: &mut OpState, state: &mut OpState,
args: RemoveArgs, args: RemoveArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let path = PathBuf::from(&args.path); let path = PathBuf::from(&args.path);
let recursive = args.recursive; let recursive = args.recursive;
@ -707,7 +706,7 @@ fn op_remove_sync(
async fn op_remove_async( async fn op_remove_async(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: RemoveArgs, args: RemoveArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let path = PathBuf::from(&args.path); let path = PathBuf::from(&args.path);
let recursive = args.recursive; let recursive = args.recursive;
@ -763,7 +762,7 @@ pub struct CopyFileArgs {
fn op_copy_file_sync( fn op_copy_file_sync(
state: &mut OpState, state: &mut OpState,
args: CopyFileArgs, args: CopyFileArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let from = PathBuf::from(&args.from); let from = PathBuf::from(&args.from);
let to = PathBuf::from(&args.to); let to = PathBuf::from(&args.to);
@ -788,7 +787,7 @@ fn op_copy_file_sync(
async fn op_copy_file_async( async fn op_copy_file_async(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: CopyFileArgs, args: CopyFileArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let from = PathBuf::from(&args.from); let from = PathBuf::from(&args.from);
let to = PathBuf::from(&args.to); let to = PathBuf::from(&args.to);
@ -885,7 +884,7 @@ pub struct StatArgs {
fn op_stat_sync( fn op_stat_sync(
state: &mut OpState, state: &mut OpState,
args: StatArgs, args: StatArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let path = PathBuf::from(&args.path); let path = PathBuf::from(&args.path);
let lstat = args.lstat; let lstat = args.lstat;
@ -902,7 +901,7 @@ fn op_stat_sync(
async fn op_stat_async( async fn op_stat_async(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: StatArgs, args: StatArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let path = PathBuf::from(&args.path); let path = PathBuf::from(&args.path);
let lstat = args.lstat; let lstat = args.lstat;
@ -934,7 +933,7 @@ pub struct RealpathArgs {
fn op_realpath_sync( fn op_realpath_sync(
state: &mut OpState, state: &mut OpState,
args: RealpathArgs, args: RealpathArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let path = PathBuf::from(&args.path); let path = PathBuf::from(&args.path);
@ -955,7 +954,7 @@ fn op_realpath_sync(
async fn op_realpath_async( async fn op_realpath_async(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: RealpathArgs, args: RealpathArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let path = PathBuf::from(&args.path); let path = PathBuf::from(&args.path);
@ -989,7 +988,7 @@ pub struct ReadDirArgs {
fn op_read_dir_sync( fn op_read_dir_sync(
state: &mut OpState, state: &mut OpState,
args: ReadDirArgs, args: ReadDirArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let path = PathBuf::from(&args.path); let path = PathBuf::from(&args.path);
@ -1019,7 +1018,7 @@ fn op_read_dir_sync(
async fn op_read_dir_async( async fn op_read_dir_async(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: ReadDirArgs, args: ReadDirArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let path = PathBuf::from(&args.path); let path = PathBuf::from(&args.path);
{ {
@ -1061,7 +1060,7 @@ pub struct RenameArgs {
fn op_rename_sync( fn op_rename_sync(
state: &mut OpState, state: &mut OpState,
args: RenameArgs, args: RenameArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let oldpath = PathBuf::from(&args.oldpath); let oldpath = PathBuf::from(&args.oldpath);
let newpath = PathBuf::from(&args.newpath); let newpath = PathBuf::from(&args.newpath);
@ -1078,7 +1077,7 @@ fn op_rename_sync(
async fn op_rename_async( async fn op_rename_async(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: RenameArgs, args: RenameArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let oldpath = PathBuf::from(&args.oldpath); let oldpath = PathBuf::from(&args.oldpath);
let newpath = PathBuf::from(&args.newpath); let newpath = PathBuf::from(&args.newpath);
@ -1112,7 +1111,7 @@ pub struct LinkArgs {
fn op_link_sync( fn op_link_sync(
state: &mut OpState, state: &mut OpState,
args: LinkArgs, args: LinkArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let oldpath = PathBuf::from(&args.oldpath); let oldpath = PathBuf::from(&args.oldpath);
let newpath = PathBuf::from(&args.newpath); let newpath = PathBuf::from(&args.newpath);
@ -1131,7 +1130,7 @@ fn op_link_sync(
async fn op_link_async( async fn op_link_async(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: LinkArgs, args: LinkArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let oldpath = PathBuf::from(&args.oldpath); let oldpath = PathBuf::from(&args.oldpath);
let newpath = PathBuf::from(&args.newpath); let newpath = PathBuf::from(&args.newpath);
@ -1173,7 +1172,7 @@ pub struct SymlinkOptions {
fn op_symlink_sync( fn op_symlink_sync(
state: &mut OpState, state: &mut OpState,
args: SymlinkArgs, args: SymlinkArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let oldpath = PathBuf::from(&args.oldpath); let oldpath = PathBuf::from(&args.oldpath);
let newpath = PathBuf::from(&args.newpath); let newpath = PathBuf::from(&args.newpath);
@ -1222,7 +1221,7 @@ fn op_symlink_sync(
async fn op_symlink_async( async fn op_symlink_async(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: SymlinkArgs, args: SymlinkArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let oldpath = PathBuf::from(&args.oldpath); let oldpath = PathBuf::from(&args.oldpath);
let newpath = PathBuf::from(&args.newpath); let newpath = PathBuf::from(&args.newpath);
@ -1280,7 +1279,7 @@ pub struct ReadLinkArgs {
fn op_read_link_sync( fn op_read_link_sync(
state: &mut OpState, state: &mut OpState,
args: ReadLinkArgs, args: ReadLinkArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let path = PathBuf::from(&args.path); let path = PathBuf::from(&args.path);
@ -1295,7 +1294,7 @@ fn op_read_link_sync(
async fn op_read_link_async( async fn op_read_link_async(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: ReadLinkArgs, args: ReadLinkArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let path = PathBuf::from(&args.path); let path = PathBuf::from(&args.path);
{ {
@ -1322,7 +1321,7 @@ pub struct FtruncateArgs {
fn op_ftruncate_sync( fn op_ftruncate_sync(
state: &mut OpState, state: &mut OpState,
args: FtruncateArgs, args: FtruncateArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
super::check_unstable(state, "Deno.ftruncate"); super::check_unstable(state, "Deno.ftruncate");
let rid = args.rid; let rid = args.rid;
@ -1337,7 +1336,7 @@ fn op_ftruncate_sync(
async fn op_ftruncate_async( async fn op_ftruncate_async(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: FtruncateArgs, args: FtruncateArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
super::check_unstable2(&state, "Deno.ftruncate"); super::check_unstable2(&state, "Deno.ftruncate");
let rid = args.rid; let rid = args.rid;
@ -1371,7 +1370,7 @@ pub struct TruncateArgs {
fn op_truncate_sync( fn op_truncate_sync(
state: &mut OpState, state: &mut OpState,
args: TruncateArgs, args: TruncateArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let path = PathBuf::from(&args.path); let path = PathBuf::from(&args.path);
let len = args.len; let len = args.len;
@ -1387,7 +1386,7 @@ fn op_truncate_sync(
async fn op_truncate_async( async fn op_truncate_async(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: TruncateArgs, args: TruncateArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let path = PathBuf::from(&args.path); let path = PathBuf::from(&args.path);
let len = args.len; let len = args.len;
@ -1461,7 +1460,7 @@ pub struct MakeTempArgs {
fn op_make_temp_dir_sync( fn op_make_temp_dir_sync(
state: &mut OpState, state: &mut OpState,
args: MakeTempArgs, args: MakeTempArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let dir = args.dir.map(|s| PathBuf::from(&s)); let dir = args.dir.map(|s| PathBuf::from(&s));
let prefix = args.prefix.map(String::from); let prefix = args.prefix.map(String::from);
@ -1490,7 +1489,7 @@ fn op_make_temp_dir_sync(
async fn op_make_temp_dir_async( async fn op_make_temp_dir_async(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: MakeTempArgs, args: MakeTempArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let dir = args.dir.map(|s| PathBuf::from(&s)); let dir = args.dir.map(|s| PathBuf::from(&s));
let prefix = args.prefix.map(String::from); let prefix = args.prefix.map(String::from);
@ -1524,7 +1523,7 @@ async fn op_make_temp_dir_async(
fn op_make_temp_file_sync( fn op_make_temp_file_sync(
state: &mut OpState, state: &mut OpState,
args: MakeTempArgs, args: MakeTempArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let dir = args.dir.map(|s| PathBuf::from(&s)); let dir = args.dir.map(|s| PathBuf::from(&s));
let prefix = args.prefix.map(String::from); let prefix = args.prefix.map(String::from);
@ -1553,7 +1552,7 @@ fn op_make_temp_file_sync(
async fn op_make_temp_file_async( async fn op_make_temp_file_async(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: MakeTempArgs, args: MakeTempArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let dir = args.dir.map(|s| PathBuf::from(&s)); let dir = args.dir.map(|s| PathBuf::from(&s));
let prefix = args.prefix.map(String::from); let prefix = args.prefix.map(String::from);
@ -1595,7 +1594,7 @@ pub struct FutimeArgs {
fn op_futime_sync( fn op_futime_sync(
state: &mut OpState, state: &mut OpState,
args: FutimeArgs, args: FutimeArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
super::check_unstable(state, "Deno.futimeSync"); super::check_unstable(state, "Deno.futimeSync");
let rid = args.rid; let rid = args.rid;
@ -1618,7 +1617,7 @@ fn op_futime_sync(
async fn op_futime_async( async fn op_futime_async(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: FutimeArgs, args: FutimeArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
super::check_unstable2(&state, "Deno.futime"); super::check_unstable2(&state, "Deno.futime");
let rid = args.rid; let rid = args.rid;
@ -1667,7 +1666,7 @@ pub struct UtimeArgs {
fn op_utime_sync( fn op_utime_sync(
state: &mut OpState, state: &mut OpState,
args: UtimeArgs, args: UtimeArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
super::check_unstable(state, "Deno.utime"); super::check_unstable(state, "Deno.utime");
@ -1683,7 +1682,7 @@ fn op_utime_sync(
async fn op_utime_async( async fn op_utime_async(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: UtimeArgs, args: UtimeArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
super::check_unstable(&state.borrow(), "Deno.utime"); super::check_unstable(&state.borrow(), "Deno.utime");
@ -1704,7 +1703,7 @@ async fn op_utime_async(
fn op_cwd( fn op_cwd(
state: &mut OpState, state: &mut OpState,
_args: Value, _args: Value,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let path = current_dir()?; let path = current_dir()?;
state state

View file

@ -6,7 +6,6 @@ use deno_core::error::AnyError;
use deno_core::serde_json::json; use deno_core::serde_json::json;
use deno_core::serde_json::Value; use deno_core::serde_json::Value;
use deno_core::AsyncRefCell; use deno_core::AsyncRefCell;
use deno_core::BufVec;
use deno_core::CancelFuture; use deno_core::CancelFuture;
use deno_core::CancelHandle; use deno_core::CancelHandle;
use deno_core::OpState; use deno_core::OpState;
@ -93,7 +92,7 @@ pub struct OpenArgs {
fn op_fs_events_open( fn op_fs_events_open(
state: &mut OpState, state: &mut OpState,
args: OpenArgs, args: OpenArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let (sender, receiver) = mpsc::channel::<Result<FsEvent, AnyError>>(16); let (sender, receiver) = mpsc::channel::<Result<FsEvent, AnyError>>(16);
let sender = std::sync::Mutex::new(sender); let sender = std::sync::Mutex::new(sender);
@ -134,7 +133,7 @@ pub struct PollArgs {
async fn op_fs_events_poll( async fn op_fs_events_poll(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: PollArgs, args: PollArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let resource = state let resource = state
.borrow() .borrow()

View file

@ -1,5 +1,6 @@
// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license. // Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.
use deno_core::error::null_opbuf;
use deno_core::error::resource_unavailable; use deno_core::error::resource_unavailable;
use deno_core::error::AnyError; use deno_core::error::AnyError;
use deno_core::error::{bad_resource_id, not_supported}; use deno_core::error::{bad_resource_id, not_supported};
@ -7,7 +8,6 @@ use deno_core::serde_json::json;
use deno_core::serde_json::Value; use deno_core::serde_json::Value;
use deno_core::AsyncMutFuture; use deno_core::AsyncMutFuture;
use deno_core::AsyncRefCell; use deno_core::AsyncRefCell;
use deno_core::BufVec;
use deno_core::CancelHandle; use deno_core::CancelHandle;
use deno_core::CancelTryFuture; use deno_core::CancelTryFuture;
use deno_core::JsRuntime; use deno_core::JsRuntime;
@ -523,11 +523,12 @@ impl Resource for StdFileResource {
fn op_read_sync( fn op_read_sync(
state: &mut OpState, state: &mut OpState,
rid: ResourceId, rid: ResourceId,
bufs: &mut [ZeroCopyBuf], buf: Option<ZeroCopyBuf>,
) -> Result<u32, AnyError> { ) -> Result<u32, AnyError> {
let mut buf = buf.ok_or_else(null_opbuf)?;
StdFileResource::with(state, rid, move |r| match r { StdFileResource::with(state, rid, move |r| match r {
Ok(std_file) => std_file Ok(std_file) => std_file
.read(&mut bufs[0]) .read(&mut buf)
.map(|n: usize| n as u32) .map(|n: usize| n as u32)
.map_err(AnyError::from), .map_err(AnyError::from),
Err(_) => Err(not_supported()), Err(_) => Err(not_supported()),
@ -537,9 +538,9 @@ fn op_read_sync(
async fn op_read_async( async fn op_read_async(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
rid: ResourceId, rid: ResourceId,
mut bufs: BufVec, buf: Option<ZeroCopyBuf>,
) -> Result<u32, AnyError> { ) -> Result<u32, AnyError> {
let buf = &mut bufs[0]; let buf = &mut buf.ok_or_else(null_opbuf)?;
let resource = state let resource = state
.borrow() .borrow()
.resource_table .resource_table
@ -568,11 +569,12 @@ async fn op_read_async(
fn op_write_sync( fn op_write_sync(
state: &mut OpState, state: &mut OpState,
rid: ResourceId, rid: ResourceId,
bufs: &mut [ZeroCopyBuf], buf: Option<ZeroCopyBuf>,
) -> Result<u32, AnyError> { ) -> Result<u32, AnyError> {
let buf = buf.ok_or_else(null_opbuf)?;
StdFileResource::with(state, rid, move |r| match r { StdFileResource::with(state, rid, move |r| match r {
Ok(std_file) => std_file Ok(std_file) => std_file
.write(&bufs[0]) .write(&buf)
.map(|nwritten: usize| nwritten as u32) .map(|nwritten: usize| nwritten as u32)
.map_err(AnyError::from), .map_err(AnyError::from),
Err(_) => Err(not_supported()), Err(_) => Err(not_supported()),
@ -582,9 +584,9 @@ fn op_write_sync(
async fn op_write_async( async fn op_write_async(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
rid: ResourceId, rid: ResourceId,
bufs: BufVec, buf: Option<ZeroCopyBuf>,
) -> Result<u32, AnyError> { ) -> Result<u32, AnyError> {
let buf = &bufs[0]; let buf = &buf.ok_or_else(null_opbuf)?;
let resource = state let resource = state
.borrow() .borrow()
.resource_table .resource_table
@ -616,7 +618,7 @@ struct ShutdownArgs {
async fn op_shutdown( async fn op_shutdown(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: ShutdownArgs, args: ShutdownArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let resource = state let resource = state
.borrow() .borrow()

View file

@ -31,7 +31,6 @@ use deno_core::json_op_async;
use deno_core::json_op_sync; use deno_core::json_op_sync;
use deno_core::serde::de::DeserializeOwned; use deno_core::serde::de::DeserializeOwned;
use deno_core::serde::Serialize; use deno_core::serde::Serialize;
use deno_core::BufVec;
use deno_core::JsRuntime; use deno_core::JsRuntime;
use deno_core::OpState; use deno_core::OpState;
use deno_core::ValueOrVector; use deno_core::ValueOrVector;
@ -45,7 +44,7 @@ pub fn reg_json_async<F, V, R, RV>(
name: &'static str, name: &'static str,
op_fn: F, op_fn: F,
) where ) where
F: Fn(Rc<RefCell<OpState>>, V, BufVec) -> R + 'static, F: Fn(Rc<RefCell<OpState>>, V, Option<ZeroCopyBuf>) -> R + 'static,
V: DeserializeOwned, V: DeserializeOwned,
R: Future<Output = Result<RV, AnyError>> + 'static, R: Future<Output = Result<RV, AnyError>> + 'static,
RV: Serialize + 'static, RV: Serialize + 'static,
@ -55,7 +54,7 @@ pub fn reg_json_async<F, V, R, RV>(
pub fn reg_json_sync<F, V, R>(rt: &mut JsRuntime, name: &'static str, op_fn: F) pub fn reg_json_sync<F, V, R>(rt: &mut JsRuntime, name: &'static str, op_fn: F)
where where
F: Fn(&mut OpState, V, &mut [ZeroCopyBuf]) -> Result<R, AnyError> + 'static, F: Fn(&mut OpState, V, Option<ZeroCopyBuf>) -> Result<R, AnyError> + 'static,
V: DeserializeOwned, V: DeserializeOwned,
R: Serialize + 'static, R: Serialize + 'static,
{ {
@ -64,7 +63,7 @@ where
pub fn reg_bin_async<F, R, RV>(rt: &mut JsRuntime, name: &'static str, op_fn: F) pub fn reg_bin_async<F, R, RV>(rt: &mut JsRuntime, name: &'static str, op_fn: F)
where where
F: Fn(Rc<RefCell<OpState>>, u32, BufVec) -> R + 'static, F: Fn(Rc<RefCell<OpState>>, u32, Option<ZeroCopyBuf>) -> R + 'static,
R: Future<Output = Result<RV, AnyError>> + 'static, R: Future<Output = Result<RV, AnyError>> + 'static,
RV: ValueOrVector, RV: ValueOrVector,
{ {
@ -73,7 +72,8 @@ where
pub fn reg_bin_sync<F, R>(rt: &mut JsRuntime, name: &'static str, op_fn: F) pub fn reg_bin_sync<F, R>(rt: &mut JsRuntime, name: &'static str, op_fn: F)
where where
F: Fn(&mut OpState, u32, &mut [ZeroCopyBuf]) -> Result<R, AnyError> + 'static, F:
Fn(&mut OpState, u32, Option<ZeroCopyBuf>) -> Result<R, AnyError> + 'static,
R: ValueOrVector, R: ValueOrVector,
{ {
rt.register_op(name, metrics_op(name, bin_op_sync(op_fn))); rt.register_op(name, metrics_op(name, bin_op_sync(op_fn)));

View file

@ -6,13 +6,13 @@ use crate::resolve_addr::resolve_addr_sync;
use deno_core::error::bad_resource; use deno_core::error::bad_resource;
use deno_core::error::custom_error; use deno_core::error::custom_error;
use deno_core::error::generic_error; use deno_core::error::generic_error;
use deno_core::error::null_opbuf;
use deno_core::error::type_error; use deno_core::error::type_error;
use deno_core::error::AnyError; use deno_core::error::AnyError;
use deno_core::serde_json; use deno_core::serde_json;
use deno_core::serde_json::json; use deno_core::serde_json::json;
use deno_core::serde_json::Value; use deno_core::serde_json::Value;
use deno_core::AsyncRefCell; use deno_core::AsyncRefCell;
use deno_core::BufVec;
use deno_core::CancelHandle; use deno_core::CancelHandle;
use deno_core::CancelTryFuture; use deno_core::CancelTryFuture;
use deno_core::OpState; use deno_core::OpState;
@ -63,7 +63,7 @@ pub(crate) struct AcceptArgs {
async fn accept_tcp( async fn accept_tcp(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: AcceptArgs, args: AcceptArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let rid = args.rid; let rid = args.rid;
@ -110,13 +110,13 @@ async fn accept_tcp(
async fn op_accept( async fn op_accept(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: Value, args: Value,
bufs: BufVec, _buf: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let args: AcceptArgs = serde_json::from_value(args)?; let args: AcceptArgs = serde_json::from_value(args)?;
match args.transport.as_str() { match args.transport.as_str() {
"tcp" => accept_tcp(state, args, bufs).await, "tcp" => accept_tcp(state, args, _buf).await,
#[cfg(unix)] #[cfg(unix)]
"unix" => net_unix::accept_unix(state, args, bufs).await, "unix" => net_unix::accept_unix(state, args, _buf).await,
_ => Err(generic_error(format!( _ => Err(generic_error(format!(
"Unsupported transport protocol {}", "Unsupported transport protocol {}",
args.transport args.transport
@ -133,10 +133,10 @@ pub(crate) struct ReceiveArgs {
async fn receive_udp( async fn receive_udp(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: ReceiveArgs, args: ReceiveArgs,
zero_copy: BufVec, zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
assert_eq!(zero_copy.len(), 1, "Invalid number of arguments"); let zero_copy = zero_copy.ok_or_else(null_opbuf)?;
let mut zero_copy = zero_copy[0].clone(); let mut zero_copy = zero_copy.clone();
let rid = args.rid; let rid = args.rid;
@ -164,10 +164,8 @@ async fn receive_udp(
async fn op_datagram_receive( async fn op_datagram_receive(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: Value, args: Value,
zero_copy: BufVec, zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
assert_eq!(zero_copy.len(), 1, "Invalid number of arguments");
let args: ReceiveArgs = serde_json::from_value(args)?; let args: ReceiveArgs = serde_json::from_value(args)?;
match args.transport.as_str() { match args.transport.as_str() {
"udp" => receive_udp(state, args, zero_copy).await, "udp" => receive_udp(state, args, zero_copy).await,
@ -191,10 +189,10 @@ struct SendArgs {
async fn op_datagram_send( async fn op_datagram_send(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: Value, args: Value,
zero_copy: BufVec, zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
assert_eq!(zero_copy.len(), 1, "Invalid number of arguments"); let zero_copy = zero_copy.ok_or_else(null_opbuf)?;
let zero_copy = zero_copy[0].clone(); let zero_copy = zero_copy.clone();
match serde_json::from_value(args)? { match serde_json::from_value(args)? {
SendArgs { SendArgs {
@ -260,7 +258,7 @@ struct ConnectArgs {
async fn op_connect( async fn op_connect(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: Value, args: Value,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
match serde_json::from_value(args)? { match serde_json::from_value(args)? {
ConnectArgs { ConnectArgs {
@ -424,7 +422,7 @@ fn listen_udp(
fn op_listen( fn op_listen(
state: &mut OpState, state: &mut OpState,
args: Value, args: Value,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let permissions = state.borrow::<Permissions>(); let permissions = state.borrow::<Permissions>();
match serde_json::from_value(args)? { match serde_json::from_value(args)? {
@ -550,7 +548,7 @@ pub struct NameServer {
async fn op_dns_resolve( async fn op_dns_resolve(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: ResolveAddrArgs, args: ResolveAddrArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let ResolveAddrArgs { let ResolveAddrArgs {
query, query,

View file

@ -5,16 +5,17 @@ use crate::ops::net::AcceptArgs;
use crate::ops::net::ReceiveArgs; use crate::ops::net::ReceiveArgs;
use deno_core::error::bad_resource; use deno_core::error::bad_resource;
use deno_core::error::custom_error; use deno_core::error::custom_error;
use deno_core::error::null_opbuf;
use deno_core::error::AnyError; use deno_core::error::AnyError;
use deno_core::serde_json::json; use deno_core::serde_json::json;
use deno_core::serde_json::Value; use deno_core::serde_json::Value;
use deno_core::AsyncRefCell; use deno_core::AsyncRefCell;
use deno_core::BufVec;
use deno_core::CancelHandle; use deno_core::CancelHandle;
use deno_core::CancelTryFuture; use deno_core::CancelTryFuture;
use deno_core::OpState; use deno_core::OpState;
use deno_core::RcRef; use deno_core::RcRef;
use deno_core::Resource; use deno_core::Resource;
use deno_core::ZeroCopyBuf;
use serde::Deserialize; use serde::Deserialize;
use std::borrow::Cow; use std::borrow::Cow;
use std::cell::RefCell; use std::cell::RefCell;
@ -63,7 +64,7 @@ pub struct UnixListenArgs {
pub(crate) async fn accept_unix( pub(crate) async fn accept_unix(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: AcceptArgs, args: AcceptArgs,
_bufs: BufVec, _bufs: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let rid = args.rid; let rid = args.rid;
@ -100,12 +101,11 @@ pub(crate) async fn accept_unix(
pub(crate) async fn receive_unix_packet( pub(crate) async fn receive_unix_packet(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: ReceiveArgs, args: ReceiveArgs,
bufs: BufVec, buf: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
assert_eq!(bufs.len(), 1, "Invalid number of arguments"); let mut buf = buf.ok_or_else(null_opbuf)?;
let rid = args.rid; let rid = args.rid;
let mut buf = bufs.into_iter().next().unwrap();
let resource = state let resource = state
.borrow() .borrow()

View file

@ -28,7 +28,7 @@ pub fn init(rt: &mut deno_core::JsRuntime) {
fn op_exec_path( fn op_exec_path(
state: &mut OpState, state: &mut OpState,
_args: Value, _args: Value,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let current_exe = env::current_exe().unwrap(); let current_exe = env::current_exe().unwrap();
state state
@ -51,7 +51,7 @@ pub struct SetEnv {
fn op_set_env( fn op_set_env(
state: &mut OpState, state: &mut OpState,
args: SetEnv, args: SetEnv,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
state.borrow::<Permissions>().env.check()?; state.borrow::<Permissions>().env.check()?;
let invalid_key = let invalid_key =
@ -67,7 +67,7 @@ fn op_set_env(
fn op_env( fn op_env(
state: &mut OpState, state: &mut OpState,
_args: Value, _args: Value,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
state.borrow::<Permissions>().env.check()?; state.borrow::<Permissions>().env.check()?;
let v = env::vars().collect::<HashMap<String, String>>(); let v = env::vars().collect::<HashMap<String, String>>();
@ -82,7 +82,7 @@ pub struct GetEnv {
fn op_get_env( fn op_get_env(
state: &mut OpState, state: &mut OpState,
args: GetEnv, args: GetEnv,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
state.borrow::<Permissions>().env.check()?; state.borrow::<Permissions>().env.check()?;
if args.key.is_empty() || args.key.contains(&['=', '\0'] as &[char]) { if args.key.is_empty() || args.key.contains(&['=', '\0'] as &[char]) {
@ -103,7 +103,7 @@ pub struct DeleteEnv {
fn op_delete_env( fn op_delete_env(
state: &mut OpState, state: &mut OpState,
args: DeleteEnv, args: DeleteEnv,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
state.borrow::<Permissions>().env.check()?; state.borrow::<Permissions>().env.check()?;
if args.key.is_empty() || args.key.contains(&['=', '\0'] as &[char]) { if args.key.is_empty() || args.key.contains(&['=', '\0'] as &[char]) {
@ -121,7 +121,7 @@ pub struct Exit {
fn op_exit( fn op_exit(
_state: &mut OpState, _state: &mut OpState,
args: Exit, args: Exit,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
std::process::exit(args.code) std::process::exit(args.code)
} }
@ -129,7 +129,7 @@ fn op_exit(
fn op_loadavg( fn op_loadavg(
state: &mut OpState, state: &mut OpState,
_args: Value, _args: Value,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
super::check_unstable(state, "Deno.loadavg"); super::check_unstable(state, "Deno.loadavg");
state.borrow::<Permissions>().env.check()?; state.borrow::<Permissions>().env.check()?;
@ -142,7 +142,7 @@ fn op_loadavg(
fn op_hostname( fn op_hostname(
state: &mut OpState, state: &mut OpState,
_args: Value, _args: Value,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
super::check_unstable(state, "Deno.hostname"); super::check_unstable(state, "Deno.hostname");
state.borrow::<Permissions>().env.check()?; state.borrow::<Permissions>().env.check()?;
@ -153,7 +153,7 @@ fn op_hostname(
fn op_os_release( fn op_os_release(
state: &mut OpState, state: &mut OpState,
_args: Value, _args: Value,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
super::check_unstable(state, "Deno.osRelease"); super::check_unstable(state, "Deno.osRelease");
state.borrow::<Permissions>().env.check()?; state.borrow::<Permissions>().env.check()?;
@ -164,7 +164,7 @@ fn op_os_release(
fn op_system_memory_info( fn op_system_memory_info(
state: &mut OpState, state: &mut OpState,
_args: Value, _args: Value,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
super::check_unstable(state, "Deno.systemMemoryInfo"); super::check_unstable(state, "Deno.systemMemoryInfo");
state.borrow::<Permissions>().env.check()?; state.borrow::<Permissions>().env.check()?;
@ -185,7 +185,7 @@ fn op_system_memory_info(
fn op_system_cpu_info( fn op_system_cpu_info(
state: &mut OpState, state: &mut OpState,
_args: Value, _args: Value,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
super::check_unstable(state, "Deno.systemCpuInfo"); super::check_unstable(state, "Deno.systemCpuInfo");
state.borrow::<Permissions>().env.check()?; state.borrow::<Permissions>().env.check()?;

View file

@ -28,7 +28,7 @@ pub struct PermissionArgs {
pub fn op_query_permission( pub fn op_query_permission(
state: &mut OpState, state: &mut OpState,
args: PermissionArgs, args: PermissionArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let permissions = state.borrow::<Permissions>(); let permissions = state.borrow::<Permissions>();
let path = args.path.as_deref(); let path = args.path.as_deref();
@ -59,7 +59,7 @@ pub fn op_query_permission(
pub fn op_revoke_permission( pub fn op_revoke_permission(
state: &mut OpState, state: &mut OpState,
args: PermissionArgs, args: PermissionArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let permissions = state.borrow_mut::<Permissions>(); let permissions = state.borrow_mut::<Permissions>();
let path = args.path.as_deref(); let path = args.path.as_deref();
@ -90,7 +90,7 @@ pub fn op_revoke_permission(
pub fn op_request_permission( pub fn op_request_permission(
state: &mut OpState, state: &mut OpState,
args: PermissionArgs, args: PermissionArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let permissions = state.borrow_mut::<Permissions>(); let permissions = state.borrow_mut::<Permissions>();
let path = args.path.as_deref(); let path = args.path.as_deref();

View file

@ -6,7 +6,6 @@ use deno_core::futures::prelude::*;
use deno_core::plugin_api; use deno_core::plugin_api;
use deno_core::serde_json::json; use deno_core::serde_json::json;
use deno_core::serde_json::Value; use deno_core::serde_json::Value;
use deno_core::BufVec;
use deno_core::JsRuntime; use deno_core::JsRuntime;
use deno_core::Op; use deno_core::Op;
use deno_core::OpAsyncFuture; use deno_core::OpAsyncFuture;
@ -38,7 +37,7 @@ pub struct OpenPluginArgs {
pub fn op_open_plugin( pub fn op_open_plugin(
state: &mut OpState, state: &mut OpState,
args: OpenPluginArgs, args: OpenPluginArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let filename = PathBuf::from(&args.filename); let filename = PathBuf::from(&args.filename);
@ -111,16 +110,9 @@ impl<'a> plugin_api::Interface for PluginInterface<'a> {
) -> OpId { ) -> OpId {
let plugin_lib = self.plugin_lib.clone(); let plugin_lib = self.plugin_lib.clone();
let plugin_op_fn: Box<OpFn> = Box::new(move |state_rc, _payload, buf| { let plugin_op_fn: Box<OpFn> = Box::new(move |state_rc, _payload, buf| {
// For sig compat map Option<ZeroCopyBuf> to BufVec
let mut bufs: BufVec = match buf {
Some(b) => vec![b],
None => vec![],
}
.into();
let mut state = state_rc.borrow_mut(); let mut state = state_rc.borrow_mut();
let mut interface = PluginInterface::new(&mut state, &plugin_lib); let mut interface = PluginInterface::new(&mut state, &plugin_lib);
let op = dispatch_op_fn(&mut interface, &mut bufs); let op = dispatch_op_fn(&mut interface, buf);
match op { match op {
sync_op @ Op::Sync(..) => sync_op, sync_op @ Op::Sync(..) => sync_op,
Op::Async(fut) => Op::Async(PluginOpAsyncFuture::new(&plugin_lib, fut)), Op::Async(fut) => Op::Async(PluginOpAsyncFuture::new(&plugin_lib, fut)),

View file

@ -12,7 +12,6 @@ use deno_core::serde_json::json;
use deno_core::serde_json::Value; use deno_core::serde_json::Value;
use deno_core::AsyncMutFuture; use deno_core::AsyncMutFuture;
use deno_core::AsyncRefCell; use deno_core::AsyncRefCell;
use deno_core::BufVec;
use deno_core::OpState; use deno_core::OpState;
use deno_core::RcRef; use deno_core::RcRef;
use deno_core::Resource; use deno_core::Resource;
@ -85,7 +84,7 @@ impl ChildResource {
fn op_run( fn op_run(
state: &mut OpState, state: &mut OpState,
run_args: RunArgs, run_args: RunArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
state.borrow::<Permissions>().run.check()?; state.borrow::<Permissions>().run.check()?;
@ -185,7 +184,7 @@ pub struct RunStatusArgs {
async fn op_run_status( async fn op_run_status(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: RunStatusArgs, args: RunStatusArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let rid = args.rid; let rid = args.rid;
@ -280,7 +279,7 @@ struct KillArgs {
fn op_kill( fn op_kill(
state: &mut OpState, state: &mut OpState,
args: KillArgs, args: KillArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
super::check_unstable(state, "Deno.kill"); super::check_unstable(state, "Deno.kill");
state.borrow::<Permissions>().run.check()?; state.borrow::<Permissions>().run.check()?;

View file

@ -24,7 +24,7 @@ pub fn init(rt: &mut deno_core::JsRuntime, main_module: ModuleSpecifier) {
fn op_main_module( fn op_main_module(
state: &mut OpState, state: &mut OpState,
_args: Value, _args: Value,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let main = state.borrow::<ModuleSpecifier>().to_string(); let main = state.borrow::<ModuleSpecifier>().to_string();
let main_url = deno_core::resolve_url_or_path(&main)?; let main_url = deno_core::resolve_url_or_path(&main)?;
@ -42,7 +42,7 @@ fn op_main_module(
fn op_metrics( fn op_metrics(
state: &mut OpState, state: &mut OpState,
_args: Value, _args: Value,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let m = state.borrow::<RuntimeMetrics>(); let m = state.borrow::<RuntimeMetrics>();
let combined = m.combined_metrics(); let combined = m.combined_metrics();

View file

@ -1,7 +1,6 @@
// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license. // Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.
use deno_core::error::AnyError; use deno_core::error::AnyError;
use deno_core::serde_json::Value; use deno_core::serde_json::Value;
use deno_core::BufVec;
use deno_core::OpState; use deno_core::OpState;
use deno_core::ZeroCopyBuf; use deno_core::ZeroCopyBuf;
use std::cell::RefCell; use std::cell::RefCell;
@ -70,7 +69,7 @@ pub struct SignalArgs {
fn op_signal_bind( fn op_signal_bind(
state: &mut OpState, state: &mut OpState,
args: BindSignalArgs, args: BindSignalArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
super::check_unstable(state, "Deno.signal"); super::check_unstable(state, "Deno.signal");
let resource = SignalStreamResource { let resource = SignalStreamResource {
@ -89,7 +88,7 @@ fn op_signal_bind(
async fn op_signal_poll( async fn op_signal_poll(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: SignalArgs, args: SignalArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
super::check_unstable2(&state, "Deno.signal"); super::check_unstable2(&state, "Deno.signal");
let rid = args.rid; let rid = args.rid;
@ -112,7 +111,7 @@ async fn op_signal_poll(
pub fn op_signal_unbind( pub fn op_signal_unbind(
state: &mut OpState, state: &mut OpState,
args: SignalArgs, args: SignalArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
super::check_unstable(state, "Deno.signal"); super::check_unstable(state, "Deno.signal");
let rid = args.rid; let rid = args.rid;
@ -127,7 +126,7 @@ pub fn op_signal_unbind(
pub fn op_signal_bind( pub fn op_signal_bind(
_state: &mut OpState, _state: &mut OpState,
_args: Value, _args: Value,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
unimplemented!(); unimplemented!();
} }
@ -136,7 +135,7 @@ pub fn op_signal_bind(
fn op_signal_unbind( fn op_signal_unbind(
_state: &mut OpState, _state: &mut OpState,
_args: Value, _args: Value,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
unimplemented!(); unimplemented!();
} }
@ -145,7 +144,7 @@ fn op_signal_unbind(
async fn op_signal_poll( async fn op_signal_poll(
_state: Rc<RefCell<OpState>>, _state: Rc<RefCell<OpState>>,
_args: Value, _args: Value,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
unimplemented!(); unimplemented!();
} }

View file

@ -9,7 +9,7 @@
//! calls it) for an entire Isolate. This is what is implemented here. //! calls it) for an entire Isolate. This is what is implemented here.
use crate::permissions::Permissions; use crate::permissions::Permissions;
use deno_core::error::type_error; use deno_core::error::null_opbuf;
use deno_core::error::AnyError; use deno_core::error::AnyError;
use deno_core::futures; use deno_core::futures;
use deno_core::futures::channel::oneshot; use deno_core::futures::channel::oneshot;
@ -17,7 +17,6 @@ use deno_core::futures::FutureExt;
use deno_core::futures::TryFutureExt; use deno_core::futures::TryFutureExt;
use deno_core::serde_json::json; use deno_core::serde_json::json;
use deno_core::serde_json::Value; use deno_core::serde_json::Value;
use deno_core::BufVec;
use deno_core::OpState; use deno_core::OpState;
use deno_core::ZeroCopyBuf; use deno_core::ZeroCopyBuf;
use serde::Deserialize; use serde::Deserialize;
@ -85,7 +84,7 @@ pub fn init(rt: &mut deno_core::JsRuntime) {
fn op_global_timer_stop( fn op_global_timer_stop(
state: &mut OpState, state: &mut OpState,
_args: Value, _args: Value,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let global_timer = state.borrow_mut::<GlobalTimer>(); let global_timer = state.borrow_mut::<GlobalTimer>();
global_timer.cancel(); global_timer.cancel();
@ -108,7 +107,7 @@ pub struct GlobalTimerArgs {
fn op_global_timer_start( fn op_global_timer_start(
state: &mut OpState, state: &mut OpState,
args: GlobalTimerArgs, args: GlobalTimerArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let val = args.timeout; let val = args.timeout;
@ -121,7 +120,7 @@ fn op_global_timer_start(
async fn op_global_timer( async fn op_global_timer(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
_args: Value, _args: Value,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let maybe_timer_fut = { let maybe_timer_fut = {
let mut s = state.borrow_mut(); let mut s = state.borrow_mut();
@ -141,13 +140,9 @@ async fn op_global_timer(
fn op_now( fn op_now(
op_state: &mut OpState, op_state: &mut OpState,
_argument: u32, _argument: u32,
zero_copy: &mut [ZeroCopyBuf], zero_copy: Option<ZeroCopyBuf>,
) -> Result<u32, AnyError> { ) -> Result<u32, AnyError> {
match zero_copy.len() { let mut zero_copy = zero_copy.ok_or_else(null_opbuf)?;
0 => return Err(type_error("no buffer specified")),
1 => {}
_ => return Err(type_error("Invalid number of arguments")),
}
let start_time = op_state.borrow::<StartTime>(); let start_time = op_state.borrow::<StartTime>();
let seconds = start_time.elapsed().as_secs(); let seconds = start_time.elapsed().as_secs();
@ -163,7 +158,7 @@ fn op_now(
let result = (seconds * 1_000) as f64 + (subsec_nanos / 1_000_000.0); let result = (seconds * 1_000) as f64 + (subsec_nanos / 1_000_000.0);
(&mut zero_copy[0]).copy_from_slice(&result.to_be_bytes()); (&mut zero_copy).copy_from_slice(&result.to_be_bytes());
Ok(0) Ok(0)
} }
@ -177,7 +172,7 @@ pub struct SleepArgs {
fn op_sleep_sync( fn op_sleep_sync(
state: &mut OpState, state: &mut OpState,
args: SleepArgs, args: SleepArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
super::check_unstable(state, "Deno.sleepSync"); super::check_unstable(state, "Deno.sleepSync");
sleep(Duration::from_millis(args.millis)); sleep(Duration::from_millis(args.millis));

View file

@ -14,7 +14,6 @@ use deno_core::error::AnyError;
use deno_core::serde_json::json; use deno_core::serde_json::json;
use deno_core::serde_json::Value; use deno_core::serde_json::Value;
use deno_core::AsyncRefCell; use deno_core::AsyncRefCell;
use deno_core::BufVec;
use deno_core::CancelHandle; use deno_core::CancelHandle;
use deno_core::CancelTryFuture; use deno_core::CancelTryFuture;
use deno_core::OpState; use deno_core::OpState;
@ -97,7 +96,7 @@ struct StartTlsArgs {
async fn op_start_tls( async fn op_start_tls(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: StartTlsArgs, args: StartTlsArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let rid = args.rid; let rid = args.rid;
@ -167,7 +166,7 @@ async fn op_start_tls(
async fn op_connect_tls( async fn op_connect_tls(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: ConnectTlsArgs, args: ConnectTlsArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
{ {
let s = state.borrow(); let s = state.borrow();
@ -307,7 +306,7 @@ pub struct ListenTlsArgs {
fn op_listen_tls( fn op_listen_tls(
state: &mut OpState, state: &mut OpState,
args: ListenTlsArgs, args: ListenTlsArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
assert_eq!(args.transport, "tcp"); assert_eq!(args.transport, "tcp");
@ -357,7 +356,7 @@ pub struct AcceptTlsArgs {
async fn op_accept_tls( async fn op_accept_tls(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: AcceptTlsArgs, args: AcceptTlsArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let rid = args.rid; let rid = args.rid;

View file

@ -67,7 +67,7 @@ pub struct SetRawArgs {
fn op_set_raw( fn op_set_raw(
state: &mut OpState, state: &mut OpState,
args: SetRawArgs, args: SetRawArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
super::check_unstable(state, "Deno.setRaw"); super::check_unstable(state, "Deno.setRaw");
@ -222,7 +222,7 @@ pub struct IsattyArgs {
fn op_isatty( fn op_isatty(
state: &mut OpState, state: &mut OpState,
args: IsattyArgs, args: IsattyArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let rid = args.rid; let rid = args.rid;
@ -263,7 +263,7 @@ struct ConsoleSize {
fn op_console_size( fn op_console_size(
state: &mut OpState, state: &mut OpState,
args: ConsoleSizeArgs, args: ConsoleSizeArgs,
_zero_copy: &mut [ZeroCopyBuf], _zero_copy: Option<ZeroCopyBuf>,
) -> Result<ConsoleSize, AnyError> { ) -> Result<ConsoleSize, AnyError> {
super::check_unstable(state, "Deno.consoleSize"); super::check_unstable(state, "Deno.consoleSize");

View file

@ -2,6 +2,7 @@
use crate::web_worker::WebWorkerHandle; use crate::web_worker::WebWorkerHandle;
use crate::web_worker::WorkerEvent; use crate::web_worker::WorkerEvent;
use deno_core::error::null_opbuf;
use deno_core::futures::channel::mpsc; use deno_core::futures::channel::mpsc;
use deno_core::serde_json::{json, Value}; use deno_core::serde_json::{json, Value};
@ -15,9 +16,9 @@ pub fn init(
super::reg_json_sync( super::reg_json_sync(
rt, rt,
"op_worker_post_message", "op_worker_post_message",
move |_state, _args: Value, bufs| { move |_state, _args: Value, buf| {
assert_eq!(bufs.len(), 1, "Invalid number of arguments"); let buf = buf.ok_or_else(null_opbuf)?;
let msg_buf: Box<[u8]> = (*bufs[0]).into(); let msg_buf: Box<[u8]> = (*buf).into();
sender_ sender_
.clone() .clone()
.try_send(WorkerEvent::Message(msg_buf)) .try_send(WorkerEvent::Message(msg_buf))

View file

@ -14,6 +14,7 @@ use crate::web_worker::WebWorkerHandle;
use crate::web_worker::WorkerEvent; use crate::web_worker::WorkerEvent;
use deno_core::error::custom_error; use deno_core::error::custom_error;
use deno_core::error::generic_error; use deno_core::error::generic_error;
use deno_core::error::null_opbuf;
use deno_core::error::AnyError; use deno_core::error::AnyError;
use deno_core::error::JsError; use deno_core::error::JsError;
use deno_core::futures::channel::mpsc; use deno_core::futures::channel::mpsc;
@ -23,7 +24,6 @@ use deno_core::serde::Deserialize;
use deno_core::serde::Deserializer; use deno_core::serde::Deserializer;
use deno_core::serde_json::json; use deno_core::serde_json::json;
use deno_core::serde_json::Value; use deno_core::serde_json::Value;
use deno_core::BufVec;
use deno_core::ModuleSpecifier; use deno_core::ModuleSpecifier;
use deno_core::OpState; use deno_core::OpState;
use deno_core::ZeroCopyBuf; use deno_core::ZeroCopyBuf;
@ -369,7 +369,7 @@ pub struct CreateWorkerArgs {
fn op_create_worker( fn op_create_worker(
state: &mut OpState, state: &mut OpState,
args: CreateWorkerArgs, args: CreateWorkerArgs,
_data: &mut [ZeroCopyBuf], _data: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let specifier = args.specifier.clone(); let specifier = args.specifier.clone();
let maybe_source_code = if args.has_source_code { let maybe_source_code = if args.has_source_code {
@ -457,7 +457,7 @@ pub struct WorkerArgs {
fn op_host_terminate_worker( fn op_host_terminate_worker(
state: &mut OpState, state: &mut OpState,
args: WorkerArgs, args: WorkerArgs,
_data: &mut [ZeroCopyBuf], _data: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let id = args.id as u32; let id = args.id as u32;
let worker_thread = state let worker_thread = state
@ -533,7 +533,7 @@ fn try_remove_and_close(state: Rc<RefCell<OpState>>, id: u32) {
async fn op_host_get_message( async fn op_host_get_message(
state: Rc<RefCell<OpState>>, state: Rc<RefCell<OpState>>,
args: WorkerArgs, args: WorkerArgs,
_zero_copy: BufVec, _zero_copy: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
let id = args.id as u32; let id = args.id as u32;
@ -567,11 +567,11 @@ async fn op_host_get_message(
fn op_host_post_message( fn op_host_post_message(
state: &mut OpState, state: &mut OpState,
args: WorkerArgs, args: WorkerArgs,
data: &mut [ZeroCopyBuf], data: Option<ZeroCopyBuf>,
) -> Result<Value, AnyError> { ) -> Result<Value, AnyError> {
assert_eq!(data.len(), 1, "Invalid number of arguments"); let data = data.ok_or_else(null_opbuf)?;
let id = args.id as u32; let id = args.id as u32;
let msg = Vec::from(&*data[0]).into_boxed_slice(); let msg = Vec::from(&*data).into_boxed_slice();
debug!("post message to worker {}", id); debug!("post message to worker {}", id);
let worker_thread = state let worker_thread = state

View file

@ -14,15 +14,14 @@ pub fn deno_plugin_init(interface: &mut dyn Interface) {
fn op_test_sync( fn op_test_sync(
_interface: &mut dyn Interface, _interface: &mut dyn Interface,
zero_copy: &mut [ZeroCopyBuf], zero_copy: Option<ZeroCopyBuf>,
) -> Op { ) -> Op {
if !zero_copy.is_empty() { if zero_copy.is_some() {
println!("Hello from plugin."); println!("Hello from plugin.");
} }
let zero_copy = zero_copy.to_vec(); if let Some(buf) = zero_copy {
for (idx, buf) in zero_copy.iter().enumerate() {
let buf_str = std::str::from_utf8(&buf[..]).unwrap(); let buf_str = std::str::from_utf8(&buf[..]).unwrap();
println!("zero_copy[{}]: {}", idx, buf_str); println!("zero_copy: {}", buf_str);
} }
let result = b"test"; let result = b"test";
let result_box: Box<[u8]> = Box::new(*result); let result_box: Box<[u8]> = Box::new(*result);
@ -31,16 +30,15 @@ fn op_test_sync(
fn op_test_async( fn op_test_async(
_interface: &mut dyn Interface, _interface: &mut dyn Interface,
zero_copy: &mut [ZeroCopyBuf], zero_copy: Option<ZeroCopyBuf>,
) -> Op { ) -> Op {
if !zero_copy.is_empty() { if zero_copy.is_some() {
println!("Hello from plugin."); println!("Hello from plugin.");
} }
let zero_copy = zero_copy.to_vec();
let fut = async move { let fut = async move {
for (idx, buf) in zero_copy.iter().enumerate() { if let Some(buf) = zero_copy {
let buf_str = std::str::from_utf8(&buf[..]).unwrap(); let buf_str = std::str::from_utf8(&buf[..]).unwrap();
println!("zero_copy[{}]: {}", idx, buf_str); println!("zero_copy: {}", buf_str);
} }
let (tx, rx) = futures::channel::oneshot::channel::<Result<(), ()>>(); let (tx, rx) = futures::channel::oneshot::channel::<Result<(), ()>>();
std::thread::spawn(move || { std::thread::spawn(move || {