From af735977fd6b31d994b6946c28c70235882564bb Mon Sep 17 00:00:00 2001 From: qvalentin <36446499+qvalentin@users.noreply.github.com> Date: Sun, 27 Oct 2024 20:11:47 +0100 Subject: [PATCH] docs: add features overview and zed to README (#113) * chore: add features to README * chore: demos of features in readme * docs: cleanup * docs: add zed extension * docs: add demo to heading --- README.md | 77 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 77 insertions(+) diff --git a/README.md b/README.md index 19be4f3..7807b66 100644 --- a/README.md +++ b/README.md @@ -39,7 +39,9 @@ Helm-ls is a [helm](https://github.com/helm/helm) language server protocol [LSP] - [nvim-lspconfig setup](#nvim-lspconfig-setup) - [coc.nvim setup](#cocnvim-setup) - [VSCode](#vscode) + - [Zed](#zed) - [Emacs eglot setup](#emacs-eglot-setup) +- [Features and Demos](#features-and-demos) - [Contributing](#contributing) - [License](#license) @@ -270,6 +272,10 @@ Save the configuration file and then either restart Neovim or type `:CocRestart` Check out the [helm-ls-vscode extension](https://github.com/qvalentin/helm-ls-vscode) for more details. +### Zed + +Setup filetypes as described in the [Zed Docs](https://zed.dev/docs/languages/helm) and install the [helm.zed extension](https://github.com/cabrinha/helm.zed). + ### Emacs eglot setup Integrating helm-ls with [eglot](https://github.com/joaotavora/eglot) for emacs consists of two steps: wiring up Helm template files into a specific major mode and then associating that major mode with `helm_ls` via the `eglot-server-programs` variable. @@ -304,6 +310,77 @@ Alternatively, you can include a comment such as the following at the top of Hel # -*- mode: helm -*- +## Features and Demos + +
+ + Hover + + + + +| Language Construct | Example Effect | +| ------------------ | ---------------------------------------------------------------------------------- | +| Values | `.Values.replicaCount` shows the value of `replicaCount` in the values.yaml files. | +| Built-In-Objects | `.Chart.Name` shows the name of the Chart. | +| Includes | `include "example.labels"` shows the defintion of the template. | +| Functions | `add` shows the docs of the add function. | +| Yaml in Templates | `Kind` shows the docs from the yaml-schema (via yaml-language-server). | + +
+ +
+ + Autocomplete + + + + +| Language Construct | Effect | +| ------------------ | -------------------------------------------------------------------- | +| Values | Values from `values*.yaml` files (including child/parent Charts). | +| Built-In-Objects | Values from `Chart`, `Release`, `Files`, `Capabilities`, `Template`. | +| Includes | Available includes (including child/parent Charts). | +| Functions | Functions from gotemplate and helm. | +| Yaml in Templates | Values from the yaml-schema (via yaml-language-server). | + +
+ +
+ + Go-To-Definition/References + + + + +| Language Construct | Effect | +| ------------------ | ----------------------------------------------------------------------------------- | +| Values | Go to `values*.yaml` files for template references (including child/parent Charts). | +| Built-In-Objects | Go to `Chart.yaml` for `Chart.*`. | +| Includes | Go to defintion/references of template (including child/parent Charts). | + +
+ +
+ + Symbol + + +Can show a breadcrumb of the yaml path of the current position (via yaml-language-server). +![Demo for Symbol](https://github.com/user-attachments/assets/0b8a9fc4-4625-4641-a296-8aedb48496e9) + +
+ +
+ + Linting + + +Diagnostics from both helm lint and yaml-language-server. +![Demo of Linting](https://github.com/user-attachments/assets/58e90dd4-2fe5-40f5-a9a7-adec6c890a0c) + +
+ ## Contributing Thank you for considering contributing to Helm-ls project!