An open API service indexing awesome lists of open source software.

https://github.com/vfile/vfile-find-down

utility to find one or more files by searching the file system downwards
https://github.com/vfile/vfile-find-down

file find fs vfile vfile-util virtual

Last synced: 4 months ago
JSON representation

utility to find one or more files by searching the file system downwards

Awesome Lists containing this project

README

          

# vfile-find-down

[![Build][build-badge]][build]
[![Coverage][coverage-badge]][coverage]
[![Downloads][downloads-badge]][downloads]
[![Sponsors][sponsors-badge]][collective]
[![Backers][backers-badge]][collective]
[![Chat][chat-badge]][chat]

[vfile][] utility to find files by searching the file system downwards.

## Contents

* [What is this?](#what-is-this)
* [When should I use this?](#when-should-i-use-this)
* [Install](#install)
* [Use](#use)
* [API](#api)
* [`findDown(test[, paths][, callback])`](#finddowntest-paths-callback)
* [`findDownAll(test[, paths][, callback])`](#finddownalltest-paths-callback)
* [`Assert`](#assert)
* [`Callback`](#callback)
* [`CallbackAll`](#callbackall)
* [`Result`](#result)
* [`Test`](#test)
* [Types](#types)
* [Compatibility](#compatibility)
* [Contribute](#contribute)
* [License](#license)

## What is this?

This utility lets you find one or many files downwards.

## When should I use this?

You can use this utility if you want to find files in, say, a folder.
One example is all markdown files.
If you instead want to find files upwards, such as config files, you can use
[`vfile-find-up`][vfile-find-up].

## Install

This package is [ESM only][esm].
In Node.js (version 16), install with [npm][]:

```sh
npm install vfile-find-down
```

## Use

```js
import {findDown} from 'vfile-find-down'

console.log(await findDown('.md'))
```

Yields:

```js
VFile {
cwd: '/Users/tilde/Projects/oss/vfile-find-down',
data: {},
history: [ '/Users/tilde/Projects/oss/vfile-find-down/readme.md' ],
messages: []
}
```

## API

This package exports the identifiers
[`findDown`][api-find-down] and
[`findDownAll`][api-find-down-all].
There is no default export.

### `findDown(test[, paths][, callback])`

Find the first file or folder downwards.

> 👉 **Note**: files are not read (their `value` is not populated).
> use [`to-vfile`][to-vfile] for that.

###### Signatures

* `(test[, paths], callback) => undefined`
* `(test[, paths]) => Promise`

###### Parameters

* `test` ([`Test`][api-test])
— things to search for
* `paths` (`Array | URL | string`, default: `process.cwd()`)
— places to search from
* `callback` ([`Callback`][api-callback], optional)
— callback called when done

###### Returns

Nothing when `callback` is given (`undefined`), otherwise a promise that
resolves to a file ([`VFile`][vfile] or `undefined`).

### `findDownAll(test[, paths][, callback])`

Find files or folders downwards.

> 👉 **Note**: files are not read (their `value` is not populated).
> use [`to-vfile`][to-vfile] for that.

###### Signatures

* `(test[, paths], callback) => undefined`
* `(test[, paths]) => Promise>`

###### Parameters

* `test` ([`Test`][api-test])
— things to search for
* `paths` (`Array | URL | string`, default: `process.cwd()`)
— places to search from
* `callback` ([`CallbackAll`][api-callback-all], optional)
— callback called when done

###### Returns

Nothing when `callback` is given (`undefined`), otherwise a promise that
resolves to files ([`Array`][vfile]).

### `Assert`

Handle a file (TypeScript type).

###### Parameters

* `file` ([`VFile`][vfile])
— file to handle
* `stats` ([`Stats`][stats])
— stats from `fs.stat`

###### Returns

How to handle this file ([`Result`][api-result], optional).

### `Callback`

Callback called when done finding one file (TypeScript type).

###### Parameters

* `error` (`Error` or `undefined`)
— error; errors are currently never passed
* `file` ([`VFile`][vfile] or `undefined`)
— file

###### Returns

Nothing (`undefined`).

### `CallbackAll`

Callback called when done (TypeScript type).

###### Parameters

* `error` (`Error` or `undefined`)
— error; errors are currently never passed
* `files` ([`Array`][vfile])
— files

###### Returns

Nothing (`undefined`).

### `Result`

What to do when collecting a file or folder (TypeScript type).

###### Fields

* `break` (`boolean`, default: `false`)
— stop searching after this file or folder
* `include` (`boolean`, default: `false`)
— include this file or folder
* `skip` (`boolean`, default: `false`)
— do not search inside this folder

### `Test`

Things to search for (TypeScript type).

For strings, the `basename` or `extname` of files must match them and
hidden folders and `node_modules` will not be searched.
For arrays, any test in them must match.

###### Type

```ts
type Test = Array | Assert | string
```

## Types

This package is fully typed with [TypeScript][].
It exports the additional types
[`Assert`][api-assert],
[`Callback`][api-callback],
[`CallbackAll`][api-callback-all],
[`Result`][api-result], and
[`Test`][api-test].

## Compatibility

Projects maintained by the unified collective are compatible with maintained
versions of Node.js.

When we cut a new major release, we drop support for unmaintained versions of
Node.
This means we try to keep the current release line, `vfile-find-down@^7`,
compatible with Node.js 16.

## Contribute

See [`contributing.md`][contributing] in [`vfile/.github`][health] for ways to
get started.
See [`support.md`][support] for ways to get help.

This project has a [code of conduct][coc].
By interacting with this repository, organization, or community you agree to
abide by its terms.

## License

[MIT][license] © [Titus Wormer][author]

[build-badge]: https://github.com/vfile/vfile-find-down/workflows/main/badge.svg

[build]: https://github.com/vfile/vfile-find-down/actions

[coverage-badge]: https://img.shields.io/codecov/c/github/vfile/vfile-find-down.svg

[coverage]: https://codecov.io/github/vfile/vfile-find-down

[downloads-badge]: https://img.shields.io/npm/dm/vfile-find-down.svg

[downloads]: https://www.npmjs.com/package/vfile-find-down

[sponsors-badge]: https://opencollective.com/unified/sponsors/badge.svg

[backers-badge]: https://opencollective.com/unified/backers/badge.svg

[collective]: https://opencollective.com/unified

[chat-badge]: https://img.shields.io/badge/chat-discussions-success.svg

[chat]: https://github.com/vfile/vfile/discussions

[npm]: https://docs.npmjs.com/cli/install

[esm]: https://gist.github.com/sindresorhus/a39789f98801d908bbc7ff3ecc99d99c

[typescript]: https://www.typescriptlang.org

[contributing]: https://github.com/vfile/.github/blob/main/contributing.md

[support]: https://github.com/vfile/.github/blob/main/support.md

[health]: https://github.com/vfile/.github

[coc]: https://github.com/vfile/.github/blob/main/code-of-conduct.md

[license]: license

[author]: https://wooorm.com

[vfile]: https://github.com/vfile/vfile

[to-vfile]: https://github.com/vfile/to-vfile

[vfile-find-up]: https://github.com/vfile/vfile-find-up

[stats]: https://nodejs.org/api/fs.html#fs_class_fs_stats

[api-find-down-all]: #finddownalltest-paths-callback

[api-find-down]: #finddowntest-paths-callback

[api-assert]: #assert

[api-callback]: #callback

[api-callback-all]: #callbackall

[api-result]: #result

[api-test]: #test