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
|
local util = require 'lspconfig.util'
local bin_name = 'kotlin-language-server'
--- The presence of one of these files indicates a project root directory
--
-- These are configuration files for the various build systems supported by
-- Kotlin. I am not sure whether the language server supports Ant projects,
-- but I'm keeping it here as well since Ant does support Kotlin.
local root_files = {
'settings.gradle', -- Gradle (multi-project)
'settings.gradle.kts', -- Gradle (multi-project)
'build.xml', -- Ant
'pom.xml', -- Maven
'build.gradle', -- Gradle
'build.gradle.kts', -- Gradle
}
---@brief
---
---A kotlin language server which was developed for internal usage and
-- released afterwards. Maintaining is not done by the original author,
-- but by fwcd.
-- It is built via gradle and developed on github.
-- Source and additional description:
-- https://github.com/fwcd/kotlin-language-server
-- This server requires vim to be aware of the kotlin-filetype.
-- You could refer for this capability to:
-- https://github.com/udalov/kotlin-vim (recommended)
-- Note that there is no LICENSE specified yet.
-- For faster startup, you can setup caching by specifying a storagePath
-- in the init_options. The default is your home directory.
return {
filetypes = { 'kotlin' },
root_markers = root_files,
cmd = { bin_name }, -- kotlin-language-server
init_options = {
-- Enables caching and use project root to store cache data.
storagePath = util.root_pattern(unpack(root_files))(vim.fn.expand '%:p:h'),
},
}
|