mirror of
https://github.com/denoland/deno.git
synced 2024-12-22 23:34:47 -05:00
24c3c96958
This commit adds granular `--unstable-*` flags: - "--unstable-broadcast-channel" - "--unstable-ffi" - "--unstable-fs" - "--unstable-http" - "--unstable-kv" - "--unstable-net" - "--unstable-worker-options" - "--unstable-cron" These flags are meant to replace a "catch-all" flag - "--unstable", that gives a binary control whether unstable features are enabled or not. The downside of this flag that allowing eg. Deno KV API also enables the FFI API (though the latter is still gated with a permission). These flags can also be specified in `deno.json` file under `unstable` key. Currently, "--unstable" flag works the same way - I will open a follow up PR that will print a warning when using "--unstable" and suggest to use concrete "--unstable-*" flag instead. We plan to phase out "--unstable" completely in Deno 2.
181 lines
4.6 KiB
Rust
181 lines
4.6 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_testing_features: bool,
|
|
pub locale: String,
|
|
pub location: Option<ModuleSpecifier>,
|
|
/// Sets `Deno.noColor` in JS runtime.
|
|
pub no_color: bool,
|
|
pub is_tty: bool,
|
|
/// Sets `Deno.version.deno` in JS runtime.
|
|
pub runtime_version: String,
|
|
/// Sets `Deno.version.typescript` in JS runtime.
|
|
pub ts_version: String,
|
|
// --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>,
|
|
}
|
|
|
|
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").into();
|
|
let user_agent = format!("Deno/{runtime_version}");
|
|
|
|
Self {
|
|
runtime_version,
|
|
user_agent,
|
|
cpu_count,
|
|
no_color: !colors::use_color(),
|
|
is_tty: colors::is_tty(),
|
|
enable_testing_features: Default::default(),
|
|
log_level: Default::default(),
|
|
ts_version: 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,
|
|
}
|
|
}
|
|
}
|
|
|
|
/// 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>(
|
|
// args
|
|
&'a Vec<String>,
|
|
// cpu_count
|
|
i32,
|
|
// log_level
|
|
i32,
|
|
// runtime_version
|
|
&'a str,
|
|
// locale
|
|
&'a str,
|
|
// location
|
|
Option<&'a str>,
|
|
// no_color
|
|
bool,
|
|
// is_tty
|
|
bool,
|
|
// ts_version
|
|
&'a str,
|
|
// unstable
|
|
bool,
|
|
// granular unstable flags
|
|
&'a [i32],
|
|
// process_id
|
|
i32,
|
|
// env!("TARGET")
|
|
&'a str,
|
|
// v8_version
|
|
&'a str,
|
|
// user_agent
|
|
&'a str,
|
|
// 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.args,
|
|
self.cpu_count as _,
|
|
self.log_level as _,
|
|
&self.runtime_version,
|
|
&self.locale,
|
|
self.location.as_ref().map(|l| l.as_str()),
|
|
self.no_color,
|
|
self.is_tty,
|
|
&self.ts_version,
|
|
self.unstable,
|
|
self.unstable_features.as_ref(),
|
|
std::process::id() as _,
|
|
env!("TARGET"),
|
|
deno_core::v8_version(),
|
|
&self.user_agent,
|
|
self.inspect,
|
|
self.enable_testing_features,
|
|
self.has_node_modules_dir,
|
|
self.maybe_binary_npm_command_name.as_deref(),
|
|
);
|
|
|
|
bootstrap.serialize(ser).unwrap()
|
|
}
|
|
}
|