rrdir v13.2.1
rrdir
Recursive directory reader with a delightful API
rrdir recursively reads a directory and returns entries within via an async iterator or async/sync as Array. It can typically iterate millions of files in a matter of seconds. Memory usage is O(1) for the async iterator and O(n) for the Array variants.
Contrary to other similar modules, this module is optionally able to read any path including ones that contain invalid UTF-8 sequences.
Usage
npm i rrdirimport {rrdir, rrdirAsync, rrdirSync} from "rrdir";
for await (const entry of rrdir("dir")) {
// => {path: 'dir/file', directory: false, symlink: false}
}
const entries = await rrdirAsync("dir");
// => [{path: 'dir/file', directory: false, symlink: false}]
const entries = rrdirSync("dir");
// => [{path: 'dir/file', directory: false, symlink: false}]API
rrdir(dir, [options])
rrdirAsync(dir, [options])
rrdirSync(dir, [options])
rrdir is an async iterator which yields entry. rrdirAsync and rrdirSync return an Array of entry.
dir String | Uint8Array
The directory to read, either absolute or relative. Pass a Uint8Array to switch the module into Uint8Array mode which is required to be able to read every file, like for example files with names that are invalid UTF-8 sequences.
options Object
statsboolean: Whether to includeentry.stats. Will reduce performance. Default:false.followSymlinksboolean: Whether to follow symlinks for both recursion andstatcalls. Default:false.excludeArray: Path globs to exclude, e.g.["**.js"]. Default:undefined.includeArray: Path globs to include, e.g.["**.map"]. Default:undefined.strictboolean: Whether to throw immediately when reading an entry fails. Default:false.insensitiveboolean: Whetherincludeandexcludematch case-insensitively. Default:false.
entry Object
pathstring | Uint8Array: The path to the entry, will be relative ifdiris given relative. Ifdiris aUint8Array, this will be too. Always present.directoryboolean: Boolean indicating whether the entry is a directory.undefinedon error.symlinkboolean: Boolean indicating whether the entry is a symbolic link.undefinedon error.statsObject: Afs.statsobject, present whenoptions.statsis set.undefinedon error.errError: Any error encountered while reading this entry.undefinedon success.
© silverwind, distributed under BSD licence
11 months ago
8 months ago
1 year ago
1 year ago
1 year ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
3 years ago
2 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago