mirror of
https://github.com/rust-lang/rust.git
synced 2024-11-22 14:55:26 +00:00
Auto merge of #86338 - JohnTitor:issue-86162, r=estebank
Do not suggest impl traits as type arguments Fixes #86162
This commit is contained in:
commit
d5fd37f00f
@ -753,23 +753,11 @@ impl<'a, 'tcx> InferCtxt<'a, 'tcx> {
|
||||
if let (UnderspecifiedArgKind::Const { .. }, Some(parent_data)) =
|
||||
(&arg_data.kind, &arg_data.parent)
|
||||
{
|
||||
let has_impl_trait =
|
||||
self.tcx.generics_of(parent_data.def_id).params.iter().any(|param| {
|
||||
matches!(
|
||||
param.kind,
|
||||
ty::GenericParamDefKind::Type {
|
||||
synthetic: Some(
|
||||
hir::SyntheticTyParamKind::ImplTrait
|
||||
| hir::SyntheticTyParamKind::FromAttr,
|
||||
),
|
||||
..
|
||||
}
|
||||
)
|
||||
});
|
||||
|
||||
// (#83606): Do not emit a suggestion if the parent has an `impl Trait`
|
||||
// as an argument otherwise it will cause the E0282 error.
|
||||
if !has_impl_trait || self.tcx.features().explicit_generic_args_with_impl_trait {
|
||||
if !self.tcx.generics_of(parent_data.def_id).has_impl_trait()
|
||||
|| self.tcx.features().explicit_generic_args_with_impl_trait
|
||||
{
|
||||
err.span_suggestion_verbose(
|
||||
span,
|
||||
"consider specifying the const argument",
|
||||
@ -814,7 +802,7 @@ impl<'a, 'tcx> InferCtxt<'a, 'tcx> {
|
||||
let borrow = typeck_results.borrow();
|
||||
if let Some((DefKind::AssocFn, did)) = borrow.type_dependent_def(e.hir_id) {
|
||||
let generics = self.tcx.generics_of(did);
|
||||
if !generics.params.is_empty() {
|
||||
if !generics.params.is_empty() && !generics.has_impl_trait() {
|
||||
err.span_suggestion_verbose(
|
||||
segment.ident.span.shrink_to_hi(),
|
||||
&format!(
|
||||
|
@ -198,6 +198,21 @@ impl<'tcx> Generics {
|
||||
_ => bug!("expected const parameter, but found another generic parameter"),
|
||||
}
|
||||
}
|
||||
|
||||
/// Returns `true` if `params` has `impl Trait`.
|
||||
pub fn has_impl_trait(&'tcx self) -> bool {
|
||||
self.params.iter().any(|param| {
|
||||
matches!(
|
||||
param.kind,
|
||||
ty::GenericParamDefKind::Type {
|
||||
synthetic: Some(
|
||||
hir::SyntheticTyParamKind::ImplTrait | hir::SyntheticTyParamKind::FromAttr,
|
||||
),
|
||||
..
|
||||
}
|
||||
)
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
/// Bounds on generics.
|
||||
|
@ -1603,6 +1603,7 @@ impl<'a, 'tcx> InferCtxtPrivExt<'tcx> for InferCtxt<'a, 'tcx> {
|
||||
let generics = self.tcx.generics_of(*def_id);
|
||||
if generics.params.iter().any(|p| p.name != kw::SelfUpper)
|
||||
&& !snippet.ends_with('>')
|
||||
&& !generics.has_impl_trait()
|
||||
{
|
||||
// FIXME: To avoid spurious suggestions in functions where type arguments
|
||||
// where already supplied, we check the snippet to make sure it doesn't
|
||||
|
@ -647,17 +647,7 @@ impl<'o, 'tcx> dyn AstConv<'tcx> + 'o {
|
||||
return false;
|
||||
}
|
||||
|
||||
let impl_trait = generics.params.iter().any(|param| {
|
||||
matches!(
|
||||
param.kind,
|
||||
ty::GenericParamDefKind::Type {
|
||||
synthetic: Some(
|
||||
hir::SyntheticTyParamKind::ImplTrait | hir::SyntheticTyParamKind::FromAttr,
|
||||
),
|
||||
..
|
||||
}
|
||||
)
|
||||
});
|
||||
let impl_trait = generics.has_impl_trait();
|
||||
|
||||
if impl_trait {
|
||||
let spans = seg
|
||||
|
9
src/test/ui/inference/issue-86162-1.rs
Normal file
9
src/test/ui/inference/issue-86162-1.rs
Normal file
@ -0,0 +1,9 @@
|
||||
// Regression test of #86162.
|
||||
|
||||
fn foo(x: impl Clone) {}
|
||||
fn gen<T>() -> T { todo!() }
|
||||
|
||||
fn main() {
|
||||
foo(gen()); //<- Do not suggest `foo::<impl Clone>()`!
|
||||
//~^ ERROR: type annotations needed
|
||||
}
|
14
src/test/ui/inference/issue-86162-1.stderr
Normal file
14
src/test/ui/inference/issue-86162-1.stderr
Normal file
@ -0,0 +1,14 @@
|
||||
error[E0283]: type annotations needed
|
||||
--> $DIR/issue-86162-1.rs:7:5
|
||||
|
|
||||
LL | fn foo(x: impl Clone) {}
|
||||
| ----- required by this bound in `foo`
|
||||
...
|
||||
LL | foo(gen()); //<- Do not suggest `foo::<impl Clone>()`!
|
||||
| ^^^ cannot infer type for type parameter `impl Clone` declared on the function `foo`
|
||||
|
|
||||
= note: cannot satisfy `_: Clone`
|
||||
|
||||
error: aborting due to previous error
|
||||
|
||||
For more information about this error, try `rustc --explain E0283`.
|
14
src/test/ui/inference/issue-86162-2.rs
Normal file
14
src/test/ui/inference/issue-86162-2.rs
Normal file
@ -0,0 +1,14 @@
|
||||
// Regression test of #86162.
|
||||
|
||||
fn gen<T>() -> T { todo!() }
|
||||
|
||||
struct Foo;
|
||||
|
||||
impl Foo {
|
||||
fn bar(x: impl Clone) {}
|
||||
}
|
||||
|
||||
fn main() {
|
||||
Foo::bar(gen()); //<- Do not suggest `Foo::bar::<impl Clone>()`!
|
||||
//~^ ERROR: type annotations needed
|
||||
}
|
14
src/test/ui/inference/issue-86162-2.stderr
Normal file
14
src/test/ui/inference/issue-86162-2.stderr
Normal file
@ -0,0 +1,14 @@
|
||||
error[E0283]: type annotations needed
|
||||
--> $DIR/issue-86162-2.rs:12:5
|
||||
|
|
||||
LL | fn bar(x: impl Clone) {}
|
||||
| ----- required by this bound in `Foo::bar`
|
||||
...
|
||||
LL | Foo::bar(gen()); //<- Do not suggest `Foo::bar::<impl Clone>()`!
|
||||
| ^^^^^^^^ cannot infer type for type parameter `impl Clone` declared on the associated function `bar`
|
||||
|
|
||||
= note: cannot satisfy `_: Clone`
|
||||
|
||||
error: aborting due to previous error
|
||||
|
||||
For more information about this error, try `rustc --explain E0283`.
|
Loading…
Reference in New Issue
Block a user