Rollup merge of #36383 - GuillaumeGomez:e0049, r=jonathandturner
Update E0049 to new error format Fixes #35210. Part of #35233. r? @jonathandturner
This commit is contained in:
commit
9eac7bdd09
@ -38,7 +38,8 @@ pub fn compare_impl_method<'a, 'tcx>(ccx: &CrateCtxt<'a, 'tcx>,
|
||||
impl_m_span: Span,
|
||||
impl_m_body_id: ast::NodeId,
|
||||
trait_m: &ty::Method<'tcx>,
|
||||
impl_trait_ref: &ty::TraitRef<'tcx>) {
|
||||
impl_trait_ref: &ty::TraitRef<'tcx>,
|
||||
trait_item_span: Option<Span>) {
|
||||
debug!("compare_impl_method(impl_trait_ref={:?})",
|
||||
impl_trait_ref);
|
||||
|
||||
@ -97,14 +98,42 @@ pub fn compare_impl_method<'a, 'tcx>(ccx: &CrateCtxt<'a, 'tcx>,
|
||||
let num_impl_m_type_params = impl_m.generics.types.len();
|
||||
let num_trait_m_type_params = trait_m.generics.types.len();
|
||||
if num_impl_m_type_params != num_trait_m_type_params {
|
||||
span_err!(tcx.sess, impl_m_span, E0049,
|
||||
let impl_m_node_id = tcx.map.as_local_node_id(impl_m.def_id).unwrap();
|
||||
let span = match tcx.map.expect_impl_item(impl_m_node_id).node {
|
||||
ImplItemKind::Method(ref impl_m_sig, _) => {
|
||||
if impl_m_sig.generics.is_parameterized() {
|
||||
impl_m_sig.generics.span
|
||||
} else {
|
||||
impl_m_span
|
||||
}
|
||||
}
|
||||
_ => bug!("{:?} is not a method", impl_m)
|
||||
};
|
||||
|
||||
struct_span_err!(tcx.sess, span, E0049,
|
||||
"method `{}` has {} type parameter{} \
|
||||
but its trait declaration has {} type parameter{}",
|
||||
trait_m.name,
|
||||
num_impl_m_type_params,
|
||||
if num_impl_m_type_params == 1 {""} else {"s"},
|
||||
num_trait_m_type_params,
|
||||
if num_trait_m_type_params == 1 {""} else {"s"});
|
||||
if num_trait_m_type_params == 1 {""} else {"s"})
|
||||
.span_label(trait_item_span.unwrap(),
|
||||
&format!("expected {}",
|
||||
&if num_trait_m_type_params != 1 {
|
||||
format!("{} type parameters",
|
||||
num_trait_m_type_params)
|
||||
} else {
|
||||
format!("{} type parameter",
|
||||
num_trait_m_type_params)
|
||||
}))
|
||||
.span_label(span, &format!("found {}",
|
||||
&if num_impl_m_type_params != 1 {
|
||||
format!("{} type parameters", num_impl_m_type_params)
|
||||
} else {
|
||||
format!("1 type parameter")
|
||||
}))
|
||||
.emit();
|
||||
return;
|
||||
}
|
||||
|
||||
|
@ -1015,13 +1015,15 @@ fn check_impl_items_against_trait<'a, 'tcx>(ccx: &CrateCtxt<'a, 'tcx>,
|
||||
_ => span_bug!(impl_item.span, "non-method impl-item for method")
|
||||
};
|
||||
|
||||
let trait_span = tcx.map.span_if_local(ty_trait_item.def_id());
|
||||
if let &ty::MethodTraitItem(ref trait_method) = ty_trait_item {
|
||||
compare_impl_method(ccx,
|
||||
&impl_method,
|
||||
impl_item.span,
|
||||
body.id,
|
||||
&trait_method,
|
||||
&impl_trait_ref);
|
||||
&impl_trait_ref,
|
||||
trait_span);
|
||||
} else {
|
||||
let mut err = struct_span_err!(tcx.sess, impl_item.span, E0324,
|
||||
"item `{}` is an associated method, \
|
||||
|
@ -9,13 +9,14 @@
|
||||
// except according to those terms.
|
||||
|
||||
trait Foo {
|
||||
fn foo<T: Default>(x: T) -> Self;
|
||||
fn foo<T: Default>(x: T) -> Self; //~ NOTE expected 1 type parameter
|
||||
}
|
||||
|
||||
struct Bar;
|
||||
|
||||
impl Foo for Bar {
|
||||
fn foo(x: bool) -> Self { Bar } //~ ERROR E0049
|
||||
//~| NOTE found 0 type parameters
|
||||
}
|
||||
|
||||
fn main() {
|
||||
|
Loading…
Reference in New Issue
Block a user