mirror of
https://github.com/denoland/deno.git
synced 2024-11-26 16:09:27 -05:00
7c2e7c6608
Provides a concrete state type that can be dynamically added. This is necessary for op crates. * renames BasicState to OpState * async ops take `Rc<RefCell<OpState>>` * sync ops take `&mut OpState` * removes `OpRegistry`, `OpRouter` traits * `get_error_class_fn` moved to OpState * ResourceTable moved to OpState
71 lines
1.7 KiB
Rust
71 lines
1.7 KiB
Rust
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
|
|
|
|
mod dispatch_minimal;
|
|
pub use dispatch_minimal::MinimalOp;
|
|
|
|
pub mod compiler;
|
|
pub mod errors;
|
|
pub mod fetch;
|
|
pub mod fs;
|
|
pub mod fs_events;
|
|
pub mod idna;
|
|
pub mod io;
|
|
pub mod net;
|
|
#[cfg(unix)]
|
|
mod net_unix;
|
|
pub mod os;
|
|
pub mod permissions;
|
|
pub mod plugin;
|
|
pub mod process;
|
|
pub mod random;
|
|
pub mod repl;
|
|
pub mod resources;
|
|
pub mod runtime;
|
|
pub mod runtime_compiler;
|
|
pub mod signal;
|
|
pub mod timers;
|
|
pub mod tls;
|
|
pub mod tty;
|
|
pub mod web_worker;
|
|
pub mod websocket;
|
|
pub mod worker_host;
|
|
|
|
use crate::metrics::metrics_op;
|
|
use deno_core::json_op_async;
|
|
use deno_core::json_op_sync;
|
|
use deno_core::BufVec;
|
|
use deno_core::ErrBox;
|
|
use deno_core::JsRuntime;
|
|
use deno_core::OpState;
|
|
use deno_core::ZeroCopyBuf;
|
|
use serde_json::Value;
|
|
use std::cell::RefCell;
|
|
use std::future::Future;
|
|
use std::rc::Rc;
|
|
|
|
pub fn reg_json_async<F, R>(rt: &mut JsRuntime, name: &'static str, op_fn: F)
|
|
where
|
|
F: Fn(Rc<RefCell<OpState>>, Value, BufVec) -> R + 'static,
|
|
R: Future<Output = Result<Value, ErrBox>> + 'static,
|
|
{
|
|
rt.register_op(name, metrics_op(json_op_async(op_fn)));
|
|
}
|
|
|
|
pub fn reg_json_sync<F>(rt: &mut JsRuntime, name: &'static str, op_fn: F)
|
|
where
|
|
F: Fn(&mut OpState, Value, &mut [ZeroCopyBuf]) -> Result<Value, ErrBox>
|
|
+ 'static,
|
|
{
|
|
rt.register_op(name, metrics_op(json_op_sync(op_fn)));
|
|
}
|
|
|
|
/// Helper for extracting the commonly used state. Used for sync ops.
|
|
pub fn cli_state(state: &OpState) -> Rc<crate::state::State> {
|
|
state.borrow::<Rc<crate::state::State>>().clone()
|
|
}
|
|
|
|
/// Helper for extracting the commonly used state. Used for async ops.
|
|
pub fn cli_state2(state: &Rc<RefCell<OpState>>) -> Rc<crate::state::State> {
|
|
let state = state.borrow();
|
|
state.borrow::<Rc<crate::state::State>>().clone()
|
|
}
|