40 lines
1.8 KiB
Lua
40 lines
1.8 KiB
Lua
---@brief
|
|
---
|
|
--- https://github.com/hashicorp/terraform-ls
|
|
---
|
|
--- Terraform language server
|
|
--- Download a released binary from https://github.com/hashicorp/terraform-ls/releases.
|
|
---
|
|
--- From https://github.com/hashicorp/terraform-ls#terraform-ls-vs-terraform-lsp:
|
|
---
|
|
--- Both HashiCorp and the maintainer of terraform-lsp expressed interest in
|
|
--- collaborating on a language server and are working towards a _long-term_
|
|
--- goal of a single stable and feature-complete implementation.
|
|
---
|
|
--- For the time being both projects continue to exist, giving users the
|
|
--- choice:
|
|
---
|
|
--- - `terraform-ls` providing
|
|
--- - overall stability (by relying only on public APIs)
|
|
--- - compatibility with any provider and any Terraform >=0.12.0 currently
|
|
--- less features
|
|
--- - due to project being younger and relying on public APIs which may
|
|
--- not offer the same functionality yet
|
|
---
|
|
--- - `terraform-lsp` providing
|
|
--- - currently more features
|
|
--- - compatibility with a single particular Terraform (0.12.20 at time of writing)
|
|
--- - configs designed for other 0.12 versions may work, but interpretation may be inaccurate
|
|
--- - less stability (due to reliance on Terraform's own internal packages)
|
|
---
|
|
--- Note, that the `settings` configuration option uses the `workspace/didChangeConfiguration` event,
|
|
--- [which is not supported by terraform-ls](https://github.com/hashicorp/terraform-ls/blob/main/docs/features.md).
|
|
--- Instead you should use `init_options` which passes the settings as part of the LSP initialize call
|
|
--- [as is required by terraform-ls](https://github.com/hashicorp/terraform-ls/blob/main/docs/SETTINGS.md#how-to-pass-settings).
|
|
|
|
---@type vim.lsp.Config
|
|
return {
|
|
cmd = { 'terraform-ls', 'serve' },
|
|
filetypes = { 'terraform', 'terraform-vars' },
|
|
root_markers = { '.terraform', '.git' },
|
|
}
|