2020-02-14 11:30:52 -06:00
= User Manual
:toc: preamble
:sectanchors:
:page-layout: post
2020-05-31 08:15:03 -05:00
:icons: font
2020-05-31 04:29:19 -05:00
:source-highlighter: rouge
2020-05-30 18:54:54 -05:00
:experimental:
2020-03-08 12:01:31 -05:00
2020-02-14 11:30:52 -06:00
// Master copy of this document lives in the https://github.com/rust-analyzer/rust-analyzer repository
2020-02-21 13:53:30 -06:00
At its core, rust-analyzer is a *library* for semantic analysis of Rust code as it changes over time.
2020-04-21 02:20:14 -05:00
This manual focuses on a specific usage of the library -- running it as part of a server that implements the
https://microsoft.github.io/language-server-protocol/[Language Server Protocol] (LSP).
The LSP allows various code editors, like VS Code, Emacs or Vim, to implement semantic features like completion or goto definition by talking to an external language server process.
2020-02-14 11:30:52 -06:00
2020-02-14 12:15:32 -06:00
To improve this document, send a pull request against
2020-05-31 06:22:02 -05:00
https://github.com/rust-analyzer/rust-analyzer/blob/master/docs/user/manual.adoc[this file].
2020-02-14 12:15:32 -06:00
2020-05-28 03:19:01 -05:00
If you have questions about using rust-analyzer, please ask them in the https://users.rust-lang.org/c/ide/14["`IDEs and Editors`"] topic of Rust users forum.
2020-02-14 11:30:52 -06:00
== Installation
2020-04-26 08:44:05 -05:00
In theory, one should be able to just install the <<rust-analyzer-language-server-binary,`rust-analyzer` binary>> and have it automatically work with any editor.
2020-02-14 11:30:52 -06:00
We are not there yet, so some editor specific setup is required.
2020-04-21 02:20:14 -05:00
Additionally, rust-analyzer needs the sources of the standard library.
2020-02-17 15:48:47 -06:00
If the source code is not present, rust-analyzer will attempt to install it automatically.
2020-02-17 15:33:48 -06:00
To add the sources manually, run the following command:
2020-02-17 03:55:08 -06:00
```bash
$ rustup component add rust-src
```
2020-02-14 11:30:52 -06:00
=== VS Code
2020-03-08 11:51:21 -05:00
This is the best supported editor at the moment.
2020-04-21 02:20:14 -05:00
The rust-analyzer plugin for VS Code is maintained
2020-02-14 11:30:52 -06:00
https://github.com/rust-analyzer/rust-analyzer/tree/master/editors/code[in tree].
You can install the latest release of the plugin from
https://marketplace.visualstudio.com/items?itemName=matklad.rust-analyzer[the marketplace].
2020-02-21 13:53:30 -06:00
By default, the plugin will prompt you to download the matching version of the server as well:
2020-02-14 11:30:52 -06:00
2020-02-21 13:55:15 -06:00
image::https://user-images.githubusercontent.com/9021944/75067008-17502500-54ba-11ea-835a-f92aac50e866.png[]
2020-02-14 11:30:52 -06:00
2020-03-08 12:01:31 -05:00
[NOTE]
====
To disable this notification put the following to `settings.json`
[source,json]
----
2020-03-09 03:59:36 -05:00
{ "rust-analyzer.updates.askBeforeDownload": false }
2020-03-08 12:01:31 -05:00
----
====
2020-03-08 11:51:21 -05:00
2020-05-04 12:16:29 -05:00
The server binary is stored in:
* Linux: `~/.config/Code/User/globalStorage/matklad.rust-analyzer`
* macOS: `~/Library/Application Support/Code/User/globalStorage/matklad.rust-analyzer`
2020-05-06 11:53:14 -05:00
* Windows: `%APPDATA%\Code\User\globalStorage\matklad.rust-analyzer`
2020-02-14 11:30:52 -06:00
2020-05-17 08:57:30 -05:00
Note that we only support two most recent versions of VS Code.
2020-02-14 11:30:52 -06:00
==== Updates
2020-02-15 19:56:54 -06:00
The extension will be updated automatically as new versions become available. It will ask your permission to download the matching language server version binary if needed.
2020-02-14 11:30:52 -06:00
2020-03-13 20:16:50 -05:00
===== Nightly
We ship nightly releases for VS Code. To help us out with testing the newest code and follow the bleeding edge of our `master`, please use the following config:
[source,json]
----
{ "rust-analyzer.updates.channel": "nightly" }
----
2020-04-21 02:20:14 -05:00
You will be prompted to install the `nightly` extension version. Just click `Download now` and from that moment you will get automatic updates every 24 hours.
2020-03-13 20:16:50 -05:00
If you don't want to be asked for `Download now` every day when the new nightly version is released add the following to your `settings.json`:
[source,json]
----
{ "rust-analyzer.updates.askBeforeDownload": false }
----
NOTE: Nightly extension should **only** be installed via the `Download now` action from VS Code.
2020-02-14 11:30:52 -06:00
==== Building From Source
Alternatively, both the server and the plugin can be installed from source:
[source]
----
2020-02-14 14:02:08 -06:00
$ git clone https://github.com/rust-analyzer/rust-analyzer.git && cd rust-analyzer
2020-02-14 11:30:52 -06:00
$ cargo xtask install
----
2020-04-26 10:08:15 -05:00
You'll need Cargo, nodejs and npm for this.
2020-02-14 11:30:52 -06:00
Note that installing via `xtask install` does not work for VS Code Remote, instead you'll need to install the `.vsix` manually.
2020-03-24 04:31:52 -05:00
==== Troubleshooting
Here are some useful self-diagnostic commands:
* **Rust Analyzer: Show RA Version** shows the version of `rust-analyzer` binary
* **Rust Analyzer: Status** prints some statistics about the server, like the few latest LSP requests
2020-05-11 12:14:12 -05:00
* To enable server-side logging, run with `env RA_LOG=info` and see `Output > Rust Analyzer Language Server` in VS Code's panel.
2020-03-24 04:31:52 -05:00
* To log all LSP requests, add `"rust-analyzer.trace.server": "verbose"` to the settings and look for `Server Trace` in the panel.
* To enable client-side logging, add `"rust-analyzer.trace.extension": true` to the settings and open the `Console` tab of VS Code developer tools.
2020-05-31 08:15:03 -05:00
==== Special `when` clause context for keybindings.
You may use `inRustProject` context to configure keybindings for rust projects only. For example:
[source,json]
----
{
"key": "ctrl+i",
"command": "rust-analyzer.toggleInlayHints",
"when": "inRustProject"
}
----
More about `when` clause contexts https://code.visualstudio.com/docs/getstarted/keybindings#_when-clause-contexts[here].
2020-04-26 08:44:05 -05:00
=== rust-analyzer Language Server Binary
2020-02-14 11:30:52 -06:00
2020-04-21 02:20:14 -05:00
Other editors generally require the `rust-analyzer` binary to be in `$PATH`.
2020-05-31 08:15:03 -05:00
You can download the pre-built binary from the https://github.com/rust-analyzer/rust-analyzer/releases[releases] page.
Typically, you then need to rename the binary for your platform, e.g. `rust-analyzer-mac` if you're on Mac OS, to `rust-analyzer` and make it executable in addition to moving it into a directory in your `$PATH`.
2020-04-21 02:20:14 -05:00
2020-04-26 10:11:44 -05:00
On Linux to install the `rust-analyzer` binary into `~/.local/bin`, this commands could be used
2020-04-26 08:44:05 -05:00
[source,bash]
----
2020-04-26 10:11:44 -05:00
$ curl -L https://github.com/rust-analyzer/rust-analyzer/releases/latest/download/rust-analyzer-linux -o ~/.local/bin/rust-analyzer
$ chmod +x ~/.local/bin/rust-analyzer
2020-04-26 08:44:05 -05:00
----
2020-04-26 12:40:13 -05:00
Ensure `~/.local/bin` is listed in the `$PATH` variable.
2020-04-26 10:11:44 -05:00
2020-04-21 02:20:14 -05:00
Alternatively, you can install it from source using the following command:
2020-02-14 11:30:52 -06:00
[source,bash]
----
2020-04-26 08:44:05 -05:00
$ git clone https://github.com/rust-analyzer/rust-analyzer.git && cd rust-analyzer
2020-02-14 11:30:52 -06:00
$ cargo xtask install --server
----
2020-05-31 08:15:03 -05:00
If your editor can't find the binary even though the binary is on your `$PATH`, the likely explanation is that it doesn't see the same `$PATH` as the shell, see https://github.com/rust-analyzer/rust-analyzer/issues/1811[this issue].
On Unix, running the editor from a shell or changing the `.desktop` file to set the environment should help.
2020-04-21 04:17:12 -05:00
2020-03-16 10:54:03 -05:00
==== Arch Linux
2020-05-05 17:23:32 -05:00
The `rust-analyzer` binary can be installed from the repos or AUR (Arch User Repository):
2020-03-16 10:54:03 -05:00
2020-05-05 17:23:32 -05:00
- https://www.archlinux.org/packages/community/x86_64/rust-analyzer/[`rust-analyzer`] (built from latest tagged source)
- https://aur.archlinux.org/packages/rust-analyzer-git[`rust-analyzer-git`] (latest Git version)
2020-03-16 10:54:03 -05:00
2020-05-05 17:23:32 -05:00
Install it with pacman, for example:
2020-03-16 10:54:03 -05:00
[source,bash]
----
2020-05-05 17:23:32 -05:00
$ pacman -S rust-analyzer
2020-03-16 10:54:03 -05:00
----
2020-02-14 11:30:52 -06:00
=== Emacs
2020-04-26 08:44:05 -05:00
Prerequisites: You have installed the <<rust-analyzer-language-server-binary,`rust-analyzer` binary>>.
2020-02-14 11:30:52 -06:00
2020-04-26 08:44:05 -05:00
Emacs support is maintained as part of the https://github.com/emacs-lsp/lsp-mode[Emacs-LSP] package in https://github.com/emacs-lsp/lsp-mode/blob/master/lsp-rust.el[lsp-rust.el].
1. Install the most recent version of `emacs-lsp` package by following the https://github.com/emacs-lsp/lsp-mode[Emacs-LSP instructions].
2020-02-14 11:30:52 -06:00
2. Set `lsp-rust-server` to `'rust-analyzer`.
3. Run `lsp` in a Rust buffer.
4. (Optionally) bind commands like `lsp-rust-analyzer-join-lines`, `lsp-extend-selection` and `lsp-rust-analyzer-expand-macro` to keys.
2020-05-04 12:12:32 -05:00
=== Vim/NeoVim
2020-02-14 11:30:52 -06:00
2020-05-04 12:12:32 -05:00
Prerequisites: You have installed the <<rust-analyzer-language-server-binary,`rust-analyzer` binary>>. Not needed if the extension can install/update it on its own, coc-rust-analyzer is one example.
2020-04-26 08:44:05 -05:00
2020-05-04 12:12:32 -05:00
The are several LSP client implementations for vim or neovim:
2020-02-14 11:30:52 -06:00
==== coc-rust-analyzer
1. Install coc.nvim by following the instructions at
https://github.com/neoclide/coc.nvim[coc.nvim]
2020-04-29 22:38:20 -05:00
(Node.js required)
2020-02-14 11:30:52 -06:00
2. Run `:CocInstall coc-rust-analyzer` to install
https://github.com/fannheyward/coc-rust-analyzer[coc-rust-analyzer],
this extension implements _most_ of the features supported in the VSCode extension:
2020-04-29 22:38:20 -05:00
* automatically install and upgrade stable/nightly releases
2020-04-21 04:54:13 -05:00
* same configurations as VSCode extension, `rust-analyzer.serverPath`, `rust-analyzer.cargo.features` etc.
* same commands too, `rust-analyzer.analyzerStatus`, `rust-analyzer.ssr` etc.
2020-04-29 22:38:20 -05:00
* inlay hints for method chaining support, _Neovim Only_
* semantic highlighting is not implemented yet
2020-02-14 11:30:52 -06:00
==== LanguageClient-neovim
1. Install LanguageClient-neovim by following the instructions
https://github.com/autozimu/LanguageClient-neovim[here]
2020-05-05 17:23:32 -05:00
* The GitHub project wiki has extra tips on configuration
2020-02-14 11:30:52 -06:00
2020-02-21 13:53:30 -06:00
2. Configure by adding this to your vim/neovim config file (replacing the existing Rust-specific line if it exists):
2020-02-14 11:30:52 -06:00
+
[source,vim]
----
let g:LanguageClient_serverCommands = {
2020-02-18 05:33:16 -06:00
\ 'rust': ['rust-analyzer'],
2020-02-14 11:30:52 -06:00
\ }
----
2020-04-23 04:09:37 -05:00
==== YouCompleteMe
1. Install YouCompleteMe by following the instructions
2020-04-29 05:50:54 -05:00
https://github.com/ycm-core/lsp-examples#rust-rust-analyzer[here]
2020-04-23 04:09:37 -05:00
2. Configure by adding this to your vim/neovim config file (replacing the existing Rust-specific line if it exists):
+
2020-05-01 03:20:58 -05:00
[source,vim]
2020-04-23 04:09:37 -05:00
----
let g:ycm_language_server =
\ [
\ {
\ 'name': 'rust',
\ 'cmdline': ['rust-analyzer'],
\ 'filetypes': ['rust'],
\ 'project_root_files': ['Cargo.toml']
\ }
\ ]
----
2020-04-28 20:01:10 -05:00
==== ALE
2020-05-05 17:23:32 -05:00
To use the LSP server in https://github.com/dense-analysis/ale[ale]:
2020-04-28 20:01:10 -05:00
[source,vim]
----
2020-05-05 17:23:32 -05:00
let g:ale_linters = {'rust': ['analyzer']}
2020-04-28 20:01:10 -05:00
----
2020-02-14 11:30:52 -06:00
==== nvim-lsp
2020-02-21 13:53:30 -06:00
NeoVim 0.5 (not yet released) has built-in language server support.
2020-02-14 11:30:52 -06:00
For a quick start configuration of rust-analyzer, use https://github.com/neovim/nvim-lsp#rust_analyzer[neovim/nvim-lsp].
2020-03-09 06:31:23 -05:00
Once `neovim/nvim-lsp` is installed, use `+lua require'nvim_lsp'.rust_analyzer.setup({})+` in your `init.vim`.
2020-02-14 11:30:52 -06:00
=== Sublime Text 3
2020-04-26 08:44:05 -05:00
Prerequisites: You have installed the <<rust-analyzer-language-server-binary,`rust-analyzer` binary>>.
2020-04-21 02:20:14 -05:00
You also need the `LSP` package. To install it:
1. If you've never installed a Sublime Text package, install Package Control:
* Open the command palette (Win/Linux: `ctrl+shift+p`, Mac: `cmd+shift+p`)
* Type `Install Package Control`, press enter
2. In the command palette, run `Package control: Install package`, and in the list that pops up, type `LSP` and press enter.
2020-04-30 13:29:21 -05:00
Finally, with your Rust project open, in the command palette, run `LSP: Enable Language Server In Project` or `LSP: Enable Language Server Globally`, then select `rust-analyzer` in the list that pops up to enable the rust-analyzer LSP. The latter means that rust-analyzer is enabled by default in Rust projects.
2020-02-14 11:30:52 -06:00
2020-04-30 13:29:21 -05:00
If it worked, you should see "rust-analyzer, Line X, Column Y" on the left side of the bottom bar, and after waiting a bit, functionality like tooltips on hovering over variables should become available.
2020-02-14 11:30:52 -06:00
2020-04-26 08:44:05 -05:00
If you get an error saying `No such file or directory: 'rust-analyzer'`, see the <<rust-analyzer-language-server-binary,`rust-analyzer` binary>> section on installing the language server binary.
2020-02-14 11:30:52 -06:00
2020-05-20 13:11:14 -05:00
=== GNOME Builder
2020-05-01 03:20:58 -05:00
Prerequisites: You have installed the <<rust-analyzer-language-server-binary,`rust-analyzer` binary>>.
Gnome Builder currently has support for RLS, and there's no way to configure the language server executable. A future version might support `rust-analyzer` out of the box.
1. Rename, symlink or copy the `rust-analyzer` binary to `rls` and place it somewhere Builder can find (in `PATH`, or under `~/.cargo/bin`).
2. Enable the Rust Builder plugin.
2020-05-30 18:54:54 -05:00
== Features
2020-02-14 11:30:52 -06:00
2020-05-30 18:54:54 -05:00
include::./generated_features.adoc[]
2020-05-31 03:14:36 -05:00
== Assists (Code Actions)
Assists, or code actions, are small local refactorings, available in a particular context.
They are usually triggered by a shortcut or by clicking a light bulb icon in the editor.
2020-05-31 08:02:12 -05:00
Cursor position or selection is signified by `┃` character.
2020-05-31 03:14:36 -05:00
2020-05-31 08:02:12 -05:00
include::./generated_assists.adoc[]