Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fabiospampinato/tiny-readdir
A simple promisified recursive readdir function.
https://github.com/fabiospampinato/tiny-readdir
promise readdir recursive simple tiny
Last synced: 24 days ago
JSON representation
A simple promisified recursive readdir function.
- Host: GitHub
- URL: https://github.com/fabiospampinato/tiny-readdir
- Owner: fabiospampinato
- License: mit
- Created: 2020-11-21T18:11:44.000Z (about 4 years ago)
- Default Branch: master
- Last Pushed: 2024-06-30T16:32:29.000Z (6 months ago)
- Last Synced: 2024-11-11T19:11:36.848Z (about 2 months ago)
- Topics: promise, readdir, recursive, simple, tiny
- Language: JavaScript
- Size: 48.8 KB
- Stars: 5
- Watchers: 3
- Forks: 4
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
- License: license
Awesome Lists containing this project
README
# Tiny Readdir
A simple promisified recursive readdir function.
## Install
```sh
npm install --save tiny-readdir
```## Usage
```ts
import readdir from 'tiny-readdir';const aborter = new AbortController ();
const result = await readdir ( '/foo/bar', {
depth: 20, // Maximum depth to look at
limit: 1_000_000, // Maximum number of files explored, useful as a stop gap in some edge cases
followSymlinks: true, // Whether to follow symlinks or not
ignore: targetPath => /node_modules/.test ( targetPath ), // Function that if returns true will ignore this particular file or a directory and its descendants
signal: aborter.signal, // Optional abort signal, useful for aborting potentially expensive operations
onDirents: dirents => console.log ( dirents ) // Optional callback that will be called as soon as new dirents are available, useful for example for discovering ".gitignore" files while searching
});result.directories; // => Array of absolute paths pointing to directories
result.files; // => Array of absolute paths pointing to files
result.symlinks; // => Array of absolute paths pointing to symlinksresult.directoriesNames; // => Set of directories names found
result.filesNames; // => Set of files name found
result.symlinksNames; // => Set of symlinks names foundresult.directoriesNamesToPaths; // => Record of directories names found to their paths
result.filesNamesToPaths; // => Record of files names found to their paths
result.symlinksNamesToPaths; // => Record of symlinks names found to their pathssetTimeout ( () => aborter.abort (), 10_000 ); // Aborting if it's going to take longer than 10s
```## License
MIT © Fabio Spampinato