โšก The fastest directory crawler & globbing library for NodeJS. Crawls 1m files in < 1s

1019
36
JavaScript

The Fastest Directory Crawler & Globber for NodeJS

โšก The Fastest: Nothing similar (in the NodeJS world) beats fdir in speed. It can easily crawl a directory containing 1 million files in < 1 second.

๐Ÿ’ก Stupidly Easy: fdir uses expressive Builder pattern to build the crawler increasing code readability.

๐Ÿค– Zero Dependencies*: fdir only uses NodeJS fs & path modules.

๐Ÿ•บ Astonishingly Small: < 2KB in size gzipped & minified.

๐Ÿ–ฎ Hackable: Extending fdir is extremely simple now that the new Builder API is here. Feel free to experiment around.

* picomatch must be installed manually by the user to support globbing.

Support

Do you like this project? Support me by donating, creating an issue, becoming a stargazer, or opening a pull request. Thanks.

๐Ÿš„ Quickstart

Installation

You can install using npm:

$ npm i fdir

or Yarn:

$ yarn add fdir

Usage

import { fdir } from "fdir";

// create the builder
const api = new fdir().withFullPaths().crawl("path/to/dir");

// get all files in a directory synchronously
const files = api.sync();

// or asynchronously
api.withPromise().then((files) => {
  // do something with the result here.
});

Documentation:

Documentation for all methods is available here.

๐Ÿ“Š Benchmarks:

Please check the benchmark against the latest version here.

๐Ÿ™Used by:

fdir is downloaded over 200k+ times a week by projects around the world. Hereโ€™s a list of some notable projects using fdir in production:

Note: if you think your project should be here, feel free to open an issue. Notable is anything with a considerable amount of GitHub stars.

  1. mdn/yari
  2. streetwriters/notesnook
  3. zhangdaren/miniprogram-to-uniapp
  4. imba/imba
  5. moroshko/react-scanner
  6. netlify/build
  7. FredKSchott/snowpack*
  8. yassinedoghri/astro-i18next
  9. immich-app/CLI
  10. selfrefactor/rambda
  • snowpack has since been discontinued.

๐Ÿฆฎ LICENSE

Copyright ยฉ 2023 Abdullah Atta under MIT. Read full text here.