mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-13 13:48:50 +00:00
Clarify rust-analyzer binary install
This commit is contained in:
parent
ef67e0a497
commit
49d494c033
1 changed files with 23 additions and 7 deletions
|
@ -23,7 +23,7 @@ https://github.com/rust-analyzer/rust-analyzer/blob/master/docs/user/readme.adoc
|
||||||
|
|
||||||
== Installation
|
== Installation
|
||||||
|
|
||||||
In theory, one should be able to just install the server binary and have it automatically work with any editor.
|
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.
|
||||||
We are not there yet, so some editor specific setup is required.
|
We are not there yet, so some editor specific setup is required.
|
||||||
|
|
||||||
Additionally, rust-analyzer needs the sources of the standard library.
|
Additionally, rust-analyzer needs the sources of the standard library.
|
||||||
|
@ -94,7 +94,8 @@ $ git clone https://github.com/rust-analyzer/rust-analyzer.git && cd rust-analyz
|
||||||
$ cargo xtask install
|
$ cargo xtask install
|
||||||
----
|
----
|
||||||
|
|
||||||
You'll need Cargo, nodejs and npm for this.
|
You'll need Cargo, xtask, nodejs and npm for this.
|
||||||
|
Cargo-xtask can be found at https://github.com/matklad/cargo-xtask
|
||||||
|
|
||||||
Note that installing via `xtask install` does not work for VS Code Remote, instead you'll need to install the `.vsix` manually.
|
Note that installing via `xtask install` does not work for VS Code Remote, instead you'll need to install the `.vsix` manually.
|
||||||
|
|
||||||
|
@ -108,18 +109,29 @@ Here are some useful self-diagnostic commands:
|
||||||
* To log all LSP requests, add `"rust-analyzer.trace.server": "verbose"` to the settings and look for `Server Trace` in the panel.
|
* 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.
|
* To enable client-side logging, add `"rust-analyzer.trace.extension": true` to the settings and open the `Console` tab of VS Code developer tools.
|
||||||
|
|
||||||
=== Language Server Binary
|
=== rust-analyzer Language Server Binary
|
||||||
|
|
||||||
Other editors generally require the `rust-analyzer` binary to be in `$PATH`.
|
Other editors generally require the `rust-analyzer` binary to be in `$PATH`.
|
||||||
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-analzyer` and make it executable in addition to moving it into a directory in your `$PATH`.
|
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-analzyer` and make it executable in addition to moving it into a directory in your `$PATH`.
|
||||||
|
|
||||||
|
On Linux to install the `rust-analyzer` binary into `~/.cargo/bin` which usually is already added to `$PATH`, this commands could be used
|
||||||
|
|
||||||
|
[source,bash]
|
||||||
|
----
|
||||||
|
$ curl -L https://github.com/rust-analyzer/rust-analyzer/releases/latest/download/rust-analyzer-linux -o ~/.cargo/bin/rust-analyzer
|
||||||
|
$ chmod +x ~/.cargo/bin/rust-analyzer
|
||||||
|
----
|
||||||
|
|
||||||
Alternatively, you can install it from source using the following command:
|
Alternatively, you can install it from source using the following command:
|
||||||
|
|
||||||
[source,bash]
|
[source,bash]
|
||||||
----
|
----
|
||||||
|
$ git clone https://github.com/rust-analyzer/rust-analyzer.git && cd rust-analyzer
|
||||||
$ cargo xtask install --server
|
$ cargo xtask install --server
|
||||||
----
|
----
|
||||||
|
|
||||||
|
Cargo-xtask can be found at https://github.com/matklad/cargo-xtask
|
||||||
|
|
||||||
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.
|
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.
|
||||||
|
|
||||||
==== Arch Linux
|
==== Arch Linux
|
||||||
|
@ -139,15 +151,19 @@ $ yay -S rust-analyzer-bin
|
||||||
|
|
||||||
=== Emacs
|
=== Emacs
|
||||||
|
|
||||||
Emacs support is maintained https://github.com/emacs-lsp/lsp-mode/blob/master/lsp-rust.el[upstream].
|
Prerequisites: You have installed the <<rust-analyzer-language-server-binary,`rust-analyzer` binary>>.
|
||||||
|
|
||||||
1. Install the most recent version of `emacs-lsp` package by following the instructions https://github.com/emacs-lsp/lsp-mode[here].
|
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].
|
||||||
2. Set `lsp-rust-server` to `'rust-analyzer`.
|
2. Set `lsp-rust-server` to `'rust-analyzer`.
|
||||||
3. Run `lsp` in a Rust buffer.
|
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.
|
4. (Optionally) bind commands like `lsp-rust-analyzer-join-lines`, `lsp-extend-selection` and `lsp-rust-analyzer-expand-macro` to keys.
|
||||||
|
|
||||||
=== Vim
|
=== Vim
|
||||||
|
|
||||||
|
Prerequisites: You have installed the <<rust-analyzer-language-server-binary,`rust-analyzer` binary>>.
|
||||||
|
|
||||||
The are several LSP client implementations for vim:
|
The are several LSP client implementations for vim:
|
||||||
|
|
||||||
==== coc-rust-analyzer
|
==== coc-rust-analyzer
|
||||||
|
@ -205,7 +221,7 @@ Once `neovim/nvim-lsp` is installed, use `+lua require'nvim_lsp'.rust_analyzer.s
|
||||||
|
|
||||||
=== Sublime Text 3
|
=== Sublime Text 3
|
||||||
|
|
||||||
Prerequisites: You have installed the <<language-server-binary,`rust-analyzer` binary>>.
|
Prerequisites: You have installed the <<rust-analyzer-language-server-binary,`rust-analyzer` binary>>.
|
||||||
|
|
||||||
You also need the `LSP` package. To install it:
|
You also need the `LSP` package. To install it:
|
||||||
|
|
||||||
|
@ -218,7 +234,7 @@ Finally, with your Rust project open, in the command palette, run `LSP: Enable L
|
||||||
|
|
||||||
If it worked, you should see "rust-analzyer, 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.
|
If it worked, you should see "rust-analzyer, 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.
|
||||||
|
|
||||||
If you get an error saying `No such file or directory: 'rust-analyzer'`, see the <<language-server-binary,section on installing the language server binary>>.
|
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.
|
||||||
|
|
||||||
== Usage
|
== Usage
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue