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
50
51
52
53
54
55
56
57
58
|
local util = require 'lspconfig.util'
local function build_index()
local params = {
command = 'systemverilog.build_index',
}
vim.lsp.buf.execute_command(params)
end
local function report_hierarchy()
local params = {
command = 'systemverilog.report_hierarchy',
arguments = { vim.fn.expand '<cword>' },
}
vim.lsp.buf.execute_command(params)
end
return {
default_config = {
cmd = { 'svlangserver' },
filetypes = { 'verilog', 'systemverilog' },
root_dir = function(fname)
return util.root_pattern '.svlangserver'(fname) or util.find_git_ancestor(fname)
end,
single_file_support = true,
settings = {
systemverilog = {
includeIndexing = { '*.{v,vh,sv,svh}', '**/*.{v,vh,sv,svh}' },
},
},
},
commands = {
SvlangserverBuildIndex = {
build_index,
description = 'Instructs language server to rerun indexing',
},
SvlangserverReportHierarchy = {
report_hierarchy,
description = 'Generates hierarchy for the given module',
},
},
docs = {
description = [[
https://github.com/imc-trading/svlangserver
Language server for SystemVerilog.
`svlangserver` can be installed via `npm`:
```sh
$ npm install -g @imc-trading/svlangserver
```
]],
default_config = {
root_dir = [[root_pattern(".svlangserver", ".git")]],
},
},
}
|