mirror of
https://github.com/denoland/deno.git
synced 2025-03-04 01:44:26 -05:00

* establish basic event loop for workers * make "self.close()" inside worker * remove "runWorkerMessageLoop() - instead manually call global function in Rust when message arrives. This is done in preparation for structured clone * refactor "WorkerChannel" and use distinct structs for internal and external channels; "WorkerChannelsInternal" and "WorkerHandle" * move "State.worker_channels_internal" to "Worker.internal_channels" * add "WorkerEvent" enum for child->host communication; currently "Message(Buf)" and "Error(ErrBox)" variants are supported * add tests for nested workers * add tests for worker throwing error on startup
68 lines
2.1 KiB
Rust
68 lines
2.1 KiB
Rust
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
|
|
use super::dispatch_json::{JsonOp, Value};
|
|
use crate::colors;
|
|
use crate::fs as deno_fs;
|
|
use crate::ops::json_op;
|
|
use crate::state::State;
|
|
use crate::version;
|
|
use crate::DenoSubcommand;
|
|
use deno_core::*;
|
|
use std::env;
|
|
use std::sync::atomic::Ordering;
|
|
|
|
/// BUILD_OS and BUILD_ARCH match the values in Deno.build. See js/build.ts.
|
|
#[cfg(target_os = "macos")]
|
|
static BUILD_OS: &str = "mac";
|
|
#[cfg(target_os = "linux")]
|
|
static BUILD_OS: &str = "linux";
|
|
#[cfg(target_os = "windows")]
|
|
static BUILD_OS: &str = "win";
|
|
#[cfg(target_arch = "x86_64")]
|
|
static BUILD_ARCH: &str = "x64";
|
|
|
|
pub fn init(i: &mut Isolate, s: &State) {
|
|
i.register_op("start", s.core_op(json_op(s.stateful_op(op_start))));
|
|
i.register_op("metrics", s.core_op(json_op(s.stateful_op(op_metrics))));
|
|
}
|
|
|
|
fn op_start(
|
|
state: &State,
|
|
_args: Value,
|
|
_zero_copy: Option<ZeroCopyBuf>,
|
|
) -> Result<JsonOp, ErrBox> {
|
|
let state = state.borrow();
|
|
let gs = &state.global_state;
|
|
|
|
Ok(JsonOp::Sync(json!({
|
|
"cwd": deno_fs::normalize_path(&env::current_dir().unwrap()),
|
|
"pid": std::process::id(),
|
|
"args": gs.flags.argv.clone(),
|
|
"repl": gs.flags.subcommand == DenoSubcommand::Repl,
|
|
"location": state.main_module.to_string(),
|
|
"debugFlag": gs.flags.log_level.map_or(false, |l| l == log::Level::Debug),
|
|
"versionFlag": gs.flags.version,
|
|
"v8Version": version::v8(),
|
|
"denoVersion": version::DENO,
|
|
"tsVersion": version::TYPESCRIPT,
|
|
"noColor": !colors::use_color(),
|
|
"os": BUILD_OS,
|
|
"arch": BUILD_ARCH,
|
|
})))
|
|
}
|
|
|
|
fn op_metrics(
|
|
state: &State,
|
|
_args: Value,
|
|
_zero_copy: Option<ZeroCopyBuf>,
|
|
) -> Result<JsonOp, ErrBox> {
|
|
let state = state.borrow();
|
|
let m = &state.metrics;
|
|
|
|
Ok(JsonOp::Sync(json!({
|
|
"opsDispatched": m.ops_dispatched.load(Ordering::SeqCst) as u64,
|
|
"opsCompleted": m.ops_completed.load(Ordering::SeqCst) as u64,
|
|
"bytesSentControl": m.bytes_sent_control.load(Ordering::SeqCst) as u64,
|
|
"bytesSentData": m.bytes_sent_data.load(Ordering::SeqCst) as u64,
|
|
"bytesReceived": m.bytes_received.load(Ordering::SeqCst) as u64
|
|
})))
|
|
}
|