From 913e2875c1c31d5ffbc9c0c9ed0e8c63f6143024 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bartek=20Iwa=C5=84czuk?= Date: Thu, 30 Mar 2023 03:20:31 +0200 Subject: refactor(ext/node): add NodeEnv::Fs associated type (#18484) This commit adds associated type to "NodeEnv" trait, called "Fs". The "Fs" type has a trait bound on "NodeFs", which specifies APIs required for all ops and resolution APIs to function. A "RealFs" implementation of "NodeFs" is exported from the "deno_node" crate, that provides a default implementation for the trait. All code in "deno_node" extension was changed to use the "NodeFs" trait to handle file system operations, instead of relying on APIs from the standard library. --- ext/node/lib.rs | 31 +++++++++++++++++++++++++------ 1 file changed, 25 insertions(+), 6 deletions(-) (limited to 'ext/node/lib.rs') diff --git a/ext/node/lib.rs b/ext/node/lib.rs index 1693a82ef..f3bdb7e5b 100644 --- a/ext/node/lib.rs +++ b/ext/node/lib.rs @@ -6,6 +6,7 @@ use deno_core::op; use deno_core::JsRuntime; use once_cell::sync::Lazy; use std::collections::HashSet; +use std::io; use std::path::Path; use std::path::PathBuf; use std::rc::Rc; @@ -41,18 +42,36 @@ pub use resolution::DEFAULT_CONDITIONS; pub trait NodeEnv { type P: NodePermissions; - // TODO(bartlomieju): - // type Fs: NodeFs; + type Fs: NodeFs; } pub trait NodePermissions { fn check_read(&mut self, path: &Path) -> Result<(), AnyError>; } -// TODO(bartlomieju): -// pub trait NodeFs { -// fn current_dir() -> Result; -// } +pub trait NodeFs { + fn current_dir() -> io::Result; + fn metadata>(path: P) -> io::Result; + fn read_to_string>(path: P) -> io::Result; +} + +pub struct RealFs; +impl NodeFs for RealFs { + fn current_dir() -> io::Result { + #[allow(clippy::disallowed_methods)] + std::env::current_dir() + } + + fn metadata>(path: P) -> io::Result { + #[allow(clippy::disallowed_methods)] + std::fs::metadata(path) + } + + fn read_to_string>(path: P) -> io::Result { + #[allow(clippy::disallowed_methods)] + std::fs::read_to_string(path) + } +} pub trait RequireNpmResolver { fn resolve_package_folder_from_package( -- cgit v1.2.3