JuliaEditorSupport/julia-emacs@2aca8cf585 -> JuliaEditorSupport/julia-emacs@0f4d74f904 ProofGeneral/PG@b30d65de80 -> ProofGeneral/PG@d668946929 abicky/nodejs-repl.el@03d0b64768 -> abicky/nodejs-repl.el@130d49b073 agda/agda@819993172d -> agda/agda@3344ca8058 ardumont/markdown-toc@3d724e518a -> ardumont/markdown-toc@d2fb4cbd95 babashka/neil@78ffab1868 -> babashka/neil@0b7373dd1b clojure-emacs/cider@c228dec27d -> clojure-emacs/cider@f00e83d338 clojure-emacs/clojure-mode@59888c84b6 -> clojure-emacs/clojure-mode@eabe29b076 davazp/graphql-mode@c3baca9280 -> davazp/graphql-mode@ee49531935 dgutov/robe@6bc8a07fc4 -> dgutov/robe@ec4b7e74e9 diml/utop@b490baca21 -> diml/utop@3322adaa52 emacs-ess/ESS@8b4664e4a7 -> emacs-ess/ESS@c72b911d70 emacs-geiser/chicken@a480598b59 -> emacs-geiser/chicken@5f2c1bb446 emacs-geiser/geiser@97ce88463f -> emacs-geiser/geiser@74eed1669a emacs-jupyter/jupyter@e966c5d3d6 -> emacs-jupyter/jupyter@db8a9e233a emacs-lsp/lsp-metals@b5139c9593 -> emacs-lsp/lsp-metals@6a6a345a8a emacs-php/php-mode@31f702ee2d -> emacs-php/php-mode@0f756a8c07 emacs-rustic/rustic@9fdf5c76b2 -> emacs-rustic/rustic@e5c0271f1e emacs-straight/auctex@0de9730957 -> emacs-straight/auctex@f00256cbfd emacs-straight/org-mode@6a5d0ed342 -> emacs-straight/org-mode@5a4686915e emacsorphanage/macrostep@419873665f -> emacsorphanage/macrostep@44faf4f7bf erlang/otp@094260aba7 -> erlang/otp@3e7f126fe4 fxbois/web-mode@0c83581d1e -> fxbois/web-mode@be2d59c8fa gcv/julia-snail@dff92c4250 -> gcv/julia-snail@24f79a067b godotengine/emacs-gdscript-mode@bee7f99c6f -> godotengine/emacs-gdscript-mode@c3d9988984 greghendershott/racket-mode@c5bee6895b -> greghendershott/racket-mode@f2645aadd2 hakimel/reveal.js@0d02d8a303 -> hakimel/reveal.js@e15cf92ccd hvesalai/emacs-scala-mode@bd0638c32a -> hvesalai/emacs-scala-mode@661337d8aa jrblevin/markdown-mode@b8637bae07 -> jrblevin/markdown-mode@e100778594 jwiegley/emacs-async@af47d6f930 -> jwiegley/emacs-async@b99658e831 jwiegley/nix-update-el@aab70a3816 -> jwiegley/nix-update-el@77022ccd91 nonsequitur/inf-ruby@6399a36682 -> nonsequitur/inf-ruby@dad78a13f1 ocaml/dune@5ac095c7c0 -> ocaml/dune@098117d229 ocaml/merlin@a36f42a5b1 -> ocaml/merlin@3a806ef87f oer/org-re-reveal@91610ba9b0 -> oer/org-re-reveal@ab1422c163 org-roam/org-roam@2a630476b3 -> org-roam/org-roam@cad3518788 polymode/poly-R@e4a39caaf4 -> polymode/poly-R@8024e852cf polymode/polymode@15b6c1e94a -> polymode/polymode@74ba75d4bc psibi/dhall-mode@87ab69fe76 -> psibi/dhall-mode@fca383a9c4 purescript-emacs/purescript-mode@d187b3d4bb -> purescript-emacs/purescript-mode@07e4d6ecfe rwv/android-mode@d5332e339a -> rwv/android-mode@67f7c0d7d3 seagle0128/grip-mode@d6c7e33e40 -> seagle0128/grip-mode@df0ba7589d technomancy/fennel-mode@259470b297 -> technomancy/fennel-mode@3632cc77de tpapp/julia-repl@bb90cc1fce -> tpapp/julia-repl@317d560218
:lang rust
Description unfold
This module adds support for the Rust language and integration for its tools,
e.g. cargo
.
- Code completion (doom-package:racer or an LSP server)
- Syntax checking (doom-package:flycheck)
- LSP support (for rust-analyzer and rls) (doom-package:rustic)
- Snippets
Maintainers
- @hlissner
Module flags
- +lsp
-
Enable LSP support for
rustic-mode
. Requires doom-module::tools lsp and a langserver (supports rust-analyzer and rls). - +tree-sitter
- Leverages tree-sitter for better syntax highlighting and structural text editing. Requires doom-module::tools tree-sitter.
Packages
Hacks
- rustic has been modified not to automatically install lsp-mode or eglot if they're missing. Doom expects you to have enabled the doom-module::tools lsp module yourself.
TODO Changelog
This module does not have a changelog yet.
Installation
Enable this module in your doom!
block.
This module requires a working installation of Rust for its more advanced features, and offer only syntax highlighting otherwise. The simplest way to install it is through rustup:
$ curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
# And can be updated later with:
$ rustup update --no-self-update
To install and manage Rust on Windows, consult Rust's official documentation.
Once installed, I recommended that you add Cargo's executable to your
$PATH
, so that the Emacs utilities that depend on it – or any tools installed through it – can easily locate them (without any added configuration on your part).Also, if you have used
$ doom env
in the past, changes to your$PATH
won't be visible to Doom until you run it (or$ doom sync
) again.
Other Requirements
- If doom-module::editor format is enabled, you'll need
rustfmt
:$ rustup component add rustfmt
. - Users with doom-module:+lsp enabled will need rust-analyzer (rls is supported, but deprecated).
-
Using the following commands requires:
cargo-process-check
:$ cargo install cargo-check
cargo-process-clippy
:$ rustup component add clippy-preview
TODO Usage
This module's usage documentation is incomplete. Complete it?
LSP support (rust-analyzer)
This module supports rust-analyzer (RLS too, but it is deprecated), which must be installed outside of Emacs, typically with rustup or your OS package manager.
Installation through rustup is simplest:
$ rustup component add rust-analyzer rust-src
If your needs are more complex, consult rust-analyzer's documentation.
Finally, enable Doom's doom-module::tools lsp module, and this module's doom-module:+lsp flag (how to enable modules and their flags), and you're good to go!
Format on save
Enable doom-module::editor format +onsave to get formatting on save with
rustfmt
. No additional configuration is necessary.
Keybinds
Binding | Description |
---|---|
<localleader> b a |
cargo audit |
<localleader> b b |
cargo build |
<localleader> b B |
cargo bench |
<localleader> b c |
cargo check |
<localleader> b C |
cargo clippy |
<localleader> b d |
cargo doc |
<localleader> b n |
cargo update |
<localleader> b o |
cargo outdated |
<localleader> b r |
cargo run |
<localleader> t a |
cargo test |
<localleader> t t |
run current test |
TODO Configuration
This module's configuration documentation is incomplete. Complete it?
Enabling eglot support for Rust
Doom's doom-module::tools lsp module has an doom-module:+eglot flag. Enable it and this module will use eglot instead.
Troubleshooting
error[E0670]: `async fn` is not permitted in the 2015 edition
You may be seeing this error, despite having edition = "2018"
in your
Cargo.toml
. This error actually originates from rustfmt
, which the LSP
server tries to invoke on save (if you have rustic-format-trigger
or [[doom-module::editor
format]] enabled).
To fix this your project needs a rustfmt.toml
with edition = "2018"
in it.
Frequently asked questions
This module has no FAQs yet. Ask one?
TODO Appendix
This module has no appendix yet. Write one?