Skip to content

Commit 50b802a

Browse files
author
Nick Hamann
committed
Add error explanations for E0185, E0186.
1 parent 35d979d commit 50b802a

File tree

1 file changed

+42
-2
lines changed

1 file changed

+42
-2
lines changed

src/librustc_typeck/diagnostics.rs

Lines changed: 42 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -443,6 +443,48 @@ it has been disabled for now.
443443
[iss20126]: https://github.com/rust-lang/rust/issues/20126
444444
"##,
445445

446+
E0185: r##"
447+
An associated function for a trait was defined to be static, but an
448+
implementation of the trait declared the same function to be a method (i.e. to
449+
take a `self` parameter).
450+
451+
Here's an example of this error:
452+
453+
```
454+
trait Foo {
455+
fn foo();
456+
}
457+
458+
struct Bar;
459+
460+
impl Foo for Bar {
461+
// error, method `foo` has a `&self` declaration in the impl, but not in
462+
// the trait
463+
fn foo(&self) {}
464+
}
465+
"##,
466+
467+
E0186: r##"
468+
An associated function for a trait was defined to be a method (i.e. to take a
469+
`self` parameter), but an implementation of the trait declared the same function
470+
to be static.
471+
472+
Here's an example of this error:
473+
474+
```
475+
trait Foo {
476+
fn foo(&self);
477+
}
478+
479+
struct Bar;
480+
481+
impl Foo for Bar {
482+
// error, method `foo` has a `&self` declaration in the trait, but not in
483+
// the impl
484+
fn foo() {}
485+
}
486+
"##,
487+
446488
E0197: r##"
447489
Inherent implementations (one that do not implement a trait but provide
448490
methods associated with a type) are always safe because they are not
@@ -828,8 +870,6 @@ register_diagnostics! {
828870
E0174, // explicit use of unboxed closure methods are experimental
829871
E0182,
830872
E0183,
831-
E0185,
832-
E0186,
833873
E0187, // can't infer the kind of the closure
834874
E0188, // types differ in mutability
835875
E0189, // can only cast a boxed pointer to a boxed object

0 commit comments

Comments
 (0)