diff options
author | Gregory Anders <greg@gpanders.com> | 2024-12-27 10:09:22 -0600 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-12-27 10:09:22 -0600 |
commit | 35247b00a44e838ed7d657a9b94964dc0664d28d (patch) | |
tree | d0c2911358fc4d0c8a905feb888465106fe7ce23 /runtime/lua/vim/lsp.lua | |
parent | 6d2c67350ad89abf09c5ddaaf02bcccfc5fc466c (diff) | |
download | rneovim-35247b00a44e838ed7d657a9b94964dc0664d28d.tar.gz rneovim-35247b00a44e838ed7d657a9b94964dc0664d28d.tar.bz2 rneovim-35247b00a44e838ed7d657a9b94964dc0664d28d.zip |
feat(lsp): support function for client root_dir (#31630)
If root_dir is a function it is evaluated when the client is created to
determine the root directory.
This enables dynamically determining the root directory based on e.g.
project or directory structure (example: finding a parent Cargo.toml
file that contains "[workspace]" in a Rust project).
Diffstat (limited to 'runtime/lua/vim/lsp.lua')
-rw-r--r-- | runtime/lua/vim/lsp.lua | 27 |
1 files changed, 22 insertions, 5 deletions
diff --git a/runtime/lua/vim/lsp.lua b/runtime/lua/vim/lsp.lua index 19d0377585..1c8356d64d 100644 --- a/runtime/lua/vim/lsp.lua +++ b/runtime/lua/vim/lsp.lua @@ -334,6 +334,11 @@ end --- rootUri, and rootPath on initialization. Unused if `root_dir` is provided. --- @field root_markers? string[] --- +--- Directory where the LSP server will base its workspaceFolders, rootUri, and rootPath on +--- initialization. If a function, it accepts a single callback argument which must be called with +--- the value of root_dir to use. The LSP server will not be started until the callback is called. +--- @field root_dir? string|fun(cb:fun(string)) +--- --- Predicate used to decide if a client should be re-used. Used on all --- running clients. The default implementation re-uses a client if name and --- root_dir matches. @@ -499,6 +504,15 @@ local function lsp_enable_callback(bufnr) return true end + --- @param config vim.lsp.Config + local function start(config) + return vim.lsp.start(config, { + bufnr = bufnr, + reuse_client = config.reuse_client, + _root_markers = config.root_markers, + }) + end + for name in vim.spairs(lsp._enabled_configs) do local config = lsp._resolve_config(name) @@ -507,11 +521,14 @@ local function lsp_enable_callback(bufnr) -- do not propagate back to the enabled configs. config = vim.deepcopy(config) - vim.lsp.start(config, { - bufnr = bufnr, - reuse_client = config.reuse_client, - _root_markers = config.root_markers, - }) + if type(config.root_dir) == 'function' then + config.root_dir(function(root_dir) + config.root_dir = root_dir + start(config) + end) + else + start(config) + end end end end |