2015-11-12 09:01:38 +13:00
|
|
|
# rustfmt [![Build Status](https://travis-ci.org/rust-lang-nursery/rustfmt.svg)](https://travis-ci.org/rust-lang-nursery/rustfmt)
|
2015-04-30 15:09:33 +12:00
|
|
|
|
|
|
|
A tool for formatting Rust code according to style guidelines.
|
|
|
|
|
2015-11-10 07:34:44 +13:00
|
|
|
If you'd like to help out (and you should, it's a fun project!), see
|
2015-11-12 11:46:55 +13:00
|
|
|
[Contributing.md](Contributing.md).
|
2015-11-10 07:34:44 +13:00
|
|
|
|
2015-12-16 17:58:20 +13:00
|
|
|
## Quick start
|
|
|
|
|
|
|
|
To install:
|
|
|
|
|
|
|
|
```
|
2015-12-16 18:00:40 +13:00
|
|
|
cargo install rustfmt
|
2015-12-16 17:58:20 +13:00
|
|
|
```
|
|
|
|
|
|
|
|
to run on a cargo project in the current working directory:
|
|
|
|
|
|
|
|
```
|
|
|
|
cargo fmt
|
|
|
|
```
|
2015-10-23 13:51:29 -07:00
|
|
|
|
|
|
|
## Installation
|
|
|
|
|
2015-11-11 12:34:17 -05:00
|
|
|
> **Note:** this method currently requires you to be running cargo 0.6.0 or
|
|
|
|
> newer.
|
2015-10-23 13:51:29 -07:00
|
|
|
|
|
|
|
```
|
2015-12-16 18:00:40 +13:00
|
|
|
cargo install rustfmt
|
2015-10-23 13:51:29 -07:00
|
|
|
```
|
|
|
|
|
2015-10-26 21:51:59 -05:00
|
|
|
or if you're using [`multirust`](https://github.com/brson/multirust)
|
2015-10-23 13:51:29 -07:00
|
|
|
|
|
|
|
```
|
2015-12-16 18:00:40 +13:00
|
|
|
multirust run nightly cargo install rustfmt
|
2015-10-23 13:51:29 -07:00
|
|
|
```
|
2015-04-30 15:09:33 +12:00
|
|
|
|
2015-12-16 04:41:58 +01:00
|
|
|
Usually cargo-fmt, which enables usage of Cargo subcommand `cargo fmt`, is
|
|
|
|
installed alongside rustfmt. To only install rustfmt run
|
|
|
|
|
|
|
|
```
|
2015-12-16 18:00:40 +13:00
|
|
|
cargo install --no-default-features rustfmt
|
2015-12-16 04:41:58 +01:00
|
|
|
```
|
2015-11-04 17:45:01 +13:00
|
|
|
|
2015-12-14 08:17:26 +13:00
|
|
|
## Running
|
|
|
|
|
2015-12-16 04:41:58 +01:00
|
|
|
You can run Rustfmt by just typing `rustfmt filename` if you used `cargo
|
2015-12-14 08:17:26 +13:00
|
|
|
install`. This runs rustfmt on the given file, if the file includes out of line
|
|
|
|
modules, then we reformat those too. So to run on a whole module or crate, you
|
|
|
|
just need to run on the root file (usually mod.rs or lib.rs). Rustfmt can also
|
2015-12-16 04:41:58 +01:00
|
|
|
read data from stdin. Alternatively, you can use `cargo fmt` to format all
|
|
|
|
binary and library targets of your crate.
|
2015-12-14 08:17:26 +13:00
|
|
|
|
|
|
|
You'll probably want to specify the write mode. Currently, there are modes for
|
2016-01-22 22:33:59 -05:00
|
|
|
diff, replace, overwrite, display, coverage, and checkstyle.
|
|
|
|
|
2016-01-23 11:33:50 -05:00
|
|
|
* `replace` Is the default and overwrites the original files after creating backups of the files.
|
|
|
|
* `overwrite` Overwrites the original files _without_ creating backups.
|
|
|
|
* `display` Will print the formatted files to stdout.
|
|
|
|
* `diff` Will print a diff between the original files and formatted files to stdout.
|
2016-01-22 22:33:59 -05:00
|
|
|
* `checkstyle` Will output the lines that need to be corrected as a checkstyle XML file,
|
|
|
|
that can be used by tools like Jenkins.
|
|
|
|
|
|
|
|
The write mode can be set by passing the `--write-mode` flag on
|
|
|
|
the command line. For example `rustfmt --write-mode=display src/filename.rs`
|
2015-12-14 08:17:26 +13:00
|
|
|
|
2015-12-16 18:07:59 +13:00
|
|
|
`cargo fmt` uses `--write-mode=replace` by default.
|
|
|
|
|
2016-04-15 02:51:50 +03:00
|
|
|
If `rustfmt` successfully reformatted the code it will exit with `0` exit
|
|
|
|
status. Exit status `1` signals some unexpected error, like an unknown option or
|
|
|
|
a failure to read a file. Exit status `2` is returned if there are syntax errors
|
|
|
|
in the input files. `rustfmt` can't format syntatically invalid code. Finally,
|
|
|
|
exit status `3` is returned if there are some issues which can't be resolved
|
|
|
|
automatically. For example, if you have a very long comment line `rustfmt`
|
|
|
|
doesn't split it. Instead it prints a warning and exits with `3`.
|
|
|
|
|
|
|
|
You can run `rustfmt --help` for more information.
|
|
|
|
|
2015-12-14 08:17:26 +13:00
|
|
|
|
2015-11-12 15:14:28 +05:30
|
|
|
## Running Rustfmt from your editor
|
2015-11-04 17:45:01 +13:00
|
|
|
|
2015-11-12 15:14:28 +05:30
|
|
|
* [Vim](http://johannh.me/blog/rustfmt-vim.html)
|
|
|
|
* [Emacs](https://github.com/fbergroth/emacs-rustfmt)
|
2015-12-12 10:11:09 +08:00
|
|
|
* [Sublime Text 3](https://packagecontrol.io/packages/BeautifyRust)
|
2015-11-17 10:54:42 +05:30
|
|
|
* [Atom](atom.md)
|
2016-01-01 09:30:36 -08:00
|
|
|
* Visual Studio Code using [RustyCode](https://github.com/saviorisdead/RustyCode) or [vsc-rustfmt](https://github.com/Connorcpu/vsc-rustfmt)
|
2015-11-04 17:45:01 +13:00
|
|
|
|
2015-08-31 19:42:58 -07:00
|
|
|
## How to build and test
|
2015-10-23 13:51:29 -07:00
|
|
|
|
2015-04-30 15:09:33 +12:00
|
|
|
`cargo build` to build.
|
|
|
|
|
|
|
|
`cargo test` to run all tests.
|
|
|
|
|
2015-12-15 01:18:47 +01:00
|
|
|
To run rustfmt after this, use `cargo run --bin rustfmt -- filename`. See the
|
2015-12-16 04:41:58 +01:00
|
|
|
notes above on running rustfmt.
|
2015-11-04 17:45:01 +13:00
|
|
|
|
|
|
|
|
2016-01-14 17:58:23 +13:00
|
|
|
## Configuring Rustfmt
|
2015-11-10 07:34:44 +13:00
|
|
|
|
|
|
|
Rustfmt is designed to be very configurable. You can create a TOML file called
|
|
|
|
rustfmt.toml, place it in the project directory and it will apply the options
|
2016-02-03 16:50:39 -07:00
|
|
|
in that file. See `rustfmt --config-help` for the options which are available,
|
2016-01-14 17:58:23 +13:00
|
|
|
or if you prefer to see source code, [src/config.rs](src/config.rs).
|
2015-11-10 07:34:44 +13:00
|
|
|
|
2015-11-28 10:03:46 +01:00
|
|
|
By default, Rustfmt uses a style which (mostly) conforms to the
|
2015-11-10 07:34:44 +13:00
|
|
|
[Rust style guidelines](https://github.com/rust-lang/rust/tree/master/src/doc/style).
|
|
|
|
There are many details which the style guidelines do not cover, and in these
|
|
|
|
cases we try to adhere to a style similar to that used in the
|
|
|
|
[Rust repo](https://github.com/rust-lang/rust). Once Rustfmt is more complete, and
|
|
|
|
able to re-format large repositories like Rust, we intend to go through the Rust
|
|
|
|
RFC process to nail down the default style in detail.
|
|
|
|
|
|
|
|
If there are styling choices you don't agree with, we are usually happy to add
|
|
|
|
options covering different styles. File an issue, or even better, submit a PR.
|
|
|
|
|
|
|
|
|
2015-11-04 17:45:01 +13:00
|
|
|
## Gotchas
|
|
|
|
|
|
|
|
* For things you do not want rustfmt to mangle, use one of
|
2015-11-20 16:58:57 -02:00
|
|
|
|
2015-11-10 07:34:44 +13:00
|
|
|
```rust
|
2016-03-17 00:51:16 -04:00
|
|
|
#[rustfmt_skip] // requires nightly and #![feature(custom_attribute)] in crate root
|
|
|
|
#[cfg_attr(rustfmt, rustfmt_skip)] // works in stable
|
2015-11-04 17:45:01 +13:00
|
|
|
```
|
|
|
|
* When you run rustfmt, place a file named rustfmt.toml in target file
|
|
|
|
directory or its parents to override the default settings of rustfmt.
|
|
|
|
* After successful compilation, a `rustfmt` executable can be found in the
|
|
|
|
target directory.
|
2016-04-14 20:48:21 +02:00
|
|
|
|
|
|
|
|
|
|
|
## License
|
|
|
|
|
|
|
|
Rustfmt is distributed under the terms of both the MIT license and the
|
|
|
|
Apache License (Version 2.0).
|
|
|
|
|
|
|
|
See [LICENSE-APACHE](LICENSE-APACHE) and [LICENSE-MIT](LICENSE-MIT) for details.
|