// Copyright 2018-2025 the Deno authors. MIT license. // TODO(petamoriken): enable prefer-primordials for node polyfills // deno-lint-ignore-file prefer-primordials import type { CallbackWithError } from "ext:deno_node/_fs/_fs_common.ts"; import { promisify } from "ext:deno_node/internal/util.mjs"; import { denoErrorToNodeError } from "ext:deno_node/internal/errors.ts"; import { getValidatedPath } from "ext:deno_node/internal/fs/utils.mjs"; import { validateBoolean } from "ext:deno_node/internal/validators.mjs"; /** * TODO: Also accept 'path' parameter as a Node polyfill Buffer type once these * are implemented. See https://github.com/denoland/deno/issues/3403 */ type MkdirOptions = | { recursive?: boolean; mode?: number | undefined } | number | boolean; export function mkdir( path: string | URL, options?: MkdirOptions | CallbackWithError, callback?: CallbackWithError, ) { path = getValidatedPath(path) as string; let mode = 0o777; let recursive = false; if (typeof options == "function") { callback = options; } else if (typeof options === "number") { mode = options; } else if (typeof options === "boolean") { recursive = options; } else if (options) { if (options.recursive !== undefined) recursive = options.recursive; if (options.mode !== undefined) mode = options.mode; } validateBoolean(recursive, "options.recursive"); Deno.mkdir(path, { recursive, mode }) .then(() => { if (typeof callback === "function") { callback(null); } }, (err) => { if (typeof callback === "function") { callback(err); } }); } export const mkdirPromise = promisify(mkdir) as ( path: string | URL, options?: MkdirOptions, ) => Promise; export function mkdirSync(path: string | URL, options?: MkdirOptions) { path = getValidatedPath(path) as string; let mode = 0o777; let recursive = false; if (typeof options === "number") { mode = options; } else if (typeof options === "boolean") { recursive = options; } else if (options) { if (options.recursive !== undefined) recursive = options.recursive; if (options.mode !== undefined) mode = options.mode; } validateBoolean(recursive, "options.recursive"); try { Deno.mkdirSync(path, { recursive, mode }); } catch (err) { throw denoErrorToNodeError(err as Error, { syscall: "mkdir", path }); } }