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
|
---@brief
---
--- https://github.com/elixir-lsp/elixir-ls
---
--- `elixir-ls` can be installed by following the instructions [here](https://github.com/elixir-lsp/elixir-ls#building-and-running).
---
--- 1. Download the zip from https://github.com/elixir-lsp/elixir-ls/releases/latest/
--- 2. Unzip it and make it executable.
--- ```bash
--- unzip elixir-ls.zip -d /path/to/elixir-ls
--- # Unix
--- chmod +x /path/to/elixir-ls/language_server.sh
--- ```
---
--- **By default, elixir-ls doesn't have a `cmd` set.** This is because nvim-lspconfig does not make assumptions about
--- your path. You must add the following to your init.vim or init.lua to set `cmd` to the absolute path ($HOME and
--- ~ are not expanded) of your unzipped elixir-ls.
---
--- ```lua
--- vim.lsp.config('elixirls', {
--- -- Unix
--- cmd = { "/path/to/elixir-ls/language_server.sh" };
--- -- Windows
--- cmd = { "/path/to/elixir-ls/language_server.bat" };
--- ...
--- })
--- ```
---
--- 'root_dir' is chosen like this: if two or more directories containing `mix.exs` were found when searching
--- directories upward, the second one (higher up) is chosen, with the assumption that it is the root of an umbrella
--- app. Otherwise the directory containing the single mix.exs that was found is chosen.
---@type vim.lsp.Config
return {
filetypes = { 'elixir', 'eelixir', 'heex', 'surface' },
root_dir = function(bufnr, on_dir)
local fname = vim.api.nvim_buf_get_name(bufnr)
--- Elixir workspaces may have multiple `mix.exs` files, for an "umbrella" layout or monorepo.
--- So we specify `limit=2` and treat the highest one (if any) as the root of an umbrella app.
local matches = vim.fs.find({ 'mix.exs' }, { upward = true, limit = 2, path = fname })
local child_or_root_path, maybe_umbrella_path = unpack(matches)
local root_dir = vim.fs.dirname(maybe_umbrella_path or child_or_root_path)
on_dir(root_dir)
end,
}
|