`rust-mode`: A major Emacs mode for editing Rust source code ============================================================ `rust-mode` makes editing [Rust](http://rust-lang.org) code with Emacs enjoyable. `rust-mode` requires Emacs 24 or later. ## Installation ### Manual Installation To install manually, check out this repository and add this to your `.emacs` file: ```lisp (add-to-list 'load-path "/path/to/rust-mode/") (autoload 'rust-mode "rust-mode" nil t) (add-to-list 'auto-mode-alist '("\\.rs\\'" . rust-mode)) ``` This associates `rust-mode` with `.rs` files. To enable it explicitly, do M-x rust-mode. ### `package.el` installation via MELPA It can be more convenient to use Emacs's package manager to handle installation for you if you use many elisp libraries. If you have `package.el` but haven't added MELPA, the community package source, yet, add this to `~/.emacs.d/init.el`: ```lisp (require 'package) (add-to-list 'package-archives '("melpa" . "https://melpa.org/packages/") t) (package-initialize) ``` Then do this to load the package listing: * M-x eval-buffer * M-x package-refresh-contents #### MELPA stable MELPA stable only updates when a new version tag is created. There isn't a specified frequency for this project to release versions; if you are a MELPA stable user and feel that the last release tag is too far out of date, open a pull request that updates the version header in `rust-mode.el` and note that a new version tag should be added when the request is merged. See [Pull Request #178](https://github.com/rust-lang/rust-mode/pull/178) (the first such pull request)) for an example of this. #### Install `rust-mode` One you have `package.el`, you can install `rust-mode` or any other modes by choosing them from a list: * M-x package-list-packages Now, to install packages, move your cursor to them and press i. This will mark the packages for installation. When you're done with marking, press x, and ELPA will install the packages for you (under `~/.emacs.d/elpa/`). * or using M-x package-install rust-mode ### Package installation on Debian ```bash apt install elpa-rust-mode ``` ### Tests via ERT The file `rust-mode-tests.el` contains tests that can be run via [ERT](http://www.gnu.org/software/emacs/manual/html_node/ert/index.html). 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. ## Features ### Formatting with [rustfmt][rfmt] The `rust-format-buffer` function will format your code with [rustfmt][rfmt] if installed. By default, this is bound to `C-c C-f`. Placing `(setq rust-format-on-save t)` in your `~/.emacs` will enable automatic running of `rust-format-buffer` when you save a buffer. [rfmt]: https://crates.io/crates/rustfmt/ ## License `rust-mode` is distributed under the terms of both the MIT license and the Apache License (Version 2.0). See [LICENSE-MIT](LICENSE-MIT) and [LICENSE-APACHE](LICENSE-APACHE) for details.