summaryrefslogtreecommitdiff
path: root/cli/js/ops/fs/read_dir.ts
diff options
context:
space:
mode:
Diffstat (limited to 'cli/js/ops/fs/read_dir.ts')
-rw-r--r--cli/js/ops/fs/read_dir.ts37
1 files changed, 37 insertions, 0 deletions
diff --git a/cli/js/ops/fs/read_dir.ts b/cli/js/ops/fs/read_dir.ts
new file mode 100644
index 000000000..75c821c33
--- /dev/null
+++ b/cli/js/ops/fs/read_dir.ts
@@ -0,0 +1,37 @@
+// 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";
+
+interface ReadDirResponse {
+ entries: StatResponse[];
+}
+
+function res(response: ReadDirResponse): FileInfo[] {
+ return response.entries.map(
+ (statRes: StatResponse): FileInfo => {
+ return new FileInfoImpl(statRes);
+ }
+ );
+}
+
+/** Synchronously reads the directory given by `path` and returns an array of
+ * `Deno.FileInfo`.
+ *
+ * const files = Deno.readdirSync("/");
+ *
+ * Requires `allow-read` permission. */
+export function readdirSync(path: string): FileInfo[] {
+ 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`.
+ *
+ * const files = await Deno.readdir("/");
+ *
+ * Requires `allow-read` permission. */
+export async function readdir(path: string): Promise<FileInfo[]> {
+ return res(await sendAsync("op_read_dir", { path }));
+}