Skip to main content
Module

x/deno/core/ops_builtin.rs

A modern runtime for JavaScript and TypeScript.
Go to Latest
File
use crate::error::type_error;use crate::include_js_files;use crate::op_async;use crate::op_sync;use crate::ops_metrics::OpMetrics;use crate::resources::ResourceId;use crate::void_op_async;use crate::void_op_sync;use crate::Extension;use crate::OpState;use crate::Resource;use crate::ZeroCopyBuf;use anyhow::Error;use std::cell::RefCell;use std::io::{stderr, stdout, Write};use std::rc::Rc;
pub(crate) fn init_builtins() -> Extension { Extension::builder() .js(include_js_files!( prefix "deno:core", "00_primordials.js", "01_core.js", "02_error.js", )) .ops(vec![ ("op_close", op_sync(op_close)), ("op_try_close", op_sync(op_try_close)), ("op_print", op_sync(op_print)), ("op_resources", op_sync(op_resources)), ("op_wasm_streaming_feed", op_sync(op_wasm_streaming_feed)), ("op_wasm_streaming_abort", op_sync(op_wasm_streaming_abort)), ( "op_wasm_streaming_set_url", op_sync(op_wasm_streaming_set_url), ), ("op_metrics", op_sync(op_metrics)), ("op_void_sync", void_op_sync()), ("op_void_async", void_op_async()), // TODO(@AaronO): track IO metrics for builtin streams ("op_read", op_async(op_read)), ("op_write", op_async(op_write)), ("op_shutdown", op_async(op_shutdown)), ]) .build()}
/// Return map of resources with id as key/// and string representation as value.pub fn op_resources( state: &mut OpState, _: (), _: (),) -> Result<Vec<(ResourceId, String)>, Error> { let serialized_resources = state .resource_table .names() .map(|(rid, name)| (rid, name.to_string())) .collect(); Ok(serialized_resources)}
/// Remove a resource from the resource table.pub fn op_close( state: &mut OpState, rid: Option<ResourceId>, _: (),) -> Result<(), Error> { // TODO(@AaronO): drop Option after improving type-strictness balance in // serde_v8 let rid = rid.ok_or_else(|| type_error("missing or invalid `rid`"))?; state.resource_table.close(rid)?; Ok(())}
/// Try to remove a resource from the resource table. If there is no resource/// with the specified `rid`, this is a no-op.pub fn op_try_close( state: &mut OpState, rid: Option<ResourceId>, _: (),) -> Result<(), Error> { // TODO(@AaronO): drop Option after improving type-strictness balance in // serde_v8. let rid = rid.ok_or_else(|| type_error("missing or invalid `rid`"))?; let _ = state.resource_table.close(rid); Ok(())}
/// Builtin utility to print to stdout/stderrpub fn op_print( _state: &mut OpState, msg: String, is_err: bool,) -> Result<(), Error> { if is_err { stderr().write_all(msg.as_bytes())?; stderr().flush().unwrap(); } else { stdout().write_all(msg.as_bytes())?; stdout().flush().unwrap(); } Ok(())}
pub struct WasmStreamingResource(pub(crate) RefCell<v8::WasmStreaming>);
impl Resource for WasmStreamingResource { fn close(self: Rc<Self>) { // At this point there are no clones of Rc<WasmStreamingResource> on the // resource table, and no one should own a reference outside of the stack. // Therefore, we can be sure `self` is the only reference. if let Ok(wsr) = Rc::try_unwrap(self) { wsr.0.into_inner().finish(); } else { panic!("Couldn't consume WasmStreamingResource."); } }}
/// Feed bytes to WasmStreamingResource.pub fn op_wasm_streaming_feed( state: &mut OpState, rid: ResourceId, bytes: ZeroCopyBuf,) -> Result<(), Error> { let wasm_streaming = state.resource_table.get::<WasmStreamingResource>(rid)?;
wasm_streaming.0.borrow_mut().on_bytes_received(&bytes);
Ok(())}
/// Abort a WasmStreamingResource.pub fn op_wasm_streaming_abort( state: &mut OpState, rid: ResourceId, exception: serde_v8::Value,) -> Result<(), Error> { let wasm_streaming = state.resource_table.take::<WasmStreamingResource>(rid)?;
// At this point there are no clones of Rc<WasmStreamingResource> on the // resource table, and no one should own a reference because we're never // cloning them. So we can be sure `wasm_streaming` is the only reference. if let Ok(wsr) = Rc::try_unwrap(wasm_streaming) { wsr.0.into_inner().abort(Some(exception.v8_value)); } else { panic!("Couldn't consume WasmStreamingResource."); }
Ok(())}
pub fn op_wasm_streaming_set_url( state: &mut OpState, rid: ResourceId, url: String,) -> Result<(), Error> { let wasm_streaming = state.resource_table.get::<WasmStreamingResource>(rid)?;
wasm_streaming.0.borrow_mut().set_url(&url);
Ok(())}
pub fn op_metrics( state: &mut OpState, _: (), _: (),) -> Result<(OpMetrics, Vec<OpMetrics>), Error> { let aggregate = state.tracker.aggregate(); let per_op = state.tracker.per_op(); Ok((aggregate, per_op))}
async fn op_read( state: Rc<RefCell<OpState>>, rid: ResourceId, buf: ZeroCopyBuf,) -> Result<u32, Error> { let resource = state.borrow().resource_table.get_any(rid)?; resource.read(buf).await.map(|n| n as u32)}
async fn op_write( state: Rc<RefCell<OpState>>, rid: ResourceId, buf: ZeroCopyBuf,) -> Result<u32, Error> { let resource = state.borrow().resource_table.get_any(rid)?; resource.write(buf).await.map(|n| n as u32)}
async fn op_shutdown( state: Rc<RefCell<OpState>>, rid: ResourceId, _: (),) -> Result<(), Error> { let resource = state.borrow().resource_table.get_any(rid)?; resource.shutdown().await}