LSP-json
Schema validation/completions for your JSON and Sublime files
Details
Installs
- Total 25K
- Win 9K
- Mac 9K
- Linux 7K
Jan 21 | Jan 20 | Jan 19 | Jan 18 | Jan 17 | Jan 16 | Jan 15 | Jan 14 | Jan 13 | Jan 12 | Jan 11 | Jan 10 | Jan 9 | Jan 8 | Jan 7 | Jan 6 | Jan 5 | Jan 4 | Jan 3 | Jan 2 | Jan 1 | Dec 31 | Dec 30 | Dec 29 | Dec 28 | Dec 27 | Dec 26 | Dec 25 | Dec 24 | Dec 23 | Dec 22 | Dec 21 | Dec 20 | Dec 19 | Dec 18 | Dec 17 | Dec 16 | Dec 15 | Dec 14 | Dec 13 | Dec 12 | Dec 11 | Dec 10 | Dec 9 | Dec 8 | Dec 7 | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Windows | 0 | 5 | 10 | 11 | 11 | 5 | 3 | 13 | 2 | 6 | 6 | 6 | 3 | 7 | 7 | 13 | 5 | 5 | 6 | 10 | 4 | 7 | 8 | 5 | 4 | 8 | 11 | 8 | 3 | 7 | 9 | 8 | 11 | 7 | 7 | 10 | 4 | 4 | 5 | 7 | 7 | 8 | 12 | 2 | 2 | 6 |
Mac | 0 | 4 | 4 | 4 | 3 | 12 | 8 | 8 | 7 | 1 | 3 | 2 | 10 | 11 | 7 | 6 | 2 | 4 | 4 | 6 | 4 | 5 | 5 | 5 | 7 | 7 | 7 | 5 | 6 | 5 | 4 | 6 | 9 | 10 | 9 | 8 | 3 | 6 | 8 | 10 | 4 | 3 | 4 | 7 | 5 | 6 |
Linux | 0 | 6 | 7 | 5 | 8 | 9 | 10 | 3 | 8 | 3 | 1 | 11 | 3 | 6 | 6 | 2 | 6 | 8 | 4 | 6 | 7 | 2 | 8 | 4 | 5 | 3 | 10 | 3 | 2 | 9 | 2 | 4 | 6 | 10 | 1 | 5 | 5 | 9 | 7 | 5 | 6 | 8 | 2 | 7 | 5 | 6 |
Readme
- Source
- raw.githubusercontent.com
LSP-json
JSON support for Sublime's LSP plugin.
Uses VSCode JSON Language Server to provide validation, formatting and other features for JSON files. See linked repository for more information.
Installation
- Install LSP and
LSP-json
from Package Control. - Restart Sublime.
Configuration
Open configuration file using command palette with Preferences: LSP-json Settings
command or opening it from the Sublime menu (Preferences > Package Settings > LSP > Servers > LSP-json
).
For users of PackageDev
The PackageDev package implements features that provide completions and tooltips when editing the Sublime settings files, which overlaps and conflicts with functionality provided by this package. To take advantage of the strict schemas that this package provides, disable corresponding functionality in PackageDev
by opening Preferences: PackageDev Settings
from the Command Palette and set the following settings on the right side:
{
"settings.auto_complete": false,
"settings.tooltip": false
}
Color Provider
The JSON-Language-Server implements a color provider that adds color decorators next to values representing colors in JSON files. If you are using a color plugin like ColorHelper or Color Highlight you may wish to disable this feature. To disable it open the LSP-json Settings as described above and add the following settings on the right side:
{
"disabled_capabilities": {
"colorProvider": true
}
}
Custom schemas
To load manually created schemas, add those to userSchemas
configuration in the settings file. See more information in the comments there.
The custom schema entry needs to look like:
{
"fileMatch": [
"/my-file.json"
],
"uri": "./my-file-schema.json",
}
The fileMatch
is an array of file patterns to match against when resolving JSON files to schemas. *
and **
can be used as a wildcard. Exclusion patterns can also be defined and start with !
. A file matches when there is at least one matching pattern and the last matching pattern is not an exclusion pattern.
The uri
is a URI or a file path to a schema. Can be a relative path (starting with ./
) when defined in a project settings and in that case will be resolved relative to the first project folder.
Schemas contributed by Packages
Sublime Text packages can provide schemas for its own settings, or contribute to global ST settings or other configuration files (for example *.sublime-project
files).
This is accomplished by including a sublime-package.json
file in the package (location doesn't matter) and defining schemas within it. Any changes made to the schemas are automatically applied to matching files so there is no need to restart the server or ST.
Here is a an example of three different schemas defined in one sublime-package.json
file:
{
"contributions": {
"settings": [
{
// Schema for MyPackage configuration.
"file_patterns": ["/MyPackage.sublime-settings"],
"schema": {
"properties": {
"my_cool_setting": {
"type": "string",
"default": "yes",
"enum": ["yes", "no"],
"markdownDescription": "Decides whether something is `on` or `off`."
}
},
"additionalProperties": false,
}
},
{
// Schema to extend global ST Preferences.
"file_patterns": ["/Preferences.sublime-settings"],
"schema": {
"properties": {
"my_cool_setting": {
// Reuses definition from the pattern-less schema defined below.
"$ref": "sublime://settings/foo/base#/definitions/ReuseMe"
}
},
}
},
{
// Pattern-less schema (note that "file_patterns" is missing).
// Can be added for the purpose of referencing it (or its definitions) from another schema.
// Pattern-less schema must define an "$id" to be able to refer to it from other schemas.
// It's recommended to assign URIs like "sublime://settings/foo/base" for "$id".
"schema": {
"$id": "sublime://settings/foo/base"
"definitions": {
"ReuseMe": {
"type": "string",
"default": "no",
"enum": ["yes", "no"],
"markdownDescription": "Decides whether something is `on` or `off`."
}
},
}
}
]
}
}