2020-01-02 15:13:47 -05:00
|
|
|
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
|
2020-03-10 00:22:15 +01:00
|
|
|
import { sendSync, sendAsync } from "../dispatch_json.ts";
|
2019-03-10 04:30:38 +11:00
|
|
|
|
2020-01-07 14:14:33 -05:00
|
|
|
// TODO(ry) The complexity in argument parsing is to support deprecated forms of
|
|
|
|
// mkdir and mkdirSync.
|
|
|
|
function mkdirArgs(
|
|
|
|
path: string,
|
2020-03-02 15:24:42 -05:00
|
|
|
optionsOrRecursive?: MkdirOptions | boolean,
|
2020-01-07 14:14:33 -05:00
|
|
|
mode?: number
|
|
|
|
): { path: string; recursive: boolean; mode: number } {
|
|
|
|
const args = { path, recursive: false, mode: 0o777 };
|
|
|
|
if (typeof optionsOrRecursive == "boolean") {
|
|
|
|
args.recursive = optionsOrRecursive;
|
|
|
|
if (mode) {
|
|
|
|
args.mode = mode;
|
|
|
|
}
|
|
|
|
} else if (optionsOrRecursive) {
|
|
|
|
if (typeof optionsOrRecursive.recursive == "boolean") {
|
|
|
|
args.recursive = optionsOrRecursive.recursive;
|
|
|
|
}
|
|
|
|
if (optionsOrRecursive.mode) {
|
|
|
|
args.mode = optionsOrRecursive.mode;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return args;
|
|
|
|
}
|
|
|
|
|
2020-03-02 15:24:42 -05:00
|
|
|
export interface MkdirOptions {
|
2020-03-02 10:19:42 -05:00
|
|
|
/** Defaults to `false`. If set to `true`, means that any intermediate
|
|
|
|
* directories will also be created (as with the shell command `mkdir -p`).
|
|
|
|
* Intermediate directories are created with the same permissions.
|
|
|
|
* When recursive is set to `true`, succeeds silently (without changing any
|
|
|
|
* permissions) if a directory already exists at the path. */
|
2020-01-07 14:14:33 -05:00
|
|
|
recursive?: boolean;
|
2020-03-02 10:19:42 -05:00
|
|
|
/** Permissions to use when creating the directory (defaults to `0o777`,
|
|
|
|
* before the process's umask).
|
|
|
|
* Does nothing/raises on Windows. */
|
2020-01-07 14:14:33 -05:00
|
|
|
mode?: number;
|
|
|
|
}
|
|
|
|
|
2020-03-02 10:19:42 -05:00
|
|
|
/** Synchronously creates a new directory with the specified path.
|
2018-09-10 14:18:36 +04:30
|
|
|
*
|
2019-02-13 02:08:56 +11:00
|
|
|
* Deno.mkdirSync("new_dir");
|
2020-01-07 14:14:33 -05:00
|
|
|
* Deno.mkdirSync("nested/directories", { recursive: true });
|
2020-03-02 10:19:42 -05:00
|
|
|
*
|
|
|
|
* Requires `allow-write` permission. */
|
2020-01-07 14:14:33 -05:00
|
|
|
export function mkdirSync(
|
|
|
|
path: string,
|
2020-03-02 15:24:42 -05:00
|
|
|
optionsOrRecursive?: MkdirOptions | boolean,
|
2020-01-07 14:14:33 -05:00
|
|
|
mode?: number
|
|
|
|
): void {
|
2020-02-25 09:14:27 -05:00
|
|
|
sendSync("op_mkdir", mkdirArgs(path, optionsOrRecursive, mode));
|
2018-09-10 14:18:36 +04:30
|
|
|
}
|
|
|
|
|
2019-01-17 23:39:06 -05:00
|
|
|
/** Creates a new directory with the specified path.
|
2018-09-10 14:18:36 +04:30
|
|
|
*
|
2019-02-13 02:08:56 +11:00
|
|
|
* await Deno.mkdir("new_dir");
|
2020-01-07 14:14:33 -05:00
|
|
|
* await Deno.mkdir("nested/directories", { recursive: true });
|
2020-03-02 10:19:42 -05:00
|
|
|
*
|
|
|
|
* Requires `allow-write` permission. */
|
2019-01-17 23:39:06 -05:00
|
|
|
export async function mkdir(
|
|
|
|
path: string,
|
2020-03-02 15:24:42 -05:00
|
|
|
optionsOrRecursive?: MkdirOptions | boolean,
|
2020-01-07 14:14:33 -05:00
|
|
|
mode?: number
|
2019-01-17 23:39:06 -05:00
|
|
|
): Promise<void> {
|
2020-02-25 09:14:27 -05:00
|
|
|
await sendAsync("op_mkdir", mkdirArgs(path, optionsOrRecursive, mode));
|
2018-09-10 14:18:36 +04:30
|
|
|
}
|