mirror of
https://github.com/denoland/deno.git
synced 2024-11-29 16:30:56 -05:00
55fac9f5ea
This PR implements the child_process IPC pipe between parent and child. The implementation uses Windows named pipes created by parent and passes the inheritable file handle to the child. I've also replace parts of the initial implementation which passed the raw parent fd to JS with resource ids instead. This way no file handle is exposed to the JS land (both parent and child). `IpcJsonStreamResource` can stream upto 800MB/s of JSON data on Win 11 AMD Ryzen 7 16GB (without `memchr` vectorization)
143 lines
4 KiB
Rust
143 lines
4 KiB
Rust
// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
|
|
|
|
use deno_core::v8;
|
|
use deno_core::ModuleSpecifier;
|
|
use serde::Serialize;
|
|
use std::cell::RefCell;
|
|
use std::thread;
|
|
|
|
use crate::colors;
|
|
|
|
/// The log level to use when printing diagnostic log messages, warnings,
|
|
/// or errors in the worker.
|
|
///
|
|
/// Note: This is disconnected with the log crate's log level and the Rust code
|
|
/// in this crate will respect that value instead. To specify that, use
|
|
/// `log::set_max_level`.
|
|
#[derive(Debug, Default, Clone, Copy)]
|
|
pub enum WorkerLogLevel {
|
|
// WARNING: Ensure this is kept in sync with
|
|
// the JS values (search for LogLevel).
|
|
Error = 1,
|
|
Warn = 2,
|
|
#[default]
|
|
Info = 3,
|
|
Debug = 4,
|
|
}
|
|
|
|
impl From<log::Level> for WorkerLogLevel {
|
|
fn from(value: log::Level) -> Self {
|
|
match value {
|
|
log::Level::Error => WorkerLogLevel::Error,
|
|
log::Level::Warn => WorkerLogLevel::Warn,
|
|
log::Level::Info => WorkerLogLevel::Info,
|
|
log::Level::Debug => WorkerLogLevel::Debug,
|
|
log::Level::Trace => WorkerLogLevel::Debug,
|
|
}
|
|
}
|
|
}
|
|
|
|
/// Common bootstrap options for MainWorker & WebWorker
|
|
#[derive(Clone)]
|
|
pub struct BootstrapOptions {
|
|
/// Sets `Deno.args` in JS runtime.
|
|
pub args: Vec<String>,
|
|
pub cpu_count: usize,
|
|
pub log_level: WorkerLogLevel,
|
|
pub enable_op_summary_metrics: bool,
|
|
pub enable_testing_features: bool,
|
|
pub locale: String,
|
|
pub location: Option<ModuleSpecifier>,
|
|
/// Sets `Deno.noColor` in JS runtime.
|
|
pub no_color: bool,
|
|
pub is_tty: bool,
|
|
// --unstable flag, deprecated
|
|
pub unstable: bool,
|
|
// --unstable-* flags
|
|
pub unstable_features: Vec<i32>,
|
|
pub user_agent: String,
|
|
pub inspect: bool,
|
|
pub has_node_modules_dir: bool,
|
|
pub maybe_binary_npm_command_name: Option<String>,
|
|
pub node_ipc_fd: Option<i64>,
|
|
}
|
|
|
|
impl Default for BootstrapOptions {
|
|
fn default() -> Self {
|
|
let cpu_count = thread::available_parallelism()
|
|
.map(|p| p.get())
|
|
.unwrap_or(1);
|
|
|
|
let runtime_version = env!("CARGO_PKG_VERSION");
|
|
let user_agent = format!("Deno/{runtime_version}");
|
|
|
|
Self {
|
|
user_agent,
|
|
cpu_count,
|
|
no_color: !colors::use_color(),
|
|
is_tty: colors::is_tty(),
|
|
enable_op_summary_metrics: Default::default(),
|
|
enable_testing_features: Default::default(),
|
|
log_level: Default::default(),
|
|
locale: "en".to_string(),
|
|
location: Default::default(),
|
|
unstable: Default::default(),
|
|
unstable_features: Default::default(),
|
|
inspect: Default::default(),
|
|
args: Default::default(),
|
|
has_node_modules_dir: Default::default(),
|
|
maybe_binary_npm_command_name: None,
|
|
node_ipc_fd: None,
|
|
}
|
|
}
|
|
}
|
|
|
|
/// This is a struct that we use to serialize the contents of the `BootstrapOptions`
|
|
/// struct above to a V8 form. While `serde_v8` is not as fast as hand-coding this,
|
|
/// it's "fast enough" while serializing a large tuple like this that it doesn't appear
|
|
/// on flamegraphs.
|
|
///
|
|
/// Note that a few fields in here are derived from the process and environment and
|
|
/// are not sourced from the underlying `BootstrapOptions`.
|
|
///
|
|
/// Keep this in sync with `99_main.js`.
|
|
#[derive(Serialize)]
|
|
struct BootstrapV8<'a>(
|
|
// location
|
|
Option<&'a str>,
|
|
// unstable
|
|
bool,
|
|
// granular unstable flags
|
|
&'a [i32],
|
|
// inspect
|
|
bool,
|
|
// enable_testing_features
|
|
bool,
|
|
// has_node_modules_dir
|
|
bool,
|
|
// maybe_binary_npm_command_name
|
|
Option<&'a str>,
|
|
);
|
|
|
|
impl BootstrapOptions {
|
|
/// Return the v8 equivalent of this structure.
|
|
pub fn as_v8<'s>(
|
|
&self,
|
|
scope: &mut v8::HandleScope<'s>,
|
|
) -> v8::Local<'s, v8::Value> {
|
|
let scope = RefCell::new(scope);
|
|
let ser = deno_core::serde_v8::Serializer::new(&scope);
|
|
|
|
let bootstrap = BootstrapV8(
|
|
self.location.as_ref().map(|l| l.as_str()),
|
|
self.unstable,
|
|
self.unstable_features.as_ref(),
|
|
self.inspect,
|
|
self.enable_testing_features,
|
|
self.has_node_modules_dir,
|
|
self.maybe_binary_npm_command_name.as_deref(),
|
|
);
|
|
|
|
bootstrap.serialize(ser).unwrap()
|
|
}
|
|
}
|