Merge pull request #3293 from scampi/issue-3241

Keep leading colons for global paths
This commit is contained in:
Seiichi Uchida 2019-01-27 23:14:57 +09:00 committed by GitHub
commit 36c9dc646c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 66 additions and 14 deletions

View File

@ -15,24 +15,33 @@ the "travis example" badge above.
You can run `rustfmt` with Rust 1.24 and above.
### On the Stable toolchain
To install:
```
```sh
rustup component add rustfmt
```
to run on a cargo project in the current working directory:
To run on a cargo project in the current working directory:
```
```sh
cargo fmt
```
For the latest and greatest `rustfmt` (nightly required):
```
### On the Nightly toolchain
For the latest and greatest `rustfmt`, nightly is required.
To install:
```sh
rustup component add rustfmt --toolchain nightly
```
To run:
```
To run on a cargo project in the current working directory:
```sh
cargo +nightly fmt
```
@ -67,7 +76,7 @@ because in the future Rustfmt might work on code where it currently does not):
## Installation
```
```sh
rustup component add rustfmt
```
@ -75,7 +84,7 @@ rustup component add rustfmt
To install from source (nightly required), first checkout to the tag or branch you want to install, then issue
```
```sh
cargo install --path .
```
@ -161,6 +170,11 @@ Configuration options are either stable or unstable. Stable options can always
be used, while unstable ones are only available on a nightly toolchain, and opt-in.
See [Configurations.md](Configurations.md) for details.
### Rust's Editions
Rustfmt is able to pick up the edition used by reading the `Cargo.toml` file if
executed through the Cargo's formatting tool `cargo fmt`. Otherwise, the edition
needs to be specified in `rustfmt.toml`, e.g., with `edition = "2018"`.
## Tips
@ -178,7 +192,7 @@ See [Configurations.md](Configurations.md) for details.
Example:
```
```sh
cargo fmt -- --emit files
```

View File

@ -324,9 +324,8 @@ impl UseTree {
attrs,
};
let leading_modsep = context.config.edition() == Edition::Edition2018
&& a.prefix.to_string().len() > 2
&& a.prefix.to_string().starts_with("::");
let leading_modsep =
context.config.edition() == Edition::Edition2018 && a.prefix.is_global();
let mut modsep = leading_modsep;
@ -339,6 +338,10 @@ impl UseTree {
match a.kind {
UseTreeKind::Glob => {
// in case of a global path and the glob starts at the root, e.g., "::*"
if a.prefix.segments.len() == 1 && leading_modsep {
result.path.push(UseSegment::Ident("".to_owned(), None));
}
result.path.push(UseSegment::Glob);
}
UseTreeKind::Nested(ref list) => {
@ -357,6 +360,11 @@ impl UseTree {
false,
)
.collect();
// in case of a global path and the nested list starts at the root,
// e.g., "::{foo, bar}"
if a.prefix.segments.len() == 1 && leading_modsep {
result.path.push(UseSegment::Ident("".to_owned(), None));
}
result.path.push(UseSegment::List(
list.iter()
.zip(items.into_iter())
@ -367,7 +375,15 @@ impl UseTree {
));
}
UseTreeKind::Simple(ref rename, ..) => {
let name = rewrite_ident(context, path_to_imported_ident(&a.prefix)).to_owned();
// If the path has leading double colons and is composed of only 2 segments, then we
// bypass the call to path_to_imported_ident which would get only the ident and
// lose the path root, e.g., `that` in `::that`.
// The span of `a.prefix` contains the leading colons.
let name = if a.prefix.segments.len() == 2 && leading_modsep {
context.snippet(a.prefix.span).to_owned()
} else {
rewrite_ident(context, path_to_imported_ident(&a.prefix)).to_owned()
};
let alias = rename.and_then(|ident| {
if ident.name == "_" {
// for impl-only-use

View File

@ -0,0 +1,11 @@
// rustfmt-edition: 2018
use ::ignore;
use ::ignore::some::more;
use ::{foo, bar};
use ::*;
use ::baz::{foo, bar};
fn main() {
println!("Hello, world!");
}

View File

@ -0,0 +1,11 @@
// rustfmt-edition: 2018
use ::baz::{bar, foo};
use ::ignore;
use ::ignore::some::more;
use ::*;
use ::{bar, foo};
fn main() {
println!("Hello, world!");
}