diff options
Diffstat (limited to 'fs/empty_dir.ts')
| -rw-r--r-- | fs/empty_dir.ts | 52 |
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 }); + } + } +} |
