Auto merge of #46403 - oli-obk:generic_missing_impl, r=nikomatsakis
Report a targeted note for generic parameters that are missing a trait bound
This commit is contained in:
commit
98a96b0b66
4 changed files with 32 additions and 7 deletions
|
@ -1196,13 +1196,6 @@ impl RegionKind {
|
||||||
|
|
||||||
/// Type utilities
|
/// Type utilities
|
||||||
impl<'a, 'gcx, 'tcx> TyS<'tcx> {
|
impl<'a, 'gcx, 'tcx> TyS<'tcx> {
|
||||||
pub fn as_opt_param_ty(&self) -> Option<ty::ParamTy> {
|
|
||||||
match self.sty {
|
|
||||||
ty::TyParam(ref d) => Some(d.clone()),
|
|
||||||
_ => None,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn is_nil(&self) -> bool {
|
pub fn is_nil(&self) -> bool {
|
||||||
match self.sty {
|
match self.sty {
|
||||||
TyTuple(ref tys, _) => tys.is_empty(),
|
TyTuple(ref tys, _) => tys.is_empty(),
|
||||||
|
|
|
@ -289,6 +289,11 @@ impl<'a, 'gcx, 'tcx> FnCtxt<'a, 'gcx, 'tcx> {
|
||||||
// This has nothing here because it means we did string
|
// This has nothing here because it means we did string
|
||||||
// concatenation (e.g. "Hello " + "World!"). This means
|
// concatenation (e.g. "Hello " + "World!"). This means
|
||||||
// we don't want the note in the else clause to be emitted
|
// we don't want the note in the else clause to be emitted
|
||||||
|
} else if let ty::TyParam(_) = lhs_ty.sty {
|
||||||
|
// FIXME: point to span of param
|
||||||
|
err.note(
|
||||||
|
&format!("`{}` might need a bound for `{}`",
|
||||||
|
lhs_ty, missing_trait));
|
||||||
} else {
|
} else {
|
||||||
err.note(
|
err.note(
|
||||||
&format!("an implementation of `{}` might be missing for `{}`",
|
&format!("an implementation of `{}` might be missing for `{}`",
|
||||||
|
|
17
src/test/ui/type-check/missing_trait_impl.rs
Normal file
17
src/test/ui/type-check/missing_trait_impl.rs
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
// Copyright 2017 The Rust Project Developers. See the COPYRIGHT
|
||||||
|
// file at the top-level directory of this distribution and at
|
||||||
|
// http://rust-lang.org/COPYRIGHT.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
||||||
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
||||||
|
// option. This file may not be copied, modified, or distributed
|
||||||
|
// except according to those terms.
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
}
|
||||||
|
|
||||||
|
fn foo<T>(x: T, y: T) {
|
||||||
|
let z = x + y; //~ ERROR binary operation `+` cannot be applied to type `T`
|
||||||
|
//~^ NOTE `T` might need a bound for `std::ops::Add`
|
||||||
|
}
|
10
src/test/ui/type-check/missing_trait_impl.stderr
Normal file
10
src/test/ui/type-check/missing_trait_impl.stderr
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
error[E0369]: binary operation `+` cannot be applied to type `T`
|
||||||
|
--> $DIR/missing_trait_impl.rs:15:13
|
||||||
|
|
|
||||||
|
15 | let z = x + y; //~ ERROR binary operation `+` cannot be applied to type `T`
|
||||||
|
| ^^^^^
|
||||||
|
|
|
||||||
|
= note: `T` might need a bound for `std::ops::Add`
|
||||||
|
|
||||||
|
error: aborting due to previous error
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue