blob: 3db6b83d9fab3c67b876702e5efd81bcfc401794 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
|
local configs = require 'lspconfig/configs'
local util = require 'lspconfig/util'
local server_name = "jsonls"
local bin_name = "vscode-json-languageserver"
configs[server_name] = {
default_config = {
cmd = {bin_name, "--stdio"};
filetypes = {"json"};
init_options = {
provideFormatter = true;
};
root_dir = util.root_pattern(".git", vim.fn.getcwd());
};
docs = {
-- this language server config is in VSCode built-in package.json
package_json = "https://raw.githubusercontent.com/microsoft/vscode/master/extensions/json-language-features/package.json";
description = [[
https://github.com/vscode-langservers/vscode-json-languageserver
vscode-json-languageserver, a language server for JSON and JSON schema
`vscode-json-languageserver` can be installed via `npm`:
```sh
npm install -g vscode-json-languageserver
```
vscode-json-languageserver only provides range formatting. You can map a command that applies range formatting to the entire document:
```lua
require'lspconfig'.jsonls.setup {
commands = {
Format = {
function()
vim.lsp.buf.range_formatting({},{0,0},{vim.fn.line("$"),0})
end
}
}
}
```
]];
default_config = {
root_dir = [[root_pattern(".git", vim.fn.getcwd())]];
};
};
}
-- vim:et ts=2 sw=2
|