swc/crates/swc_bundler/tests/.cache/deno/76654db7bbc0e432ccc438345e4a583e0b486339.ts

56 lines
1.5 KiB
TypeScript
Raw Normal View History

// Loaded from https://deno.land/std@0.77.0/fs/ensure_dir.ts
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
import { getFileInfoType } from "./_util.ts";
/**
* Ensures that the directory exists.
* If the directory structure does not exist, it is created. Like mkdir -p.
* Requires the `--allow-read` and `--allow-write` flag.
*/
export async function ensureDir(dir: string): Promise<void> {
try {
const fileInfo = await Deno.lstat(dir);
if (!fileInfo.isDirectory) {
throw new Error(
`Ensure path exists, expected 'dir', got '${
getFileInfoType(fileInfo)
}'`,
);
}
} catch (err) {
if (err instanceof Deno.errors.NotFound) {
// if dir not exists. then create it.
await Deno.mkdir(dir, { recursive: true });
return;
}
throw err;
}
}
/**
* Ensures that the directory exists.
* If the directory structure does not exist, it is created. Like mkdir -p.
* Requires the `--allow-read` and `--allow-write` flag.
*/
export function ensureDirSync(dir: string): void {
try {
const fileInfo = Deno.lstatSync(dir);
if (!fileInfo.isDirectory) {
throw new Error(
`Ensure path exists, expected 'dir', got '${
getFileInfoType(fileInfo)
}'`,
);
}
} catch (err) {
if (err instanceof Deno.errors.NotFound) {
// if dir not exists. then create it.
Deno.mkdirSync(dir, { recursive: true });
return;
}
throw err;
}
}