blowfish/node_modules/rimraf/dist/mjs/rimraf-posix.js

51 lines
2 KiB
JavaScript
Raw Normal View History

2023-01-29 22:30:24 +00:00
// the simple recursive removal, where unlink and rmdir are atomic
// Note that this approach does NOT work on Windows!
// We rmdir before unlink even though that is arguably less efficient
// (since the average folder contains >1 file, it means more system
// calls), because sunos will let root unlink a directory, and some
// SUPER weird breakage happens as a result.
import { promises, rmdirSync, unlinkSync } from './fs.js';
const { rmdir, unlink } = promises;
import { parse, resolve } from 'path';
import { readdirOrError, readdirOrErrorSync } from './readdir-or-error.js';
import { ignoreENOENT, ignoreENOENTSync } from './ignore-enoent.js';
export const rimrafPosix = async (path, opt) => {
const entries = await readdirOrError(path);
if (!Array.isArray(entries)) {
if (entries.code === 'ENOENT') {
return;
}
if (entries.code !== 'ENOTDIR') {
throw entries;
}
return ignoreENOENT(unlink(path));
}
await Promise.all(entries.map(entry => rimrafPosix(resolve(path, entry), opt)));
// we don't ever ACTUALLY try to unlink /, because that can never work
// but when preserveRoot is false, we could be operating on it.
// No need to check if preserveRoot is not false.
if (opt.preserveRoot === false && path === parse(path).root) {
return;
}
return ignoreENOENT(rmdir(path));
};
export const rimrafPosixSync = (path, opt) => {
const entries = readdirOrErrorSync(path);
if (!Array.isArray(entries)) {
if (entries.code === 'ENOENT') {
return;
}
if (entries.code !== 'ENOTDIR') {
throw entries;
}
return ignoreENOENTSync(() => unlinkSync(path));
}
for (const entry of entries) {
rimrafPosixSync(resolve(path, entry), opt);
}
if (opt.preserveRoot === false && path === parse(path).root) {
return;
}
return ignoreENOENTSync(() => rmdirSync(path));
};
//# sourceMappingURL=rimraf-posix.js.map