Find a file
bors[bot] 7c1fb6caa5
Merge #3137
3137: Do not register all proposed features r=matklad a=kjeremy

Instead only opt-in to CallHierarchy since it has a vscode API but LSP support
is still proposed.

Discovered while working on SemanticTokens which does not have a vscode API
and is still in the proposed state. Somehow enabling it would crash the
language server.

See https://github.com/microsoft/vscode-languageserver-node/issues/572

Co-authored-by: kjeremy <kjeremy@gmail.com>
2020-02-14 16:50:06 +00:00
.cargo Alternative quite tests alias 2019-11-20 22:22:32 +03:00
.github Third time's a charm? 2020-02-11 11:44:29 +01:00
.vscode Add rollup 2019-12-30 11:20:45 +01:00
crates Move hir_fmt code to display module 2020-02-14 15:01:42 +01:00
docs Move build prerequisites into build section 2020-02-10 06:55:10 +01:00
editors/code Merge #3137 2020-02-14 16:50:06 +00:00
xtask Cleanup 2020-02-14 17:11:19 +01:00
.gitattributes
.gitignore
bors.toml Gate CI on windows build 2020-01-26 14:15:57 +01:00
Cargo.lock Add error context to failures in ra_project_model using anyhow crate (#3119) 2020-02-13 11:10:50 +01:00
Cargo.toml Disable optimizations for some build-time crates 2020-01-31 21:49:44 +02:00
LICENSE-APACHE
LICENSE-MIT
README.md Some README fixes/cleanups 2020-02-09 13:35:54 +01:00
rustfmt.toml

rust-analyzer logo

rust-analyzer is an experimental modular compiler frontend for the Rust language. It is a part of a larger rls-2.0 effort to create excellent IDE support for Rust. If you want to get involved, check the rls-2.0 working group:

https://rust-lang.zulipchat.com/#narrow/stream/185405-t-compiler.2Fwg-rls-2.2E0

Work on rust-analyzer is sponsored by

Ferrous Systems

Language Server Quick Start

rust-analyzer is a work-in-progress, so you might encounter critical bugs. That said, it is complete enough to provide a useful IDE experience and some people use it as a daily driver.

To build rust-analyzer, you need:

  • latest stable Rust for the language server itself
  • latest stable npm and VS Code for VS Code extension

To quickly install the rust-analyzer language server and VS Code extension with standard setup (code and cargo in $PATH, etc), use this:

# clone the repo
$ git clone https://github.com/rust-analyzer/rust-analyzer && cd rust-analyzer

# install both the language server and VS Code extension
$ cargo xtask install

# alternatively, install only the server. Binary name is `ra_lsp_server`.
$ cargo xtask install --server

For non-standard setup of VS Code and other editors, or if the language server cannot start, see ./docs/user.

Documentation

If you want to contribute to rust-analyzer or are just curious about how things work under the hood, check the ./docs/dev folder.

If you want to use rust-analyzer's language server with your editor of choice, check ./docs/user folder. It also contains some tips & tricks to help you be more productive when using rust-analyzer.

Getting in touch

We are on the rust-lang Zulip!

https://rust-lang.zulipchat.com/#narrow/stream/185405-t-compiler.2Frls-2.2E0

License

Rust analyzer is primarily distributed under the terms of both the MIT license and the Apache License (Version 2.0).

See LICENSE-APACHE and LICENSE-MIT for details.