-
Notifications
You must be signed in to change notification settings - Fork 13k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Fix ICE, generalize 'move generics to trait' suggestion for >0 non-rc…
…vr arguments
- Loading branch information
1 parent
b44197a
commit bee48e3
Showing
5 changed files
with
104 additions
and
11 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,12 @@ | ||
pub trait Ice { | ||
fn f(&self, _: ()); | ||
} | ||
|
||
impl Ice for () { | ||
fn f(&self, _: ()) {} | ||
} | ||
|
||
fn main() { | ||
().f::<()>(()); | ||
//~^ ERROR this associated function takes 0 generic arguments but 1 generic argument was supplied | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
error[E0107]: this associated function takes 0 generic arguments but 1 generic argument was supplied | ||
--> $DIR/issue-101421.rs:10:8 | ||
| | ||
LL | ().f::<()>(()); | ||
| ^------ help: remove these generics | ||
| | | ||
| expected 0 generic arguments | ||
| | ||
note: associated function defined here, with 0 generic parameters | ||
--> $DIR/issue-101421.rs:2:8 | ||
| | ||
LL | fn f(&self, _: ()); | ||
| ^ | ||
|
||
error: aborting due to previous error | ||
|
||
For more information about this error, try `rustc --explain E0107`. |
18 changes: 18 additions & 0 deletions
18
src/test/ui/suggestions/move-generic-to-trait-in-method-with-params.rs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
// Generalizes the suggestion introduced in #100838 | ||
|
||
trait Foo<T> { | ||
fn bar(&self, _: T); | ||
} | ||
|
||
impl Foo<i32> for i32 { | ||
fn bar(&self, x: i32) { | ||
println!("{}", self + x); | ||
} | ||
} | ||
|
||
fn main() { | ||
1.bar::<i32>(0); | ||
//~^ ERROR this associated function takes 0 generic arguments but 1 generic argument was supplied | ||
//~| HELP consider moving this generic argument to the `Foo` trait, which takes up to 1 argument | ||
//~| HELP remove these generics | ||
} |
24 changes: 24 additions & 0 deletions
24
src/test/ui/suggestions/move-generic-to-trait-in-method-with-params.stderr
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
error[E0107]: this associated function takes 0 generic arguments but 1 generic argument was supplied | ||
--> $DIR/move-generic-to-trait-in-method-with-params.rs:14:7 | ||
| | ||
LL | 1.bar::<i32>(0); | ||
| ^^^ expected 0 generic arguments | ||
| | ||
note: associated function defined here, with 0 generic parameters | ||
--> $DIR/move-generic-to-trait-in-method-with-params.rs:4:8 | ||
| | ||
LL | fn bar(&self, _: T); | ||
| ^^^ | ||
help: consider moving this generic argument to the `Foo` trait, which takes up to 1 argument | ||
| | ||
LL | Foo::<i32>::bar(1, 0); | ||
| ~~~~~~~~~~~~~~~~~~~~~ | ||
help: remove these generics | ||
| | ||
LL - 1.bar::<i32>(0); | ||
LL + 1.bar(0); | ||
| | ||
|
||
error: aborting due to previous error | ||
|
||
For more information about this error, try `rustc --explain E0107`. |