summaryrefslogtreecommitdiff
path: root/cli/js/ops/fs/rename.ts
diff options
context:
space:
mode:
Diffstat (limited to 'cli/js/ops/fs/rename.ts')
-rw-r--r--cli/js/ops/fs/rename.ts25
1 files changed, 25 insertions, 0 deletions
diff --git a/cli/js/ops/fs/rename.ts b/cli/js/ops/fs/rename.ts
new file mode 100644
index 000000000..016ebc2d7
--- /dev/null
+++ b/cli/js/ops/fs/rename.ts
@@ -0,0 +1,25 @@
+// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
+import { sendSync, sendAsync } from "../dispatch_json.ts";
+
+/** Synchronously renames (moves) `oldpath` to `newpath`. If `newpath` already
+ * exists and is not a directory, `renameSync()` replaces it. OS-specific
+ * restrictions may apply when `oldpath` and `newpath` are in different
+ * directories.
+ *
+ * Deno.renameSync("old/path", "new/path");
+ *
+ * Requires `allow-read` and `allow-write` permissions. */
+export function renameSync(oldpath: string, newpath: string): void {
+ sendSync("op_rename", { oldpath, newpath });
+}
+
+/** Renames (moves) `oldpath` to `newpath`. If `newpath` already exists and is
+ * not a directory, `rename()` replaces it. OS-specific restrictions may apply
+ * when `oldpath` and `newpath` are in different directories.
+ *
+ * await Deno.rename("old/path", "new/path");
+ *
+ * Requires `allow-read` and `allow-write`. */
+export async function rename(oldpath: string, newpath: string): Promise<void> {
+ await sendAsync("op_rename", { oldpath, newpath });
+}