2021-01-10 21:59:07 -05:00
|
|
|
// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.
|
2020-12-13 13:45:53 -05:00
|
|
|
|
|
|
|
pub mod crypto;
|
|
|
|
pub mod fetch;
|
2021-04-07 09:22:14 -04:00
|
|
|
pub mod file;
|
2020-12-13 13:45:53 -05:00
|
|
|
pub mod fs;
|
|
|
|
pub mod fs_events;
|
2021-04-08 18:34:15 -04:00
|
|
|
pub mod http;
|
2020-12-13 13:45:53 -05:00
|
|
|
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 runtime;
|
|
|
|
pub mod signal;
|
|
|
|
pub mod timers;
|
|
|
|
pub mod tls;
|
|
|
|
pub mod tty;
|
chore: split web op crate (#9635)
This commit starts splitting out the deno_web op crate into multiple
smaller crates. This commit splits out WebIDL and URL API, but in the
future I want to split out each spec into its own crate. That means we
will have (in rough order of loading): `webidl`, `dom`, `streams`,
`console`, `encoding`, `url`, `file`, `fetch`, `websocket`, and
`webgpu` crates.
2021-03-12 10:17:18 -05:00
|
|
|
pub mod url;
|
2021-04-06 04:33:43 -04:00
|
|
|
mod utils;
|
2020-12-13 13:45:53 -05:00
|
|
|
pub mod web_worker;
|
2021-03-01 05:31:13 -05:00
|
|
|
pub mod webgpu;
|
2020-12-13 13:45:53 -05:00
|
|
|
pub mod websocket;
|
|
|
|
pub mod worker_host;
|
|
|
|
|
|
|
|
use crate::metrics::metrics_op;
|
2021-03-20 12:51:08 -04:00
|
|
|
use deno_core::bin_op_async;
|
|
|
|
use deno_core::bin_op_sync;
|
2020-12-13 13:45:53 -05:00
|
|
|
use deno_core::error::AnyError;
|
|
|
|
use deno_core::json_op_async;
|
|
|
|
use deno_core::json_op_sync;
|
2021-02-18 07:54:57 -05:00
|
|
|
use deno_core::serde::de::DeserializeOwned;
|
|
|
|
use deno_core::serde::Serialize;
|
2020-12-13 13:45:53 -05:00
|
|
|
use deno_core::JsRuntime;
|
|
|
|
use deno_core::OpState;
|
2021-03-20 12:51:08 -04:00
|
|
|
use deno_core::ValueOrVector;
|
2020-12-13 13:45:53 -05:00
|
|
|
use deno_core::ZeroCopyBuf;
|
|
|
|
use std::cell::RefCell;
|
|
|
|
use std::future::Future;
|
|
|
|
use std::rc::Rc;
|
|
|
|
|
2021-02-18 07:54:57 -05:00
|
|
|
pub fn reg_json_async<F, V, R, RV>(
|
|
|
|
rt: &mut JsRuntime,
|
|
|
|
name: &'static str,
|
|
|
|
op_fn: F,
|
|
|
|
) where
|
2021-04-02 09:47:57 -04:00
|
|
|
F: Fn(Rc<RefCell<OpState>>, V, Option<ZeroCopyBuf>) -> R + 'static,
|
2021-02-18 07:54:57 -05:00
|
|
|
V: DeserializeOwned,
|
|
|
|
R: Future<Output = Result<RV, AnyError>> + 'static,
|
2021-03-31 10:37:38 -04:00
|
|
|
RV: Serialize + 'static,
|
2020-12-13 13:45:53 -05:00
|
|
|
{
|
2021-02-21 13:20:31 -05:00
|
|
|
rt.register_op(name, metrics_op(name, json_op_async(op_fn)));
|
2020-12-13 13:45:53 -05:00
|
|
|
}
|
|
|
|
|
2021-02-18 07:54:57 -05:00
|
|
|
pub fn reg_json_sync<F, V, R>(rt: &mut JsRuntime, name: &'static str, op_fn: F)
|
2020-12-13 13:45:53 -05:00
|
|
|
where
|
2021-04-02 09:47:57 -04:00
|
|
|
F: Fn(&mut OpState, V, Option<ZeroCopyBuf>) -> Result<R, AnyError> + 'static,
|
2021-02-18 07:54:57 -05:00
|
|
|
V: DeserializeOwned,
|
2021-03-31 10:37:38 -04:00
|
|
|
R: Serialize + 'static,
|
2020-12-13 13:45:53 -05:00
|
|
|
{
|
2021-02-21 13:20:31 -05:00
|
|
|
rt.register_op(name, metrics_op(name, json_op_sync(op_fn)));
|
2020-12-13 13:45:53 -05:00
|
|
|
}
|
|
|
|
|
2021-03-20 12:51:08 -04:00
|
|
|
pub fn reg_bin_async<F, R, RV>(rt: &mut JsRuntime, name: &'static str, op_fn: F)
|
|
|
|
where
|
2021-04-02 09:47:57 -04:00
|
|
|
F: Fn(Rc<RefCell<OpState>>, u32, Option<ZeroCopyBuf>) -> R + 'static,
|
2021-03-18 09:10:27 -04:00
|
|
|
R: Future<Output = Result<RV, AnyError>> + 'static,
|
|
|
|
RV: ValueOrVector,
|
|
|
|
{
|
2021-03-20 12:51:08 -04:00
|
|
|
rt.register_op(name, metrics_op(name, bin_op_async(op_fn)));
|
2021-03-18 09:10:27 -04:00
|
|
|
}
|
|
|
|
|
2021-03-20 12:51:08 -04:00
|
|
|
pub fn reg_bin_sync<F, R>(rt: &mut JsRuntime, name: &'static str, op_fn: F)
|
2021-03-18 09:10:27 -04:00
|
|
|
where
|
2021-04-02 09:47:57 -04:00
|
|
|
F:
|
|
|
|
Fn(&mut OpState, u32, Option<ZeroCopyBuf>) -> Result<R, AnyError> + 'static,
|
2021-03-18 09:10:27 -04:00
|
|
|
R: ValueOrVector,
|
|
|
|
{
|
2021-03-20 12:51:08 -04:00
|
|
|
rt.register_op(name, metrics_op(name, bin_op_sync(op_fn)));
|
2021-03-18 09:10:27 -04:00
|
|
|
}
|
|
|
|
|
2020-12-13 13:45:53 -05:00
|
|
|
/// `UnstableChecker` is a struct so it can be placed inside `GothamState`;
|
|
|
|
/// using type alias for a bool could work, but there's a high chance
|
|
|
|
/// that there might be another type alias pointing to a bool, which
|
|
|
|
/// would override previously used alias.
|
|
|
|
pub struct UnstableChecker {
|
|
|
|
pub unstable: bool,
|
|
|
|
}
|
|
|
|
|
|
|
|
impl UnstableChecker {
|
|
|
|
/// Quits the process if the --unstable flag was not provided.
|
|
|
|
///
|
|
|
|
/// This is intentionally a non-recoverable check so that people cannot probe
|
|
|
|
/// for unstable APIs from stable programs.
|
|
|
|
// NOTE(bartlomieju): keep in sync with `cli/program_state.rs`
|
|
|
|
pub fn check_unstable(&self, api_name: &str) {
|
|
|
|
if !self.unstable {
|
|
|
|
eprintln!(
|
|
|
|
"Unstable API '{}'. The --unstable flag must be provided.",
|
|
|
|
api_name
|
|
|
|
);
|
|
|
|
std::process::exit(70);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/// Helper for checking unstable features. Used for sync ops.
|
|
|
|
pub fn check_unstable(state: &OpState, api_name: &str) {
|
|
|
|
state.borrow::<UnstableChecker>().check_unstable(api_name)
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Helper for checking unstable features. Used for async ops.
|
|
|
|
pub fn check_unstable2(state: &Rc<RefCell<OpState>>, api_name: &str) {
|
|
|
|
let state = state.borrow();
|
|
|
|
state.borrow::<UnstableChecker>().check_unstable(api_name)
|
|
|
|
}
|