aboutsummaryrefslogtreecommitdiffstats
path: root/lsp/msbuild_project_tools_server.lua
blob: 0db6b3305f9ffb76af03d8f3796dcb0d03184f99 (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
local host_dll_name = 'MSBuildProjectTools.LanguageServer.Host.dll'
local util = require 'lspconfig.util'

---@brief
---
---https://github.com/tintoy/msbuild-project-tools-server/
--
-- MSBuild Project Tools Server can be installed by following the README.MD on the above repository.
--
-- Example config:
-- ```lua
-- vim.lsp.config('msbuild_project_tools_server', {
--   cmd = {'dotnet', '/path/to/server/MSBuildProjectTools.LanguageServer.Host.dll'}
-- })
-- ```
--
-- There's no builtin filetypes for msbuild files, would require some filetype aliases:
--
-- ```lua
-- vim.filetype.add({
--   extension = {
--     props = 'msbuild',
--     tasks = 'msbuild',
--     targets = 'msbuild',
--   },
--   pattern = {
--     [ [[.*\..*proj]] ] = 'msbuild',
--   },
-- })
-- ```
--
-- Optionally tell treesitter to treat `msbuild` as `xml` so you can get syntax highlighting if you have the treesitter-xml-parser installed.
--
-- ```lua
-- vim.treesitter.language.register('xml', { 'msbuild' })
-- ```
return {
  filetypes = { 'msbuild' },
  root_dir = function(bufnr, on_dir)
    local fname = vim.api.nvim_buf_get_name(bufnr)
    on_dir(util.root_pattern('*.sln', '*.slnx', '*.*proj', '.git')(fname))
  end,
  init_options = {},
  cmd = { 'dotnet', host_dll_name },
}