1
Fork 0

Point out the known type when field doesn't satisfy bound

For file

```rust
use std::path::Path;

fn f(p: Path) { }
```

provide the following error

```nocode
error[E0277]: the trait bound `[u8]: std::marker::Sized` is not satisfied in `std::path::Path`
 --> file.rs:3:6
  |
3 | fn f(p: Path) { }
  |      ^ within `std::path::Path`, the trait `std::marker::Sized` is not implemented for `[u8]`
  |
  = note: `[u8]` does not have a constant size known at compile-time
  = note: required because it appears within the type `std::path::Path`
  = note: all local variables must have a statically known size
```
This commit is contained in:
Esteban Küber 2016-12-03 17:41:14 -08:00
parent 070fad1701
commit ef09db0ff3
2 changed files with 32 additions and 7 deletions

View file

@ -487,13 +487,29 @@ impl<'a, 'gcx, 'tcx> InferCtxt<'a, 'gcx, 'tcx> {
} else { } else {
let trait_ref = trait_predicate.to_poly_trait_ref(); let trait_ref = trait_predicate.to_poly_trait_ref();
let mut err = struct_span_err!(self.tcx.sess, span, E0277, let (post_message, pre_message) =
"the trait bound `{}` is not satisfied", if let ObligationCauseCode::BuiltinDerivedObligation(ref data)
trait_ref.to_predicate()); = obligation.cause.code {
err.span_label(span, &format!("the trait `{}` is not implemented \ let parent_trait_ref = self.resolve_type_vars_if_possible(
for `{}`", &data.parent_trait_ref);
trait_ref, (format!(" in `{}`", parent_trait_ref.0.self_ty()),
trait_ref.self_ty())); format!("within `{}`, ", parent_trait_ref.0.self_ty()))
} else {
(String::new(), String::new())
};
let mut err = struct_span_err!(
self.tcx.sess,
span,
E0277,
"the trait bound `{}` is not satisfied{}",
trait_ref.to_predicate(),
post_message);
err.span_label(span,
&format!("{}the trait `{}` is not \
implemented for `{}`",
pre_message,
trait_ref,
trait_ref.self_ty()));
// Try to report a help message // Try to report a help message

View file

@ -8,6 +8,8 @@
// option. This file may not be copied, modified, or distributed // option. This file may not be copied, modified, or distributed
// except according to those terms. // except according to those terms.
use std::path::Path;
trait Foo { trait Foo {
fn bar(&self); fn bar(&self);
} }
@ -16,6 +18,13 @@ fn some_func<T: Foo>(foo: T) {
foo.bar(); foo.bar();
} }
fn f(p: Path) { }
//~^ ERROR the trait bound `[u8]: std::marker::Sized` is not satisfied in `std::path::Path`
//~| NOTE within `std::path::Path`, the trait `std::marker::Sized` is not implemented for `[u8]`
//~| NOTE `[u8]` does not have a constant size known at compile-time
//~| NOTE required because it appears within the type `std::path::Path`
//~| NOTE all local variables must have a statically known size
fn main() { fn main() {
some_func(5i32); some_func(5i32);
//~^ ERROR the trait bound `i32: Foo` is not satisfied //~^ ERROR the trait bound `i32: Foo` is not satisfied