mirror of
https://github.com/denoland/deno.git
synced 2025-08-04 19:08:15 +00:00
refactor(cli/js/ops/fs): Improve readdir() and FileInfo interfaces (#4763)
This commit is contained in:
parent
6441852a1d
commit
5ac728a5f1
33 changed files with 312 additions and 360 deletions
|
@ -1,24 +1,32 @@
|
|||
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
|
||||
import { sendSync, sendAsync } from "../dispatch_json.ts";
|
||||
import { FileInfo, FileInfoImpl } from "../../file_info.ts";
|
||||
import { StatResponse } from "./stat.ts";
|
||||
import { FileInfo, StatResponse, parseFileInfo } from "./stat.ts";
|
||||
|
||||
export interface DirEntry extends FileInfo {
|
||||
name: string;
|
||||
}
|
||||
|
||||
interface ReadDirResponse {
|
||||
entries: StatResponse[];
|
||||
}
|
||||
|
||||
function res(response: ReadDirResponse): FileInfo[] {
|
||||
function res(response: ReadDirResponse): DirEntry[] {
|
||||
return response.entries.map(
|
||||
(statRes: StatResponse): FileInfo => {
|
||||
return new FileInfoImpl(statRes);
|
||||
(statRes: StatResponse): DirEntry => {
|
||||
return { ...parseFileInfo(statRes), name: statRes.name! };
|
||||
}
|
||||
);
|
||||
}
|
||||
|
||||
export function readdirSync(path: string): FileInfo[] {
|
||||
return res(sendSync("op_read_dir", { path }));
|
||||
export function readdirSync(path: string): Iterable<DirEntry> {
|
||||
return res(sendSync("op_read_dir", { path }))[Symbol.iterator]();
|
||||
}
|
||||
|
||||
export async function readdir(path: string): Promise<FileInfo[]> {
|
||||
return res(await sendAsync("op_read_dir", { path }));
|
||||
export function readdir(path: string): AsyncIterable<DirEntry> {
|
||||
const array = sendAsync("op_read_dir", { path }).then(res);
|
||||
return {
|
||||
async *[Symbol.asyncIterator](): AsyncIterableIterator<DirEntry> {
|
||||
yield* await array;
|
||||
},
|
||||
};
|
||||
}
|
||||
|
|
|
@ -1,6 +1,25 @@
|
|||
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
|
||||
import { sendSync, sendAsync } from "../dispatch_json.ts";
|
||||
import { FileInfo, FileInfoImpl } from "../../file_info.ts";
|
||||
import { build } from "../../build.ts";
|
||||
|
||||
export interface FileInfo {
|
||||
size: number;
|
||||
modified: number | null;
|
||||
accessed: number | null;
|
||||
created: number | null;
|
||||
dev: number | null;
|
||||
ino: number | null;
|
||||
mode: number | null;
|
||||
nlink: number | null;
|
||||
uid: number | null;
|
||||
gid: number | null;
|
||||
rdev: number | null;
|
||||
blksize: number | null;
|
||||
blocks: number | null;
|
||||
isFile: boolean;
|
||||
isDirectory: boolean;
|
||||
isSymlink: boolean;
|
||||
}
|
||||
|
||||
export interface StatResponse {
|
||||
isFile: boolean;
|
||||
|
@ -10,6 +29,7 @@ export interface StatResponse {
|
|||
modified: number;
|
||||
accessed: number;
|
||||
created: number;
|
||||
// Null for stat(), but exists for readdir().
|
||||
name: string | null;
|
||||
// Unix only members
|
||||
dev: number;
|
||||
|
@ -23,12 +43,36 @@ export interface StatResponse {
|
|||
blocks: number;
|
||||
}
|
||||
|
||||
// @internal
|
||||
export function parseFileInfo(response: StatResponse): FileInfo {
|
||||
const isUnix = build.os === "mac" || build.os === "linux";
|
||||
return {
|
||||
isFile: response.isFile,
|
||||
isDirectory: response.isDirectory,
|
||||
isSymlink: response.isSymlink,
|
||||
size: response.size,
|
||||
modified: response.modified ? response.modified : null,
|
||||
accessed: response.accessed ? response.accessed : null,
|
||||
created: response.created ? response.created : null,
|
||||
// Only non-null if on Unix
|
||||
dev: isUnix ? response.dev : null,
|
||||
ino: isUnix ? response.ino : null,
|
||||
mode: isUnix ? response.mode : null,
|
||||
nlink: isUnix ? response.nlink : null,
|
||||
uid: isUnix ? response.uid : null,
|
||||
gid: isUnix ? response.gid : null,
|
||||
rdev: isUnix ? response.rdev : null,
|
||||
blksize: isUnix ? response.blksize : null,
|
||||
blocks: isUnix ? response.blocks : null,
|
||||
};
|
||||
}
|
||||
|
||||
export async function lstat(path: string): Promise<FileInfo> {
|
||||
const res = (await sendAsync("op_stat", {
|
||||
path,
|
||||
lstat: true,
|
||||
})) as StatResponse;
|
||||
return new FileInfoImpl(res);
|
||||
return parseFileInfo(res);
|
||||
}
|
||||
|
||||
export function lstatSync(path: string): FileInfo {
|
||||
|
@ -36,7 +80,7 @@ export function lstatSync(path: string): FileInfo {
|
|||
path,
|
||||
lstat: true,
|
||||
}) as StatResponse;
|
||||
return new FileInfoImpl(res);
|
||||
return parseFileInfo(res);
|
||||
}
|
||||
|
||||
export async function stat(path: string): Promise<FileInfo> {
|
||||
|
@ -44,7 +88,7 @@ export async function stat(path: string): Promise<FileInfo> {
|
|||
path,
|
||||
lstat: false,
|
||||
})) as StatResponse;
|
||||
return new FileInfoImpl(res);
|
||||
return parseFileInfo(res);
|
||||
}
|
||||
|
||||
export function statSync(path: string): FileInfo {
|
||||
|
@ -52,5 +96,5 @@ export function statSync(path: string): FileInfo {
|
|||
path,
|
||||
lstat: false,
|
||||
}) as StatResponse;
|
||||
return new FileInfoImpl(res);
|
||||
return parseFileInfo(res);
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue