diff options
Diffstat (limited to '.config/nvim/lsp/yamlls.lua')
-rw-r--r-- | .config/nvim/lsp/yamlls.lua | 80 |
1 files changed, 0 insertions, 80 deletions
diff --git a/.config/nvim/lsp/yamlls.lua b/.config/nvim/lsp/yamlls.lua deleted file mode 100644 index 04e837e..0000000 --- a/.config/nvim/lsp/yamlls.lua +++ /dev/null @@ -1,80 +0,0 @@ ----@brief ---- ---- https://github.com/redhat-developer/yaml-language-server ---- ---- `yaml-language-server` can be installed via `yarn`: ---- ```sh ---- yarn global add yaml-language-server ---- ``` ---- ---- To use a schema for validation, there are two options: ---- ---- 1. Add a modeline to the file. A modeline is a comment of the form: ---- ---- ``` ---- # yaml-language-server: $schema=<urlToTheSchema|relativeFilePath|absoluteFilePath}> ---- ``` ---- ---- where the relative filepath is the path relative to the open yaml file, and the absolute filepath ---- is the filepath relative to the filesystem root ('/' on unix systems) ---- ---- 2. Associated a schema url, relative , or absolute (to root of project, not to filesystem root) path to ---- the a glob pattern relative to the detected project root. Check `:checkhealth vim.lsp` to determine the resolved project ---- root. ---- ---- ```lua ---- vim.lsp.config('yamlls', { ---- ... ---- settings = { ---- yaml = { ---- ... -- other settings. note this overrides the lspconfig defaults. ---- schemas = { ---- ["https://json.schemastore.org/github-workflow.json"] = "/.github/workflows/*", ---- ["../path/relative/to/file.yml"] = "/.github/workflows/*", ---- ["/path/from/root/of/project"] = "/.github/workflows/*", ---- }, ---- }, ---- } ---- }) ---- ``` ---- ---- Currently, kubernetes is special-cased in yammls, see the following upstream issues: ---- * [#211](https://github.com/redhat-developer/yaml-language-server/issues/211). ---- * [#307](https://github.com/redhat-developer/yaml-language-server/issues/307). ---- ---- To override a schema to use a specific k8s schema version (for example, to use 1.18): ---- ---- ```lua ---- vim.lsp.config('yamlls', { ---- ... ---- settings = { ---- yaml = { ---- ... -- other settings. note this overrides the lspconfig defaults. ---- schemas = { ---- ["https://raw.githubusercontent.com/yannh/kubernetes-json-schema/refs/heads/master/v1.32.1-standalone-strict/all.json"] = "/*.k8s.yaml", ---- ... -- other schemas ---- }, ---- }, ---- } ---- }) ---- ``` - ----@type vim.lsp.Config -return { - cmd = { 'yaml-language-server', '--stdio' }, - filetypes = { 'yaml', 'yaml.docker-compose', 'yaml.gitlab', 'yaml.helm-values' }, - root_markers = { '.git' }, - settings = { - -- https://github.com/redhat-developer/vscode-redhat-telemetry#how-to-disable-telemetry-reporting - redhat = { telemetry = { enabled = false } }, - -- formatting disabled by default in yaml-language-server; enable it - yaml = { format = { enable = true } }, - }, - on_init = function(client) - --- https://github.com/neovim/nvim-lspconfig/pull/4016 - --- Since formatting is disabled by default if you check `client:supports_method('textDocument/formatting')` - --- during `LspAttach` it will return `false`. This hack sets the capability to `true` to facilitate - --- autocmd's which check this capability - client.server_capabilities.documentFormattingProvider = true - end, -} |