70 lines
3.2 KiB
Markdown
70 lines
3.2 KiB
Markdown
![]() |
# vscode-html-languageservice
|
||
|
HTML language service extracted from VSCode to be reused, e.g in the Monaco editor.
|
||
|
|
||
|
[data:image/s3,"s3://crabby-images/54650/546502f817c32bf98097620370a8aac98bde2946" alt="npm Package"](https://www.npmjs.org/package/vscode-html-languageservice)
|
||
|
[data:image/s3,"s3://crabby-images/bece9/bece9b1987f57b01d3dcfd7cb025168dec12bd83" alt="NPM Downloads"](https://npmjs.org/package/vscode-html-languageservice)
|
||
|
[data:image/s3,"s3://crabby-images/dc931/dc931a2aebbe9acb57529529bd33e487543866cf" alt="Build Status"](https://github.com/microsoft/vscode-html-languageservice/actions)
|
||
|
[data:image/s3,"s3://crabby-images/7a4eb/7a4eb7dde90b3c6effc80e7c87d5259e805747df" alt="License: MIT"](https://opensource.org/licenses/MIT)
|
||
|
|
||
|
Why?
|
||
|
----
|
||
|
|
||
|
The _vscode-html-languageservice_ contains the language smarts behind the HTML editing experience of Visual Studio Code
|
||
|
and the Monaco editor.
|
||
|
|
||
|
- *doComplete* / *doComplete2* (async) provide completion proposals for a given location.
|
||
|
- *setCompletionParticipants* allows participant to provide suggestions for specific tokens.
|
||
|
- *doHover* provides hover information at a given location.
|
||
|
|
||
|
- *format* formats the code at the given range.
|
||
|
- *findDocumentLinks* finds all links in the document.
|
||
|
- *findDocumentSymbols* finds all the symbols in the document.
|
||
|
- *getFoldingRanges* return folding ranges for the given document.
|
||
|
- *getSelectionRanges* return the selection ranges for the given document.
|
||
|
...
|
||
|
|
||
|
For the complete API see [htmlLanguageService.ts](./src/htmlLanguageService.ts) and [htmlLanguageTypes.ts](./src/htmlLanguageTypes.ts)
|
||
|
|
||
|
Installation
|
||
|
------------
|
||
|
|
||
|
npm install --save vscode-html-languageservice
|
||
|
|
||
|
Development
|
||
|
-----------
|
||
|
|
||
|
- clone this repo, run yarn
|
||
|
- `yarn test` to compile and run tests
|
||
|
|
||
|
|
||
|
How can I run and debug the service?
|
||
|
|
||
|
- open the folder in VSCode.
|
||
|
- set breakpoints, e.g. in `htmlCompletion.ts`
|
||
|
- run the Unit tests from the run viewlet and wait until a breakpoint is hit:
|
||
|
data:image/s3,"s3://crabby-images/278aa/278aac4d571862651bbb19cebd27073a64fbd5b1" alt="image"
|
||
|
|
||
|
|
||
|
How can I run and debug the service inside an instance of VSCode?
|
||
|
|
||
|
- run VSCode out of sources setup as described here: https://github.com/Microsoft/vscode/wiki/How-to-Contribute
|
||
|
- link the folder of the `vscode-html-languageservice` repo to `vscode/extensions/html-language-features/server` to run VSCode with the latest changes from that folder:
|
||
|
- cd `vscode-html-languageservice`, `yarn link`
|
||
|
- cd `vscode/extensions/html-language-features/server`, `yarn link vscode-html-languageservice`
|
||
|
- run VSCode out of source (`vscode/scripts/code.sh|bat`) and open a `.html` file
|
||
|
- in VSCode window that is open on the `vscode-html-languageservice` sources, run command `Debug: Attach to Node process` and pick the `code-oss` process with the `html-language-features` path
|
||
|
data:image/s3,"s3://crabby-images/72134/72134c67e9023eb055021063310e95a08dff26e2" alt="image"
|
||
|
- set breakpoints, e.g. in `htmlCompletion.ts`
|
||
|
- in the instance run from sources, invoke code completion in the `.html` file
|
||
|
|
||
|
|
||
|
License
|
||
|
-------
|
||
|
|
||
|
(MIT License)
|
||
|
|
||
|
Copyright 2016-2020, Microsoft
|
||
|
|
||
|
With the exceptions of `data/*.json`, which is built upon content from [Mozilla Developer Network](https://developer.mozilla.org/en-US/docs/Web)
|
||
|
and distributed under CC BY-SA 2.5.
|