2020-01-02 15:13:47 -05:00
|
|
|
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
|
2019-12-18 18:12:36 +08:00
|
|
|
import { join } from "../path/mod.ts";
|
2020-06-12 20:23:38 +01:00
|
|
|
|
2019-03-12 02:19:52 +08:00
|
|
|
/**
|
|
|
|
* 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.
|
2020-05-17 00:06:13 +05:30
|
|
|
* Requires the `--allow-read` and `--allow-write` flag.
|
2019-03-12 02:19:52 +08:00
|
|
|
*/
|
|
|
|
export async function emptyDir(dir: string): Promise<void> {
|
|
|
|
try {
|
2020-04-16 06:40:30 +01:00
|
|
|
const items = [];
|
2020-06-12 20:23:38 +01:00
|
|
|
for await (const dirEntry of Deno.readDir(dir)) {
|
2020-04-16 06:40:30 +01:00
|
|
|
items.push(dirEntry);
|
|
|
|
}
|
2019-12-18 18:12:36 +08:00
|
|
|
|
|
|
|
while (items.length) {
|
|
|
|
const item = items.shift();
|
|
|
|
if (item && item.name) {
|
|
|
|
const filepath = join(dir, item.name);
|
2020-06-12 20:23:38 +01:00
|
|
|
await Deno.remove(filepath, { recursive: true });
|
2019-12-18 18:12:36 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
} catch (err) {
|
2020-02-24 15:48:35 -05:00
|
|
|
if (!(err instanceof Deno.errors.NotFound)) {
|
2019-12-18 18:12:36 +08:00
|
|
|
throw err;
|
2019-03-12 02:19:52 +08:00
|
|
|
}
|
2019-12-18 18:12:36 +08:00
|
|
|
|
|
|
|
// if not exist. then create it
|
2020-06-12 20:23:38 +01:00
|
|
|
await Deno.mkdir(dir, { recursive: true });
|
2019-03-12 02:19:52 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 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.
|
2020-05-17 00:06:13 +05:30
|
|
|
* Requires the `--allow-read` and `--allow-write` flag.
|
2019-03-12 02:19:52 +08:00
|
|
|
*/
|
|
|
|
export function emptyDirSync(dir: string): void {
|
|
|
|
try {
|
2020-06-12 20:23:38 +01:00
|
|
|
const items = [...Deno.readDirSync(dir)];
|
2019-12-18 18:12:36 +08:00
|
|
|
|
2020-05-17 19:24:39 +02:00
|
|
|
// If the directory exists, remove all entries inside it.
|
2019-12-18 18:12:36 +08:00
|
|
|
while (items.length) {
|
|
|
|
const item = items.shift();
|
|
|
|
if (item && item.name) {
|
|
|
|
const filepath = join(dir, item.name);
|
2020-06-12 20:23:38 +01:00
|
|
|
Deno.removeSync(filepath, { recursive: true });
|
2019-12-18 18:12:36 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
} catch (err) {
|
2020-02-24 15:48:35 -05:00
|
|
|
if (!(err instanceof Deno.errors.NotFound)) {
|
2019-12-18 18:12:36 +08:00
|
|
|
throw err;
|
|
|
|
}
|
2019-03-12 02:19:52 +08:00
|
|
|
// if not exist. then create it
|
2020-06-12 20:23:38 +01:00
|
|
|
Deno.mkdirSync(dir, { recursive: true });
|
2019-03-12 02:19:52 +08:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|