From d4d3a3c54f5e26dec0cc79e273dc488f8a47f2b3 Mon Sep 17 00:00:00 2001 From: Nathan Whitaker <17734409+nathanwhit@users.noreply.github.com> Date: Fri, 5 Jul 2024 11:32:51 -0700 Subject: fix(node): Implement `fs.lchown` (and `process.getegid`) (#24418) Closes https://github.com/denoland/deno/issues/21260. Part of https://github.com/denoland/deno/issues/18218. Implements `node:fs.lchown`, and enables the node_compat test for it. The test uses `process.getegid`, which we didn't have implemented, so I went ahead and implemented that as well to get the test working. --- cli/standalone/file_system.rs | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) (limited to 'cli/standalone/file_system.rs') diff --git a/cli/standalone/file_system.rs b/cli/standalone/file_system.rs index 13da0a729..536b17f27 100644 --- a/cli/standalone/file_system.rs +++ b/cli/standalone/file_system.rs @@ -145,6 +145,26 @@ impl FileSystem for DenoCompileFileSystem { RealFs.chown_async(path, uid, gid).await } + fn lchown_sync( + &self, + path: &Path, + uid: Option, + gid: Option, + ) -> FsResult<()> { + self.error_if_in_vfs(path)?; + RealFs.lchown_sync(path, uid, gid) + } + + async fn lchown_async( + &self, + path: PathBuf, + uid: Option, + gid: Option, + ) -> FsResult<()> { + self.error_if_in_vfs(&path)?; + RealFs.lchown_async(path, uid, gid).await + } + fn remove_sync(&self, path: &Path, recursive: bool) -> FsResult<()> { self.error_if_in_vfs(path)?; RealFs.remove_sync(path, recursive) -- cgit v1.2.3