![Zig Language Server](https://raw.githubusercontent.com/zigtools/zls/master/.assets/zls.svg) ![CI](https://github.com/zigtools/zls/workflows/CI/badge.svg) ![Zig Tools](https://img.shields.io/static/v1?label=zigtools&message=for%20all%20of%20ziguanity&color=F7A41D&logo=) Zig Language Server, or `zls`, is a language server for Zig. The Zig wiki states that "The Zig community is decentralized" and "There is no concept of 'official' or 'unofficial'", so instead of calling `zls` unofficial, and I'm going to call it a cool option, one of [many](https://github.com/search?q=zig+language+server). ## Table Of Contents - [Installation](#installation) - [Build Options](#build-options) - [Configuration Options](#configuration-options) - [Usage](#usage) - [VSCode](#vscode) - [Sublime Text 3](#sublime-text-3) - [Kate](#kate) - [Neovim/Vim8](#neovimvim8) - [Emacs](#emacs) - [Related Projects](#related-projects) - [License](#license) ## Installation Installing `zls` is pretty simple. You will need [a build of Zig master](https://ziglang.org/download/) to build zls. ```bash git clone --recurse-submodules https://github.com/zigtools/zls cd zls zig build # To configure zls: zig build config ``` The `zls` executable will be saved to `zls\zig-cache\bin`. ### Build Options | Option | Type | Default Value | What it Does | | --- | --- | --- | --- | | `-Ddata_version` | `string` (master or 0.6.0) | master | The data file version. This selects the files in the `src/data` folder that correspond to the Zig version being served.| Then, you can use the `zls` executable in an editor of your choice that has a Zig language server client! ### Configuration Options You can configure zls by providing a zls.json file. zls will look for a zls.json configuration file in multiple locations with the following priority: - In the folders open in your workspace (this applies for files in those folders) - In the local configuration folder of your OS (as provided by [known-folders](https://github.com/ziglibs/known-folders#folder-list)) - In the same directory as the executable The following options are currently available. | Option | Type | Default value | What it Does | | --- | --- | --- | --- | | `enable_snippets` | `bool` | `false` | Enables snippet completions when the client also supports them. | | `zig_lib_path` | `?[]const u8` | `null` | zig library path, e.g. `/path/to/zig/lib/zig`, used to analyze std library imports. | | `zig_exe_path` | `?[]const u8` | `null` | zig executable path, e.g. `/path/to/zig/zig`, used to run the custom build runner. If `null`, zig is looked up in `PATH`. Will be used to infer the zig standard library path if none is provided. | | `warn_style` | `bool` | `false` | Enables warnings for style *guideline* mismatches | | `build_runner_path` | `?[]const u8` | `null` | Path to the build_runner.zig file provided by zls. This option must be present in one of the global configuration files to have any effect. `null` is equivalent to `${executable_directory}/build_runner.zig` | | `enable_semantic_tokens` | `bool` | `false` | Enables semantic token support when the client also supports it. | | `operator_completions` | `bool` | `true` | Enables `*` and `?` operators in completion lists. | ## Features `zls` supports most language features, including simple type function support, usingnamespace, payload capture type resolution, custom packages and others. Notable language features that are not currently implemented include `@cImport` as well as most forms of compile time evaluation. The following LSP features are supported: - Completions - Hover - Goto definition/declaration - Document symbols - Find references - Rename symbol - Formatting using `zig fmt` - Semantic token highlighting (LSP 3.16 proposed feature, implemented by a few clients including VSCode, kak and emacs lsp-mode) You can install `zls` using the instuctions for your text editor below: ### VSCode Install the `zls-vscode` extension from [here](https://github.com/zigtools/zls-vscode/releases) and provide a path to the build `zls` executable. ### Sublime Text 3 - Install the `LSP` package from [here](https://github.com/sublimelsp/LSP/releases) or via Package Control. - Add this snippet to `LSP's` user settings: ```json { "clients": { "zig":{ "command": ["zls"], "enabled": true, "languageId": "zig", "scopes": ["source.zig"], "syntaxes": ["Packages/Zig Language/Syntaxes/Zig.tmLanguage"] } } } ``` ### Kate - Enable `LSP client` plugin in Kate settings. - Add this snippet to `LSP client's` user settings (e.g. /$HOME/.config/kate/lspclient) (or paste it in `LSP client's` GUI settings) ```json { "servers": { "zig": { "command": ["zls"], "url": "https://github.com/zigtools/zls", "highlightingModeRegex": "^Zig$" } } } ``` ### Neovim/Vim8 - Install the CoC engine from [here](https://github.com/neoclide/coc.nvim). - Issue `:CocConfig` from within your Vim editor, and the following snippet: ```json { "languageserver": { "zls" : { "command": "command_or_path_to_zls", "filetypes": ["zig"] } } } ``` ### Emacs - Install [lsp-mode](https://github.com/emacs-lsp/lsp-mode) from melpa - [zig mode](https://github.com/ziglang/zig-mode) is also useful ```elisp (require 'lsp) (add-to-list 'lsp-language-id-configuration '(zig-mode . "zig")) (lsp-register-client (make-lsp-client :new-connection (lsp-stdio-connection "") :major-modes '(zig-mode) :server-id 'zls)) ``` ## Related Projects - [`sublime-zig-language` by @prime31](https://github.com/prime31/sublime-zig-language) - Supports basic language features - Uses data provided by `src/data` to perform builtin autocompletion - [`zig-lsp` by @xackus](https://github.com/xackus/zig-lsp) - Inspiration for `zls` - [`known-folders` by @ziglibs](https://github.com/ziglibs/known-folders) - Provides API to access known folders on Linux, Windows and Mac OS ## License MIT