kjelsrud.dev/node_modules/vfile-location/readme.md
2023-07-19 21:31:30 +02:00

185 lines
4.6 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# vfile-location
[![Build][build-badge]][build]
[![Coverage][coverage-badge]][coverage]
[![Downloads][downloads-badge]][downloads]
[![Size][size-badge]][size]
[![Sponsors][sponsors-badge]][collective]
[![Backers][backers-badge]][collective]
[![Chat][chat-badge]][chat]
[vfile][] utility to convert between positional (line and column-based) and
offsets (range-based) locations.
## Contents
* [What is this?](#what-is-this)
* [When should I use this?](#when-should-i-use-this)
* [Install](#install)
* [Use](#use)
* [API](#api)
* [`location(file)`](#locationfile)
* [`Location`](#location)
* [Types](#types)
* [Compatibility](#compatibility)
* [Contribute](#contribute)
* [License](#license)
## What is this?
This is a tiny but useful package to convert between arbitrary places in a
file.
## When should I use this?
This utility is useful when ASTs nodes dont cut it.
For example, when you are making a lint rule that looks for dangerous
characters in a file, which you accomplish by searching the raw file value,
and still want to report it to users.
## Install
This package is [ESM only][esm].
In Node.js (version 14.14+ and 16.0+), install with [npm][]:
```sh
npm install vfile-location
```
In Deno with [`esm.sh`][esmsh]:
```js
import {location} from 'https://esm.sh/vfile-location@4'
```
In browsers with [`esm.sh`][esmsh]:
```html
<script type="module">
import {location} from 'https://esm.sh/vfile-location@4?bundle'
</script>
```
## Use
```js
import {VFile} from 'vfile'
import {location} from 'vfile-location'
const place = location(new VFile('foo\nbar\nbaz'))
const offset = place.toOffset({line: 3, column: 3}) // => 10
place.toPoint(offset) // => {line: 3, column: 3, offset: 10}
```
## API
This package exports the identifier [`location`][api-location].
There is no default export.
### `location(file)`
Index the given document so you can translate between line/column and offset
based positional info.
###### Parameters
* `file` (`string`, `Buffer`, or [`VFile`][vfile])
— file to index
###### Returns
Accessors for index ([`Location`][api-location-map]).
### `Location`
Accessors for index (TypeScript type).
###### Fields
* `toPoint` (`(offset?: number) => Point`)
— get a line/column-based [`Point`][point] from `offset`
* `toOffset` (`(point?: Point) => number`)
— get an offset from a line/column-based [`point`][point]
## Types
This package is fully typed with [TypeScript][].
It exports the additional type [`Location`][api-location-map].
## Compatibility
Projects maintained by the unified collective are compatible with all maintained
versions of Node.js.
As of now, that is Node.js 14.14+ and 16.0+.
Our projects sometimes work with older versions, but this is not guaranteed.
## 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]
<!-- Definitions -->
[build-badge]: https://github.com/vfile/vfile-location/workflows/main/badge.svg
[build]: https://github.com/vfile/vfile-location/actions
[coverage-badge]: https://img.shields.io/codecov/c/github/vfile/vfile-location.svg
[coverage]: https://codecov.io/github/vfile/vfile-location
[downloads-badge]: https://img.shields.io/npm/dm/vfile-location.svg
[downloads]: https://www.npmjs.com/package/vfile-location
[size-badge]: https://img.shields.io/bundlephobia/minzip/vfile-location.svg
[size]: https://bundlephobia.com/result?p=vfile-location
[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
[esmsh]: https://esm.sh
[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
[point]: https://github.com/syntax-tree/unist#point
[api-location]: #locationfile
[api-location-map]: #location