watcher/dist_ts/tiny-readdir/index.js
2024-04-18 21:12:37 +02:00

179 lines
17 KiB
JavaScript

/* IMPORT */
import fs from 'node:fs';
import path from 'node:path';
import { isFunction, makeCounterPromise } from './utils.js';
/* MAIN */
//TODO: Streamline the type of dirnmaps
const readdir = (rootPath, options) => {
const followSymlinks = options?.followSymlinks ?? false;
const maxDepth = options?.depth ?? Infinity;
const maxPaths = options?.limit ?? Infinity;
const ignore = options?.ignore ?? (() => false);
const isIgnored = isFunction(ignore) ? ignore : (targetPath) => ignore.test(targetPath);
const signal = options?.signal ?? { aborted: false };
const directories = [];
const directoriesNames = new Set();
const directoriesNamesToPaths = {};
const files = [];
const filesNames = new Set();
const filesNamesToPaths = {};
const symlinks = [];
const symlinksNames = new Set();
const symlinksNamesToPaths = {};
const map = {};
const visited = new Set();
const resultEmpty = { directories: [], directoriesNames: new Set(), directoriesNamesToPaths: {}, files: [], filesNames: new Set(), filesNamesToPaths: {}, symlinks: [], symlinksNames: new Set(), symlinksNamesToPaths: {}, map: {} };
const result = { directories, directoriesNames, directoriesNamesToPaths, files, filesNames, filesNamesToPaths, symlinks, symlinksNames, symlinksNamesToPaths, map };
const { promise, increment, decrement } = makeCounterPromise();
let foundPaths = 0;
const handleDirectory = (dirmap, subPath, name, depth) => {
if (visited.has(subPath))
return;
if (foundPaths >= maxPaths)
return;
foundPaths += 1;
dirmap.directories.push(subPath);
dirmap.directoriesNames.add(name);
// dirmap.directoriesNamesToPaths.propertyIsEnumerable(name) || ( dirmap.directoriesNamesToPaths[name] = [] );
// dirmap.directoriesNamesToPaths[name].push ( subPath );
directories.push(subPath);
directoriesNames.add(name);
directoriesNamesToPaths.propertyIsEnumerable(name) || (directoriesNamesToPaths[name] = []);
directoriesNamesToPaths[name].push(subPath);
visited.add(subPath);
if (depth >= maxDepth)
return;
if (foundPaths >= maxPaths)
return;
populateResultFromPath(subPath, depth + 1);
};
const handleFile = (dirmap, subPath, name) => {
if (visited.has(subPath))
return;
if (foundPaths >= maxPaths)
return;
foundPaths += 1;
dirmap.files.push(subPath);
dirmap.filesNames.add(name);
// dirmap.filesNamesToPaths.propertyIsEnumerable(name) || ( dirmap.filesNamesToPaths[name] = [] );
// dirmap.filesNamesToPaths[name].push ( subPath );
files.push(subPath);
filesNames.add(name);
filesNamesToPaths.propertyIsEnumerable(name) || (filesNamesToPaths[name] = []);
filesNamesToPaths[name].push(subPath);
visited.add(subPath);
};
const handleSymlink = (dirmap, subPath, name, depth) => {
if (visited.has(subPath))
return;
if (foundPaths >= maxPaths)
return;
foundPaths += 1;
dirmap.symlinks.push(subPath);
dirmap.symlinksNames.add(name);
// dirmap.symlinksNamesToPaths.propertyIsEnumerable(name) || ( dirmap.symlinksNamesToPaths[name] = [] );
// dirmap.symlinksNamesToPaths[name].push ( subPath );
symlinks.push(subPath);
symlinksNames.add(name);
symlinksNamesToPaths.propertyIsEnumerable(name) || (symlinksNamesToPaths[name] = []);
symlinksNamesToPaths[name].push(subPath);
visited.add(subPath);
if (!followSymlinks)
return;
if (depth >= maxDepth)
return;
if (foundPaths >= maxPaths)
return;
populateResultFromSymlink(subPath, depth + 1);
};
const handleStat = (dirmap, rootPath, name, stat, depth) => {
if (signal.aborted)
return;
if (isIgnored(rootPath))
return;
if (stat.isDirectory()) {
handleDirectory(dirmap, rootPath, name, depth);
}
else if (stat.isFile()) {
handleFile(dirmap, rootPath, name);
}
else if (stat.isSymbolicLink()) {
handleSymlink(dirmap, rootPath, name, depth);
}
};
const handleDirent = (dirmap, rootPath, dirent, depth) => {
if (signal.aborted)
return;
const separator = (rootPath === path.sep) ? '' : path.sep;
const name = dirent.name;
const subPath = `${rootPath}${separator}${name}`;
if (isIgnored(subPath))
return;
if (dirent.isDirectory()) {
handleDirectory(dirmap, subPath, name, depth);
}
else if (dirent.isFile()) {
handleFile(dirmap, subPath, name);
}
else if (dirent.isSymbolicLink()) {
handleSymlink(dirmap, subPath, name, depth);
}
};
const handleDirents = (dirmap, rootPath, dirents, depth) => {
for (let i = 0, l = dirents.length; i < l; i++) {
handleDirent(dirmap, rootPath, dirents[i], depth);
}
};
const populateResultFromPath = (rootPath, depth) => {
if (signal.aborted)
return;
if (depth > maxDepth)
return;
if (foundPaths >= maxPaths)
return;
increment();
fs.readdir(rootPath, { withFileTypes: true }, (error, dirents) => {
if (error)
return decrement();
if (signal.aborted)
return decrement();
if (!dirents.length)
return decrement();
const dirmap = map[rootPath] = { directories: [], directoriesNames: new Set(), directoriesNamesToPaths: {}, files: [], filesNames: new Set(), filesNamesToPaths: {}, symlinks: [], symlinksNames: new Set(), symlinksNamesToPaths: {} };
handleDirents(dirmap, rootPath, dirents, depth);
decrement();
});
};
const populateResultFromSymlink = async (rootPath, depth) => {
increment();
fs.realpath(rootPath, (error, realPath) => {
if (error)
return decrement();
if (signal.aborted)
return decrement();
fs.stat(realPath, async (error, stat) => {
if (error)
return decrement();
if (signal.aborted)
return decrement();
const name = path.basename(realPath);
const dirmap = map[rootPath] = { directories: [], directoriesNames: new Set(), directoriesNamesToPaths: {}, files: [], filesNames: new Set(), filesNamesToPaths: {}, symlinks: [], symlinksNames: new Set(), symlinksNamesToPaths: {} };
handleStat(dirmap, realPath, name, stat, depth);
decrement();
});
});
};
const getResult = async (rootPath, depth = 1) => {
rootPath = path.normalize(rootPath);
visited.add(rootPath);
populateResultFromPath(rootPath, depth);
await promise;
if (signal.aborted)
return resultEmpty;
return result;
};
return getResult(rootPath);
};
/* EXPORT */
export default readdir;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../ts/tiny-readdir/index.ts"],"names":[],"mappings":"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"}