first commit
This commit is contained in:
66
node_modules/locate-character/README.md
generated
vendored
Normal file
66
node_modules/locate-character/README.md
generated
vendored
Normal file
@@ -0,0 +1,66 @@
|
||||
# locate-character
|
||||
|
||||
Get the line and column number of a particular character in a string.
|
||||
|
||||
## Installation
|
||||
|
||||
`npm install locate-character`, or get it from [unpkg.com/locate-character](https://unpkg.com/locate-character).
|
||||
|
||||
## Usage
|
||||
|
||||
To search for a particular character, using the index or a search string, use `locate`:
|
||||
|
||||
```js
|
||||
import { locate } from 'locate-character';
|
||||
|
||||
const sample = `
|
||||
A flea and a fly in a flue
|
||||
Were imprisoned, so what could they do?
|
||||
Said the fly, "let us flee!"
|
||||
"Let us fly!" said the flea.
|
||||
So they flew through a flaw in the flue.
|
||||
`.trim();
|
||||
|
||||
// Using a character index
|
||||
const index = sample.indexOf('fly');
|
||||
locate(sample, index);
|
||||
// -> { line: 0, column: 13, character: 13 }
|
||||
|
||||
// Using the string itself
|
||||
locate(sample, 'fly');
|
||||
// -> { line: 0, column: 13, character: 13 }
|
||||
|
||||
// Using the string with a start index
|
||||
locate(sample, 'fly', { startIndex: 14 });
|
||||
// -> { line: 2, column: 9, character: 76 }
|
||||
```
|
||||
|
||||
If you will be searching the same string repeatedly, it's much faster if you use `getLocator`:
|
||||
|
||||
```js
|
||||
import { getLocator } from 'locate-character';
|
||||
|
||||
const locate = getLocator(sample);
|
||||
|
||||
let location = locate(13);
|
||||
// -> { line: 0, column: 13, character: 13 }
|
||||
|
||||
location = locate('fly', { startIndex: location.character + 1 });
|
||||
// -> { line: 2, column: 9, character: 76 }
|
||||
|
||||
location = locate('fly', { startIndex: location.character + 1 });
|
||||
// -> { line: 3, column: 8, character: 104 }
|
||||
```
|
||||
|
||||
In some situations (for example, dealing with sourcemaps), you need one-based line numbers:
|
||||
|
||||
```js
|
||||
getLocator(sample, { offsetLine: 1 });
|
||||
locate(sample, { offsetLine: 1 });
|
||||
```
|
||||
|
||||
There's also an `offsetColumn` option which is less useful in real-world situations.
|
||||
|
||||
## License
|
||||
|
||||
MIT
|
Reference in New Issue
Block a user