summaryrefslogtreecommitdiff
path: root/js/mkdir.ts
blob: 784d891f91a69b09479bbb4ac4564b8076259815 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
// Copyright 2018-2019 the Deno authors. All rights reserved. MIT license.
import * as msg from "gen/msg_generated";
import * as flatbuffers from "./flatbuffers";
import * as dispatch from "./dispatch";

function req(
  path: string,
  recursive: boolean,
  mode: number
): [flatbuffers.Builder, msg.Any, flatbuffers.Offset] {
  const builder = flatbuffers.createBuilder();
  const path_ = builder.createString(path);
  msg.Mkdir.startMkdir(builder);
  msg.Mkdir.addPath(builder, path_);
  msg.Mkdir.addRecursive(builder, recursive);
  msg.Mkdir.addMode(builder, mode);
  const inner = msg.Mkdir.endMkdir(builder);
  return [builder, msg.Any.Mkdir, inner];
}

/** 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.
 *
 *       Deno.mkdirSync("new_dir");
 *       Deno.mkdirSync("nested/directories", true);
 */
export function mkdirSync(path: string, recursive = false, mode = 0o777): void {
  dispatch.sendSync(...req(path, recursive, mode));
}

/** 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.
 *
 *       await Deno.mkdir("new_dir");
 *       await Deno.mkdir("nested/directories", true);
 */
export async function mkdir(
  path: string,
  recursive = false,
  mode = 0o777
): Promise<void> {
  await dispatch.sendAsync(...req(path, recursive, mode));
}