Skip to content

Commit

Permalink
Auto merge of #46403 - oli-obk:generic_missing_impl, r=nikomatsakis
Browse files Browse the repository at this point in the history
Report a targeted note for generic parameters that are missing a trait bound
  • Loading branch information
bors committed Dec 5, 2017
2 parents a4fa23a + 9e062c8 commit 98a96b0
Show file tree
Hide file tree
Showing 4 changed files with 32 additions and 7 deletions.
7 changes: 0 additions & 7 deletions src/librustc/ty/sty.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1196,13 +1196,6 @@ impl RegionKind {

/// Type utilities
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 {
match self.sty {
TyTuple(ref tys, _) => tys.is_empty(),
Expand Down
5 changes: 5 additions & 0 deletions src/librustc_typeck/check/op.rs
Original file line number Diff line number Diff line change
Expand Up @@ -289,6 +289,11 @@ impl<'a, 'gcx, 'tcx> FnCtxt<'a, 'gcx, 'tcx> {
// This has nothing here because it means we did string
// concatenation (e.g. "Hello " + "World!"). This means
// 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 {
err.note(
&format!("an implementation of `{}` might be missing for `{}`",
Expand Down
17 changes: 17 additions & 0 deletions src/test/ui/type-check/missing_trait_impl.rs
Original file line number Diff line number Diff line change
@@ -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 changes: 10 additions & 0 deletions src/test/ui/type-check/missing_trait_impl.stderr
Original file line number Diff line number Diff line change
@@ -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

0 comments on commit 98a96b0

Please sign in to comment.