JSON language service extracted from VSCode to be reused, e.g in the Monaco editor.
The vscode-json-languageservice contains the language smarts behind the JSON editing experience of Visual Studio Code and the Monaco editor.
-
doValidation analyses an input string and returns syntax and lint errors.
-
doComplete provides completion proposals for a given location. doResolve resolves a completion proposal
-
doResolve resolves a completion proposals.
-
doHover provides a hover text for a given location.
-
findDocumentSymbols provides all symbols in the given document
-
findDocumentColors provides all color symbols in the given document, getColorPresentations returns available color formats for a color symbol.
-
format formats the code at the given range.
-
getFoldingRanges gets folding ranges for the given document
-
getSelectionRanges gets selection ranges for a given location.
-
getMatchingSchemas matches a document against its schema and returns all AST nodes along with the matching sub schemas
-
use parseJSONDocument create a JSON document from source code, or newJSONDocument to create the document from an AST.
For the complete API see jsonLanguageService.ts and jsonLanguageTypes.ts
npm install --save vscode-json-languageservice
- 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
jsonCompletion.ts
- run the Unit tests from the run viewlet and wait until a breakpoint is hit:
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
- use
yarn link vscode-json-languageservice
invscode/extensions/json-language-features/server
to run VSCode with the latest changes fromvscode-json-languageservice
- run VSCode out of source (
vscode/scripts/code.sh|bat
) and open a.json
file - in VSCode window that is open on the
vscode-json-languageservice
sources, run commandDebug: Attach to Node process
and pick thecode-oss
process with thejson-language-features
path - set breakpoints, e.g. in
jsonCompletion.ts
- in the instance run from sources, invoke code completion in the
.json
file