1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-26 00:47:50 -05:00
denoland-deno/cli/js/read_dir.ts

38 lines
1.1 KiB
TypeScript
Raw Normal View History

2020-01-02 15:13:47 -05:00
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
import { sendSync, sendAsync } from "./ops/dispatch_json.ts";
import { FileInfo, FileInfoImpl } from "./file_info.ts";
import { StatResponse } from "./stat.ts";
2018-10-04 06:56:56 +09:00
2019-08-26 16:18:42 +02:00
interface ReadDirResponse {
entries: StatResponse[];
2018-10-04 06:56:56 +09:00
}
2019-08-26 16:18:42 +02:00
function res(response: ReadDirResponse): FileInfo[] {
return response.entries.map(
(statRes: StatResponse): FileInfo => {
return new FileInfoImpl(statRes);
}
);
2018-10-04 06:56:56 +09:00
}
/** Synchronously reads the directory given by `path` and returns an array of
* `Deno.FileInfo`.
*
2020-03-06 08:34:02 -05:00
* const files = Deno.readdirSync("/");
*
* Requires `allow-read` permission. */
2020-03-06 08:34:02 -05:00
export function readdirSync(path: string): FileInfo[] {
2020-02-25 09:14:27 -05:00
return res(sendSync("op_read_dir", { path }));
}
/** UNSTABLE: Maybe need to return an `AsyncIterable`.
*
* Reads the directory given by `path` and resolves to an array of `Deno.FileInfo`.
*
2020-03-06 08:34:02 -05:00
* const files = await Deno.readdir("/");
*
* Requires `allow-read` permission. */
2020-03-06 08:34:02 -05:00
export async function readdir(path: string): Promise<FileInfo[]> {
2020-02-25 09:14:27 -05:00
return res(await sendAsync("op_read_dir", { path }));
}