mirror of
https://github.com/denoland/deno.git
synced 2024-12-26 09:10:40 -05:00
53 lines
1.3 KiB
TypeScript
53 lines
1.3 KiB
TypeScript
|
// 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 });
|
||
|
}
|
||
|
}
|
||
|
}
|