summaryrefslogtreecommitdiff
path: root/fs/empty_dir.ts
diff options
context:
space:
mode:
Diffstat (limited to 'fs/empty_dir.ts')
-rw-r--r--fs/empty_dir.ts52
1 files changed, 52 insertions, 0 deletions
diff --git a/fs/empty_dir.ts b/fs/empty_dir.ts
new file mode 100644
index 000000000..2ca9efb0c
--- /dev/null
+++ b/fs/empty_dir.ts
@@ -0,0 +1,52 @@
+// 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
+ * @param {string} dir
+ * @returns {Promise<void>}
+ */
+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.path) {
+ await Deno.remove(item.path, { 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
+ * @param {string} dir
+ * @returns {void}
+ */
+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.path) {
+ Deno.removeSync(item.path, { recursive: true });
+ }
+ }
+}