summaryrefslogtreecommitdiff
path: root/ext/node/polyfills/_fs/_fs_opendir.ts
diff options
context:
space:
mode:
Diffstat (limited to 'ext/node/polyfills/_fs/_fs_opendir.ts')
-rw-r--r--ext/node/polyfills/_fs/_fs_opendir.ts89
1 files changed, 89 insertions, 0 deletions
diff --git a/ext/node/polyfills/_fs/_fs_opendir.ts b/ext/node/polyfills/_fs/_fs_opendir.ts
new file mode 100644
index 000000000..5ee13f951
--- /dev/null
+++ b/ext/node/polyfills/_fs/_fs_opendir.ts
@@ -0,0 +1,89 @@
+// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
+
+import Dir from "internal:deno_node/polyfills/_fs/_fs_dir.ts";
+import { Buffer } from "internal:deno_node/polyfills/buffer.ts";
+import {
+ getOptions,
+ getValidatedPath,
+} from "internal:deno_node/polyfills/internal/fs/utils.mjs";
+import { denoErrorToNodeError } from "internal:deno_node/polyfills/internal/errors.ts";
+import {
+ validateFunction,
+ validateInteger,
+} from "internal:deno_node/polyfills/internal/validators.mjs";
+import { promisify } from "internal:deno_node/polyfills/internal/util.mjs";
+
+/** These options aren't funcitonally used right now, as `Dir` doesn't yet support them.
+ * However, these values are still validated.
+ */
+type Options = {
+ encoding?: string;
+ bufferSize?: number;
+};
+type Callback = (err?: Error | null, dir?: Dir) => void;
+
+function _validateFunction(callback: unknown): asserts callback is Callback {
+ validateFunction(callback, "callback");
+}
+
+/** @link https://nodejs.org/api/fs.html#fsopendirsyncpath-options */
+export function opendir(
+ path: string | Buffer | URL,
+ options: Options | Callback,
+ callback?: Callback,
+) {
+ callback = typeof options === "function" ? options : callback;
+ _validateFunction(callback);
+
+ path = getValidatedPath(path).toString();
+
+ let err, dir;
+ try {
+ const { bufferSize } = getOptions(options, {
+ encoding: "utf8",
+ bufferSize: 32,
+ });
+ validateInteger(bufferSize, "options.bufferSize", 1, 4294967295);
+
+ /** Throws if path is invalid */
+ Deno.readDirSync(path);
+
+ dir = new Dir(path);
+ } catch (error) {
+ err = denoErrorToNodeError(error as Error, { syscall: "opendir" });
+ }
+ if (err) {
+ callback(err);
+ } else {
+ callback(null, dir);
+ }
+}
+
+/** @link https://nodejs.org/api/fs.html#fspromisesopendirpath-options */
+export const opendirPromise = promisify(opendir) as (
+ path: string | Buffer | URL,
+ options?: Options,
+) => Promise<Dir>;
+
+export function opendirSync(
+ path: string | Buffer | URL,
+ options?: Options,
+): Dir {
+ path = getValidatedPath(path).toString();
+
+ const { bufferSize } = getOptions(options, {
+ encoding: "utf8",
+ bufferSize: 32,
+ });
+
+ validateInteger(bufferSize, "options.bufferSize", 1, 4294967295);
+
+ try {
+ /** Throws if path is invalid */
+ Deno.readDirSync(path);
+
+ return new Dir(path);
+ } catch (err) {
+ throw denoErrorToNodeError(err as Error, { syscall: "opendir" });
+ }
+}