tiny-readdir-glob

A simple promisified recursive readdir function, with support for globs.

MIT 16 个版本
安装
npm install tiny-readdir-glob
yarn add tiny-readdir-glob
pnpm add tiny-readdir-glob
bun add tiny-readdir-glob
README

Tiny Readdir Glob

A simple promisified recursive readdir function, with support for globs.

Globs are expressed in zeptomatch's flavor.

Install

npm install tiny-readdir-glob

Usage

import readdir from 'tiny-readdir-glob';

// Let's recursively read into a directory using a glob

const aborter = new AbortController ();
const result = await readdir ( ['src/**/*.js'], {
  cwd: process.cwd (), // Directory to start the search from, defaults to process.cwd()
  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: ['**/.git', '**/node_modules'], // Globs, or raw 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
});

// This is how we would abort the recursive read after 10s

setTimeout ( () => aborter.abort (), 10_000 ); // Aborting if it's going to take longer than 10s

// This is what the result object will look like

result.directories; // => Array of absolute paths pointing to directories, filtered by the provided glob
result.files; // => Array of absolute paths pointing to files, filtered by the provided glob
result.symlinks; // => Array of absolute paths pointing to symlinks, filtered by the provided glob

License

MIT © Fabio Spampinato

版本列表
2.0.0 2026-02-22
1.23.2 2025-04-22
1.23.1 2025-02-10
1.23.0 2025-02-09
1.22.24 2024-03-29
1.22.23 2024-03-28
1.4.0 2024-03-19
1.3.0 2024-03-18
1.2.1 2023-12-15
1.2.0 2023-12-15
1.1.0 2023-12-01
1.0.4 2023-11-30
1.0.3 2023-11-28
1.0.2 2023-11-28
1.0.1 2023-11-24
1.0.0 2023-11-23