summaryrefslogtreecommitdiff
path: root/std/fs/empty_dir.ts
diff options
context:
space:
mode:
Diffstat (limited to 'std/fs/empty_dir.ts')
-rw-r--r--std/fs/empty_dir.ts48
1 files changed, 48 insertions, 0 deletions
diff --git a/std/fs/empty_dir.ts b/std/fs/empty_dir.ts
new file mode 100644
index 000000000..81bc45839
--- /dev/null
+++ b/std/fs/empty_dir.ts
@@ -0,0 +1,48 @@
+// Copyright 2018-2019 the Deno authors. All rights reserved. MIT license.
+/**
+ * Ensures that a directory is empty.
+ * Deletes directory contents if the directory is not empty.
+ * If the directory does not exist, it is created.
+ * The directory itself is not deleted.
+ */
+export async function emptyDir(dir: string): Promise<void> {
+ let items: Deno.FileInfo[] = [];
+ try {
+ items = await Deno.readDir(dir);
+ } catch {
+ // if not exist. then create it
+ await Deno.mkdir(dir, true);
+ return;
+ }
+ while (items.length) {
+ const item = items.shift();
+ if (item && item.name) {
+ const fn = dir + "/" + item.name;
+ await Deno.remove(fn, { recursive: true });
+ }
+ }
+}
+
+/**
+ * Ensures that a directory is empty.
+ * Deletes directory contents if the directory is not empty.
+ * If the directory does not exist, it is created.
+ * The directory itself is not deleted.
+ */
+export function emptyDirSync(dir: string): void {
+ let items: Deno.FileInfo[] = [];
+ try {
+ items = Deno.readDirSync(dir);
+ } catch {
+ // if not exist. then create it
+ Deno.mkdirSync(dir, true);
+ return;
+ }
+ while (items.length) {
+ const item = items.shift();
+ if (item && item.name) {
+ const fn = dir + "/" + item.name;
+ Deno.removeSync(fn, { recursive: true });
+ }
+ }
+}