Rollup merge of #56755 - estebank:impl-trait-lt-sugg, r=cramertj
Account for `impl Trait` when suggesting lifetime Fix https://github.com/rust-lang/rust/issues/56745
This commit is contained in:
commit
c530e31245
4 changed files with 75 additions and 11 deletions
|
@ -1095,7 +1095,8 @@ impl<'a, 'gcx, 'tcx> InferCtxt<'a, 'gcx, 'tcx> {
|
|||
let sp = hir.span(id);
|
||||
// `sp` only covers `T`, change it so that it covers
|
||||
// `T:` when appropriate
|
||||
let sp = if has_bounds {
|
||||
let is_impl_trait = bound_kind.to_string().starts_with("impl ");
|
||||
let sp = if has_bounds && !is_impl_trait {
|
||||
sp.to(self.tcx
|
||||
.sess
|
||||
.source_map()
|
||||
|
@ -1103,7 +1104,7 @@ impl<'a, 'gcx, 'tcx> InferCtxt<'a, 'gcx, 'tcx> {
|
|||
} else {
|
||||
sp
|
||||
};
|
||||
(sp, has_bounds)
|
||||
(sp, has_bounds, is_impl_trait)
|
||||
})
|
||||
} else {
|
||||
None
|
||||
|
@ -1136,25 +1137,33 @@ impl<'a, 'gcx, 'tcx> InferCtxt<'a, 'gcx, 'tcx> {
|
|||
|
||||
fn binding_suggestion<'tcx, S: fmt::Display>(
|
||||
err: &mut DiagnosticBuilder<'tcx>,
|
||||
type_param_span: Option<(Span, bool)>,
|
||||
type_param_span: Option<(Span, bool, bool)>,
|
||||
bound_kind: GenericKind<'tcx>,
|
||||
sub: S,
|
||||
) {
|
||||
let consider = &format!(
|
||||
"consider adding an explicit lifetime bound `{}: {}`...",
|
||||
bound_kind, sub
|
||||
let consider = format!(
|
||||
"consider adding an explicit lifetime bound {}",
|
||||
if type_param_span.map(|(_, _, is_impl_trait)| is_impl_trait).unwrap_or(false) {
|
||||
format!(" `{}` to `{}`...", sub, bound_kind)
|
||||
} else {
|
||||
format!("`{}: {}`...", bound_kind, sub)
|
||||
},
|
||||
);
|
||||
if let Some((sp, has_lifetimes)) = type_param_span {
|
||||
let tail = if has_lifetimes { " + " } else { "" };
|
||||
let suggestion = format!("{}: {}{}", bound_kind, sub, tail);
|
||||
if let Some((sp, has_lifetimes, is_impl_trait)) = type_param_span {
|
||||
let suggestion = if is_impl_trait {
|
||||
format!("{} + {}", bound_kind, sub)
|
||||
} else {
|
||||
let tail = if has_lifetimes { " + " } else { "" };
|
||||
format!("{}: {}{}", bound_kind, sub, tail)
|
||||
};
|
||||
err.span_suggestion_short_with_applicability(
|
||||
sp,
|
||||
consider,
|
||||
&consider,
|
||||
suggestion,
|
||||
Applicability::MaybeIncorrect, // Issue #41966
|
||||
);
|
||||
} else {
|
||||
err.help(consider);
|
||||
err.help(&consider);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
18
src/test/ui/suggestions/suggest-impl-trait-lifetime.fixed
Normal file
18
src/test/ui/suggestions/suggest-impl-trait-lifetime.fixed
Normal file
|
@ -0,0 +1,18 @@
|
|||
// run-rustfix
|
||||
|
||||
use std::fmt::Debug;
|
||||
|
||||
fn foo(d: impl Debug + 'static) {
|
||||
//~^ HELP consider adding an explicit lifetime bound `'static` to `impl Debug`
|
||||
bar(d);
|
||||
//~^ ERROR the parameter type `impl Debug` may not live long enough
|
||||
//~| NOTE ...so that the type `impl Debug` will meet its required lifetime bounds
|
||||
}
|
||||
|
||||
fn bar(d: impl Debug + 'static) {
|
||||
println!("{:?}", d)
|
||||
}
|
||||
|
||||
fn main() {
|
||||
foo("hi");
|
||||
}
|
18
src/test/ui/suggestions/suggest-impl-trait-lifetime.rs
Normal file
18
src/test/ui/suggestions/suggest-impl-trait-lifetime.rs
Normal file
|
@ -0,0 +1,18 @@
|
|||
// run-rustfix
|
||||
|
||||
use std::fmt::Debug;
|
||||
|
||||
fn foo(d: impl Debug) {
|
||||
//~^ HELP consider adding an explicit lifetime bound `'static` to `impl Debug`
|
||||
bar(d);
|
||||
//~^ ERROR the parameter type `impl Debug` may not live long enough
|
||||
//~| NOTE ...so that the type `impl Debug` will meet its required lifetime bounds
|
||||
}
|
||||
|
||||
fn bar(d: impl Debug + 'static) {
|
||||
println!("{:?}", d)
|
||||
}
|
||||
|
||||
fn main() {
|
||||
foo("hi");
|
||||
}
|
19
src/test/ui/suggestions/suggest-impl-trait-lifetime.stderr
Normal file
19
src/test/ui/suggestions/suggest-impl-trait-lifetime.stderr
Normal file
|
@ -0,0 +1,19 @@
|
|||
error[E0310]: the parameter type `impl Debug` may not live long enough
|
||||
--> $DIR/suggest-impl-trait-lifetime.rs:7:5
|
||||
|
|
||||
LL | bar(d);
|
||||
| ^^^
|
||||
|
|
||||
note: ...so that the type `impl Debug` will meet its required lifetime bounds
|
||||
--> $DIR/suggest-impl-trait-lifetime.rs:7:5
|
||||
|
|
||||
LL | bar(d);
|
||||
| ^^^
|
||||
help: consider adding an explicit lifetime bound `'static` to `impl Debug`...
|
||||
|
|
||||
LL | fn foo(d: impl Debug + 'static) {
|
||||
| ^^^^^^^^^^^^^^^^^^^^
|
||||
|
||||
error: aborting due to previous error
|
||||
|
||||
For more information about this error, try `rustc --explain E0310`.
|
Loading…
Add table
Add a link
Reference in a new issue