Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sindresorhus/open-editor
Open files in your editor at a specific line and column
https://github.com/sindresorhus/open-editor
Last synced: 4 days ago
JSON representation
Open files in your editor at a specific line and column
- Host: GitHub
- URL: https://github.com/sindresorhus/open-editor
- Owner: sindresorhus
- License: mit
- Created: 2017-05-04T14:13:37.000Z (over 7 years ago)
- Default Branch: main
- Last Pushed: 2024-12-22T18:06:42.000Z (about 1 month ago)
- Last Synced: 2025-01-16T04:24:43.795Z (12 days ago)
- Language: JavaScript
- Size: 26.4 KB
- Stars: 201
- Watchers: 5
- Forks: 15
- Open Issues: 2
-
Metadata Files:
- Readme: readme.md
- License: license
Awesome Lists containing this project
- awesome-javascript - open-editor
- awesome-javascript - open-editor
README
# open-editor
> Open files in your editor at a specific line and column
Supports any editor, but only the following editors will open at a specific line and column:
- Sublime Text
- Atom
- Zed
- Visual Studio Code
- VSCodium
- WebStorm*
- TextMate
- Vim
- NeoVim
- IntelliJ IDEA**\*Doesn't support column.*
## Install
```sh
npm install open-editor
```## Usage
```js
import openEditor from 'open-editor';openEditor([
{
file: 'readme.md',
line: 10,
column: 2,
}
]);openEditor([
'unicorn.js:5:3',
]);
```## API
### openEditor(files, options?)
Open the given files in the user's editor at specific line and column if supported by the editor. It does not wait for the editor to start or quit unless you specify `wait: true` in the options.
#### files
Type: `Array`
Items should be in the format `foo.js:1:5` or `{file: 'foo.js', line: 1: column: 5}`.
#### options
Type: `object`
##### wait
Type: `boolean`\
Default: `false`Wait until the editor is closed.
```js
import openEditor from 'open-editor';await openEditor(['unicorn.js:5:3'], {wait: true});
console.log('File was closed');
```##### editor
Type: `string`\
Default: [Auto-detected](https://github.com/sindresorhus/env-editor)The name, command, or binary path of the editor.
**Only use this option if you really have to.** Can be useful if you want to force a specific editor or implement your own auto-detection.
### getEditorInfo(files, options?)
Same as `openEditor()`, but returns an object with the binary name, arguments, and a flag indicating whether the editor runs in the terminal.
Example: `{binary: 'subl', arguments: ['foo.js:1:5'], isTerminalEditor: false}`
Can be useful if you want to handle opening the files yourself.
```js
import {getEditorInfo} from 'open-editor';getEditorInfo([
{
file: 'foo.js',
line: 1,
column: 5,
}
]);
//=> {binary: 'subl', arguments: ['foo.js:1:5'], isTerminalEditor: false}
```## Related
- [open-editor-cli](https://github.com/sindresorhus/open-editor-cli) - CLI for this module
- [open](https://github.com/sindresorhus/open) - Open stuff like URLs, files, executables