2019-01-22 04:03:30 +09:00
|
|
|
// Copyright 2018-2019 the Deno authors. All rights reserved. MIT license.
|
2019-08-26 16:18:42 +02:00
|
|
|
import { sendSync, sendAsync } from "./dispatch_json";
|
|
|
|
import * as dispatch from "./dispatch";
|
2019-03-10 04:30:38 +11:00
|
|
|
|
2019-01-17 23:39:06 -05:00
|
|
|
/** Creates a new directory with the specified path synchronously.
|
|
|
|
* If `recursive` is set to true, nested directories will be created (also known
|
|
|
|
* as "mkdir -p").
|
|
|
|
* `mode` sets permission bits (before umask) on UNIX and does nothing on
|
|
|
|
* Windows.
|
2018-09-10 14:18:36 +04:30
|
|
|
*
|
2019-02-13 02:08:56 +11:00
|
|
|
* Deno.mkdirSync("new_dir");
|
|
|
|
* Deno.mkdirSync("nested/directories", true);
|
2018-09-10 14:18:36 +04:30
|
|
|
*/
|
2019-01-17 23:39:06 -05:00
|
|
|
export function mkdirSync(path: string, recursive = false, mode = 0o777): void {
|
2019-08-26 16:18:42 +02:00
|
|
|
sendSync(dispatch.OP_MKDIR, { path, recursive, 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.
|
|
|
|
* If `recursive` is set to true, nested directories will be created (also known
|
|
|
|
* as "mkdir -p").
|
|
|
|
* `mode` sets permission bits (before umask) on UNIX and does nothing on
|
|
|
|
* Windows.
|
2018-09-10 14:18:36 +04:30
|
|
|
*
|
2019-02-13 02:08:56 +11:00
|
|
|
* await Deno.mkdir("new_dir");
|
|
|
|
* await Deno.mkdir("nested/directories", true);
|
2018-09-10 14:18:36 +04:30
|
|
|
*/
|
2019-01-17 23:39:06 -05:00
|
|
|
export async function mkdir(
|
|
|
|
path: string,
|
|
|
|
recursive = false,
|
|
|
|
mode = 0o777
|
|
|
|
): Promise<void> {
|
2019-08-26 16:18:42 +02:00
|
|
|
await sendAsync(dispatch.OP_MKDIR, { path, recursive, mode });
|
2018-09-10 14:18:36 +04:30
|
|
|
}
|