Table of Contents
rust-mode
makes editing Rust code with Emacs
enjoyable. It requires Emacs 25 or later, and is include in both
Emacs Prelude and
Spacemacs by default.
This mode provides:
- Syntax highlighting (for Font Lock Mode)
- Indentation
- Integration with Cargo, clippy and rustfmt
This mode does not provide autocompletion, or jumping to function / trait definitions. See Integration with Rust Language Server below for tips on how to enable this.
The package is available on MELPA. Add this to your init.el.
(require 'package)
(add-to-list 'package-archives
'("melpa" . "https://melpa.org/packages/") t)
(package-initialize)
(package-refresh-contents)
Now you can install rust-mode
with:
M-x package-install rust-mode
And put this in your config to load rust-mode automatically:
(require 'rust-mode)
Clone this repository locally, and add this to your init.el:
(add-to-list 'load-path "/path/to/rust-mode/")
(autoload 'rust-mode "rust-mode" nil t)
Commands like TAB should indent correctly.
The Rust style guide recommends spaces rather than tabs for indentation; to follow the recommendation add this to your init.el, which forces indentation to always use spaces.
(add-hook 'rust-mode-hook
(lambda () (setq indent-tabs-mode nil)))
The rust-format-buffer
function will format your code with
rustfmt if installed. By
default, this is bound to C-c C-f.
The variable rust-format-on-save
enables automatic formatting on
save. For example, add the following in your init.el to enable format
on save:
(setq rust-format-on-save t)
The rust-run
, rust-test
and rust-build
functions shell out to
Cargo to run, test or build your code. Under the hood, these use the
standard Emacs compile
function.
These are not bound by default. To bind these to keyboard shortcuts, you can use the following in your init.el:
(define-key rust-mode-map (kbd "C-c C-c") 'rust-run)
rust-run-clippy
runs
Clippy, a linter.
rust-dbg-wrap-or-unwrap
either wraps or unwraps the current region
in dbg!
. This can be useful for easily adding debug lines to your
program.
This is bound to C-c C-d by default.
This package does not provide integration with RLS, which provides auto-completion and code navigation. To use this you need an Emacs package that supports LSP.
Two examples are:
A lighter package that uses racer is emacs-racer.
flycheck allows highlighting compile errors and Clippy lints inline.
cargo.el provides a minor mode for integration with Cargo, Rust's package manager.
rustic is a fork of rust-mode, extending it with other features such as integration with LSP and with flycheck.
The file rust-mode-tests.el
contains tests that can be run via
ERT.
You can use run_rust_emacs_tests.sh
to run them in batch mode, if
you set the environment variable EMACS to a program that runs emacs.