deep-list-dir
Version: 
Recursively lists given directory, alternatively filtering results with given options
76 lines (56 loc) • 1.79 kB
Markdown
# deep-list-dir
> Deeply lists a directory filtering files by given pattern(s)
<a href="https://www.npmjs.com/package/deep-list-dir" target="_blank"><img src="https://img.shields.io/npm/v/deep-list-dir.svg" alt="Version"></a>
[](https://github.com/devtin/deep-list-dir/actions)
This module recursively lists all files in given directory (including sub-folders) by early filtering the results using the
given `pattern` which can be an array of <a href="https://www.npmjs.com/package/minimatch" target="_blank">minimatch</a>
expressions or `RegExp`.
It will return all matching results. <a href="https://www.npmjs.com/package/minimatch" target="_blank">minimatch</a>
negative patterns are used to explicitly exclude a path from being scan / returned.
## Example
Take the following file structure:
```
<directory>
├── dir1
│   └── README.md
├── dir2
│   └── sub-dir2
│       ├── hi.txt
│       └── index.js
├── index.js
└── README.md
```
...and the following script:
```js
const { deepListDir, deepListDirSync } = require('deep-list-dir')
deepListDir('<directory>',
  {
    pattern: ['*.md'], // minimatch or RegExp
    // base: '', set parent base to something different than given directory
    // minimatchOptions: { matchBase: true } // minimatch options
  }
).then(console.log)
```
Will output
```json
[
  "dir1/README.md",
  "README.md"
]
```
A sync version is also provided:
```js
console.log(deepListDirSync('<directory>', { pattern: '*.js'})) 
```
Output:
```json
[
  "dir2/sub-dir2/index.js",
  "index.js"
]
```
* * *
### License
[MIT](https://opensource.org/licenses/MIT)
© 2020-present Martin Rafael Gonzalez
<tin@devtin.io>