2020-05-15 17:44:49 +01:00

2020-04-24 23:19:03 +01:00
2020-05-14 15:07:14 +01:00


2020-05-07 18:54:58 +01:00
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 ).
2020-04-24 23:19:03 +01:00
2020-05-15 05:01:54 +01:00
<!-- omit in toc -->
## Table Of Contents
2020-05-15 05:00:44 +01:00
- [Installation ](#installation )
- [Build Options ](#build-options )
- [Configuration Options ](#configuration-options )
- [Usage ](#usage )
- [VSCode ](#vscode )
2020-05-24 16:56:51 +01:00
- [Sublime Text 3 ](#sublime-text-3 )
2020-05-27 08:48:22 +01:00
- [Kate ](#kate )
2020-05-28 18:16:37 +01:00
- [Neovim/Vim8 ](#neovimvim8 )
2020-06-08 09:21:30 +01:00
- [Emacs ](#emacs )
2020-05-15 05:00:44 +01:00
- [Related Projects ](#related-projects )
- [License ](#license )
2020-04-24 23:19:03 +01:00
## Installation
2020-07-07 21:26:12 +01:00
Installing `zls` is pretty simple. You will need [a build of Zig master ](https://ziglang.org/download/ ) to build zls.
2020-05-07 18:54:58 +01:00
2020-04-24 23:19:03 +01:00
```bash
2020-05-20 01:44:37 +01:00
git clone --recurse-submodules https://github.com/zigtools/zls
2020-04-24 23:19:03 +01:00
cd zls
zig build
2020-05-25 22:12:08 +01:00
2020-07-07 21:26:12 +01:00
# To configure zls:
2020-05-25 22:12:08 +01:00
zig build config
2020-04-24 23:19:03 +01:00
```
2020-10-02 21:07:26 +01:00
The `zls` executable will be saved to `zls\zig-cache\bin` .
2020-04-24 23:19:03 +01:00
2020-05-07 18:54:58 +01:00
### Build Options
2020-05-18 17:56:43 +01:00
| Option | Type | Default Value | What it Does |
| --- | --- | --- | --- |
2020-11-04 22:39:24 +00:00
| `-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.|
2020-05-07 18:54:58 +01:00
2020-04-24 23:19:03 +01:00
Then, you can use the `zls` executable in an editor of your choice that has a Zig language server client!
2020-05-15 05:00:44 +01:00
### Configuration Options
2020-05-09 19:45:13 +01:00
2020-05-19 20:22:02 +01:00
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
2020-05-09 19:45:13 +01:00
The following options are currently available.
| Option | Type | Default value | What it Does |
| --- | --- | --- | --- |
2020-06-16 12:27:00 +01:00
| `enable_snippets` | `bool` | `false` | Enables snippet completions when the client also supports them. |
2020-05-21 12:36:14 +01:00
| `zig_lib_path` | `?[]const u8` | `null` | zig library path, e.g. `/path/to/zig/lib/zig` , used to analyze std library imports. |
2020-05-30 21:39:57 +01:00
| `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. |
2020-05-15 20:10:53 +01:00
| `warn_style` | `bool` | `false` | Enables warnings for style *guideline* mismatches |
2020-05-25 18:04:23 +01:00
| `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` |
2020-07-07 21:26:12 +01:00
| `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. |
2020-05-09 19:45:13 +01:00
2020-07-07 21:26:12 +01:00
## Features
2020-04-24 23:19:03 +01:00
2020-07-07 21:26:12 +01:00
`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:
2020-04-24 23:19:03 +01:00
### VSCode
2020-07-07 21:26:12 +01:00
Install the `zls-vscode` extension from [here ](https://github.com/zigtools/zls-vscode/releases ) and provide a path to the build `zls` executable.
2020-05-07 18:54:58 +01:00
2020-05-24 16:45:09 +01:00
### 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:
2020-06-08 23:18:12 +01:00
2020-05-24 16:45:09 +01:00
```json
{
"clients": {
"zig":{
"command": ["zls"],
"enabled": true,
"languageId": "zig",
2020-05-26 11:06:13 +01:00
"scopes": ["source.zig"],
2020-06-07 05:06:56 +01:00
"syntaxes": ["Packages/Zig Language/Syntaxes/Zig.tmLanguage"]
2020-05-24 16:45:09 +01:00
}
}
}
```
2020-05-27 08:48:22 +01:00
### 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)
2020-06-08 23:18:12 +01:00
2020-05-27 08:48:22 +01:00
```json
{
"servers": {
"zig": {
"command": ["zls"],
"url": "https://github.com/zigtools/zls",
"highlightingModeRegex": "^Zig$"
}
}
}
```
2020-05-28 18:14:59 +01:00
### 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:
2020-06-08 23:18:12 +01:00
2020-05-28 18:14:59 +01:00
```json
{
2020-06-08 12:18:46 +01:00
"languageserver": {
2020-05-28 18:14:59 +01:00
"zls" : {
"command": "command_or_path_to_zls",
"filetypes": ["zig"]
}
}
}
```
2020-06-08 09:21:30 +01:00
### 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 "< path to zls > ")
:major-modes '(zig-mode)
:server-id 'zls))
```
2020-05-07 18:54:58 +01:00
## 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
2020-05-15 05:00:44 +01:00
- [`zig-lsp` by @xackus ](https://github.com/xackus/zig-lsp )
- Inspiration for `zls`
2020-05-19 20:22:02 +01:00
- [`known-folders` by @ziglibs ](https://github.com/ziglibs/known-folders )
2020-06-05 17:29:34 +01:00
- Provides API to access known folders on Linux, Windows and Mac OS
2020-05-07 18:54:58 +01:00
## License
MIT