summaryrefslogtreecommitdiff
path: root/cli/ops/os.rs
diff options
context:
space:
mode:
Diffstat (limited to 'cli/ops/os.rs')
-rw-r--r--cli/ops/os.rs90
1 files changed, 49 insertions, 41 deletions
diff --git a/cli/ops/os.rs b/cli/ops/os.rs
index 1b961164e..7a2a7155e 100644
--- a/cli/ops/os.rs
+++ b/cli/ops/os.rs
@@ -1,8 +1,9 @@
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
-use super::dispatch_json::{Deserialize, JsonOp, Value};
+use super::dispatch_json::{Deserialize, Value};
use crate::state::State;
use deno_core::CoreIsolate;
use deno_core::ErrBox;
+use deno_core::ResourceTable;
use deno_core::ZeroCopyBuf;
use std::collections::HashMap;
use std::env;
@@ -10,29 +11,32 @@ use std::rc::Rc;
use url::Url;
pub fn init(i: &mut CoreIsolate, s: &Rc<State>) {
- i.register_op("op_exit", s.stateful_json_op(op_exit));
- i.register_op("op_env", s.stateful_json_op(op_env));
- i.register_op("op_exec_path", s.stateful_json_op(op_exec_path));
- i.register_op("op_set_env", s.stateful_json_op(op_set_env));
- i.register_op("op_get_env", s.stateful_json_op(op_get_env));
- i.register_op("op_delete_env", s.stateful_json_op(op_delete_env));
- i.register_op("op_hostname", s.stateful_json_op(op_hostname));
- i.register_op("op_loadavg", s.stateful_json_op(op_loadavg));
- i.register_op("op_os_release", s.stateful_json_op(op_os_release));
+ let t = &CoreIsolate::state(i).borrow().resource_table.clone();
+
+ i.register_op("op_exit", s.stateful_json_op_sync(t, op_exit));
+ i.register_op("op_env", s.stateful_json_op_sync(t, op_env));
+ i.register_op("op_exec_path", s.stateful_json_op_sync(t, op_exec_path));
+ i.register_op("op_set_env", s.stateful_json_op_sync(t, op_set_env));
+ i.register_op("op_get_env", s.stateful_json_op_sync(t, op_get_env));
+ i.register_op("op_delete_env", s.stateful_json_op_sync(t, op_delete_env));
+ i.register_op("op_hostname", s.stateful_json_op_sync(t, op_hostname));
+ i.register_op("op_loadavg", s.stateful_json_op_sync(t, op_loadavg));
+ i.register_op("op_os_release", s.stateful_json_op_sync(t, op_os_release));
}
fn op_exec_path(
- state: &Rc<State>,
+ state: &State,
+ _resource_table: &mut ResourceTable,
_args: Value,
_zero_copy: &mut [ZeroCopyBuf],
-) -> Result<JsonOp, ErrBox> {
+) -> Result<Value, ErrBox> {
let current_exe = env::current_exe().unwrap();
state.check_read_blind(&current_exe, "exec_path")?;
// Now apply URL parser to current exe to get fully resolved path, otherwise
// we might get `./` and `../` bits in `exec_path`
let exe_url = Url::from_file_path(current_exe).unwrap();
let path = exe_url.to_file_path().unwrap();
- Ok(JsonOp::Sync(json!(path)))
+ Ok(json!(path))
}
#[derive(Deserialize)]
@@ -42,24 +46,26 @@ struct SetEnv {
}
fn op_set_env(
- state: &Rc<State>,
+ state: &State,
+ _resource_table: &mut ResourceTable,
args: Value,
_zero_copy: &mut [ZeroCopyBuf],
-) -> Result<JsonOp, ErrBox> {
+) -> Result<Value, ErrBox> {
let args: SetEnv = serde_json::from_value(args)?;
state.check_env()?;
env::set_var(args.key, args.value);
- Ok(JsonOp::Sync(json!({})))
+ Ok(json!({}))
}
fn op_env(
- state: &Rc<State>,
+ state: &State,
+ _resource_table: &mut ResourceTable,
_args: Value,
_zero_copy: &mut [ZeroCopyBuf],
-) -> Result<JsonOp, ErrBox> {
+) -> Result<Value, ErrBox> {
state.check_env()?;
let v = env::vars().collect::<HashMap<String, String>>();
- Ok(JsonOp::Sync(json!(v)))
+ Ok(json!(v))
}
#[derive(Deserialize)]
@@ -68,17 +74,18 @@ struct GetEnv {
}
fn op_get_env(
- state: &Rc<State>,
+ state: &State,
+ _resource_table: &mut ResourceTable,
args: Value,
_zero_copy: &mut [ZeroCopyBuf],
-) -> Result<JsonOp, ErrBox> {
+) -> Result<Value, ErrBox> {
let args: GetEnv = serde_json::from_value(args)?;
state.check_env()?;
let r = match env::var(args.key) {
Err(env::VarError::NotPresent) => json!([]),
v => json!([v?]),
};
- Ok(JsonOp::Sync(r))
+ Ok(r)
}
#[derive(Deserialize)]
@@ -87,14 +94,15 @@ struct DeleteEnv {
}
fn op_delete_env(
- state: &Rc<State>,
+ state: &State,
+ _resource_table: &mut ResourceTable,
args: Value,
_zero_copy: &mut [ZeroCopyBuf],
-) -> Result<JsonOp, ErrBox> {
+) -> Result<Value, ErrBox> {
let args: DeleteEnv = serde_json::from_value(args)?;
state.check_env()?;
env::remove_var(args.key);
- Ok(JsonOp::Sync(json!({})))
+ Ok(json!({}))
}
#[derive(Deserialize)]
@@ -103,49 +111,49 @@ struct Exit {
}
fn op_exit(
- _s: &Rc<State>,
+ _state: &State,
+ _resource_table: &mut ResourceTable,
args: Value,
_zero_copy: &mut [ZeroCopyBuf],
-) -> Result<JsonOp, ErrBox> {
+) -> Result<Value, ErrBox> {
let args: Exit = serde_json::from_value(args)?;
std::process::exit(args.code)
}
fn op_loadavg(
- state: &Rc<State>,
+ state: &State,
+ _resource_table: &mut ResourceTable,
_args: Value,
_zero_copy: &mut [ZeroCopyBuf],
-) -> Result<JsonOp, ErrBox> {
+) -> Result<Value, ErrBox> {
state.check_unstable("Deno.loadavg");
state.check_env()?;
match sys_info::loadavg() {
- Ok(loadavg) => Ok(JsonOp::Sync(json!([
- loadavg.one,
- loadavg.five,
- loadavg.fifteen
- ]))),
- Err(_) => Ok(JsonOp::Sync(json!([0f64, 0f64, 0f64]))),
+ Ok(loadavg) => Ok(json!([loadavg.one, loadavg.five, loadavg.fifteen])),
+ Err(_) => Ok(json!([0f64, 0f64, 0f64])),
}
}
fn op_hostname(
- state: &Rc<State>,
+ state: &State,
+ _resource_table: &mut ResourceTable,
_args: Value,
_zero_copy: &mut [ZeroCopyBuf],
-) -> Result<JsonOp, ErrBox> {
+) -> Result<Value, ErrBox> {
state.check_unstable("Deno.hostname");
state.check_env()?;
let hostname = sys_info::hostname().unwrap_or_else(|_| "".to_string());
- Ok(JsonOp::Sync(json!(hostname)))
+ Ok(json!(hostname))
}
fn op_os_release(
- state: &Rc<State>,
+ state: &State,
+ _resource_table: &mut ResourceTable,
_args: Value,
_zero_copy: &mut [ZeroCopyBuf],
-) -> Result<JsonOp, ErrBox> {
+) -> Result<Value, ErrBox> {
state.check_unstable("Deno.osRelease");
state.check_env()?;
let release = sys_info::os_release().unwrap_or_else(|_| "".to_string());
- Ok(JsonOp::Sync(json!(release)))
+ Ok(json!(release))
}