Skip to content

Commit

Permalink
Rollup merge of #83092 - petrochenkov:qspan, r=estebank
Browse files Browse the repository at this point in the history
More precise spans for HIR paths

`Ty::assoc_item` is lowered to `<Ty>::assoc_item` in HIR, but `Ty` got span from the whole path.
This PR fixes that, and adjusts some diagnostic code that relied on `Ty` having the whole path span.

This is a pre-requisite for rust-lang/rust#82868 (we cannot report suggestions like `Tr::assoc` -> `<dyn Tr>::assoc` with the current imprecise spans).
r? ````@estebank````
  • Loading branch information
JohnTitor authored Mar 17, 2021
2 parents 846d4f0 + 09a9ea6 commit 5476382
Show file tree
Hide file tree
Showing 5 changed files with 28 additions and 38 deletions.
23 changes: 12 additions & 11 deletions tests/ui/use_self.fixed
Original file line number Diff line number Diff line change
Expand Up @@ -312,17 +312,18 @@ mod issue4140 {
fn try_from(value: T) -> Result<Self, Error<Self::From, Self::To>>;
}

impl<F, T> TryFrom<F> for T
where
T: From<F>,
{
type From = Self;
type To = Self;

fn try_from(value: F) -> Result<Self, Error<Self::From, Self::To>> {
Ok(From::from(value))
}
}
// FIXME: Suggested fix results in infinite recursion.
// impl<F, T> TryFrom<F> for T
// where
// T: From<F>,
// {
// type From = Self::From;
// type To = Self::To;

// fn try_from(value: F) -> Result<Self, Error<Self::From, Self::To>> {
// Ok(From::from(value))
// }
// }

impl From<bool> for i64 {
type From = bool;
Expand Down
23 changes: 12 additions & 11 deletions tests/ui/use_self.rs
Original file line number Diff line number Diff line change
Expand Up @@ -312,17 +312,18 @@ mod issue4140 {
fn try_from(value: T) -> Result<Self, Error<Self::From, Self::To>>;
}

impl<F, T> TryFrom<F> for T
where
T: From<F>,
{
type From = T::From;
type To = T::To;

fn try_from(value: F) -> Result<Self, Error<Self::From, Self::To>> {
Ok(From::from(value))
}
}
// FIXME: Suggested fix results in infinite recursion.
// impl<F, T> TryFrom<F> for T
// where
// T: From<F>,
// {
// type From = Self::From;
// type To = Self::To;

// fn try_from(value: F) -> Result<Self, Error<Self::From, Self::To>> {
// Ok(From::from(value))
// }
// }

impl From<bool> for i64 {
type From = bool;
Expand Down
16 changes: 2 additions & 14 deletions tests/ui/use_self.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -157,22 +157,10 @@ LL | Foo { value }
| ^^^ help: use the applicable keyword: `Self`

error: unnecessary structure name repetition
--> $DIR/use_self.rs:319:21
|
LL | type From = T::From;
| ^^^^^^^ help: use the applicable keyword: `Self`

error: unnecessary structure name repetition
--> $DIR/use_self.rs:320:19
|
LL | type To = T::To;
| ^^^^^ help: use the applicable keyword: `Self`

error: unnecessary structure name repetition
--> $DIR/use_self.rs:453:13
--> $DIR/use_self.rs:454:13
|
LL | A::new::<submod::B>(submod::B {})
| ^ help: use the applicable keyword: `Self`

error: aborting due to 29 previous errors
error: aborting due to 27 previous errors

2 changes: 1 addition & 1 deletion tests/ui/zero_sized_btreemap_values.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,7 @@ error: map with zero-sized value type
--> $DIR/zero_sized_btreemap_values.rs:64:35
|
LL | let _: BTreeMap<String, ()> = BTreeMap::new();
| ^^^^^^^^^^^^^
| ^^^^^^^^
|
= help: consider using a set instead

Expand Down
2 changes: 1 addition & 1 deletion tests/ui/zero_sized_hashmap_values.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,7 @@ error: map with zero-sized value type
--> $DIR/zero_sized_hashmap_values.rs:64:34
|
LL | let _: HashMap<String, ()> = HashMap::new();
| ^^^^^^^^^^^^
| ^^^^^^^
|
= help: consider using a set instead

Expand Down

0 comments on commit 5476382

Please sign in to comment.