Rollup merge of #91764 - cjgillot:elide-anyway, r=jackh726
Do not ICE when suggesting elided lifetimes on non-existent spans. Fixes https://github.com/rust-lang/rust/issues/91763 r? `@jackh726`
This commit is contained in:
commit
72b6a91fe7
6 changed files with 78 additions and 21 deletions
|
@ -22,9 +22,7 @@ use ast::util::unicode::TEXT_FLOW_CONTROL_CHARS;
|
||||||
use rustc_ast as ast;
|
use rustc_ast as ast;
|
||||||
use rustc_data_structures::fx::FxHashMap;
|
use rustc_data_structures::fx::FxHashMap;
|
||||||
use rustc_data_structures::sync;
|
use rustc_data_structures::sync;
|
||||||
use rustc_errors::{
|
use rustc_errors::{struct_span_err, Applicability, SuggestionStyle};
|
||||||
add_elided_lifetime_in_path_suggestion, struct_span_err, Applicability, SuggestionStyle,
|
|
||||||
};
|
|
||||||
use rustc_hir as hir;
|
use rustc_hir as hir;
|
||||||
use rustc_hir::def::Res;
|
use rustc_hir::def::Res;
|
||||||
use rustc_hir::def_id::{CrateNum, DefId};
|
use rustc_hir::def_id::{CrateNum, DefId};
|
||||||
|
@ -670,23 +668,6 @@ pub trait LintContext: Sized {
|
||||||
) => {
|
) => {
|
||||||
db.span_note(span_def, "the macro is defined here");
|
db.span_note(span_def, "the macro is defined here");
|
||||||
}
|
}
|
||||||
BuiltinLintDiagnostics::ElidedLifetimesInPaths(
|
|
||||||
n,
|
|
||||||
path_span,
|
|
||||||
incl_angl_brckt,
|
|
||||||
insertion_span,
|
|
||||||
anon_lts,
|
|
||||||
) => {
|
|
||||||
add_elided_lifetime_in_path_suggestion(
|
|
||||||
sess.source_map(),
|
|
||||||
&mut db,
|
|
||||||
n,
|
|
||||||
path_span,
|
|
||||||
incl_angl_brckt,
|
|
||||||
insertion_span,
|
|
||||||
anon_lts,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
BuiltinLintDiagnostics::UnknownCrateTypes(span, note, sugg) => {
|
BuiltinLintDiagnostics::UnknownCrateTypes(span, note, sugg) => {
|
||||||
db.span_suggestion(span, ¬e, sugg, Applicability::MaybeIncorrect);
|
db.span_suggestion(span, ¬e, sugg, Applicability::MaybeIncorrect);
|
||||||
}
|
}
|
||||||
|
|
|
@ -289,7 +289,6 @@ pub enum BuiltinLintDiagnostics {
|
||||||
AbsPathWithModule(Span),
|
AbsPathWithModule(Span),
|
||||||
ProcMacroDeriveResolutionFallback(Span),
|
ProcMacroDeriveResolutionFallback(Span),
|
||||||
MacroExpandedMacroExportsAccessedByAbsolutePaths(Span),
|
MacroExpandedMacroExportsAccessedByAbsolutePaths(Span),
|
||||||
ElidedLifetimesInPaths(usize, Span, bool, Span, String),
|
|
||||||
UnknownCrateTypes(Span, String, String),
|
UnknownCrateTypes(Span, String, String),
|
||||||
UnusedImports(String, Vec<(Span, String)>),
|
UnusedImports(String, Vec<(Span, String)>),
|
||||||
RedundantImport(Vec<(Span, bool)>, Ident),
|
RedundantImport(Vec<(Span, bool)>, Ident),
|
||||||
|
|
|
@ -2115,6 +2115,11 @@ impl<'tcx> LifetimeContext<'_, 'tcx> {
|
||||||
})
|
})
|
||||||
.map(|(formatter, span)| (*span, formatter(name)))
|
.map(|(formatter, span)| (*span, formatter(name)))
|
||||||
.collect();
|
.collect();
|
||||||
|
if spans_suggs.is_empty() {
|
||||||
|
// If all the spans come from macros, we cannot extract snippets and then
|
||||||
|
// `formatters` only contains None and `spans_suggs` is empty.
|
||||||
|
return;
|
||||||
|
}
|
||||||
err.multipart_suggestion_verbose(
|
err.multipart_suggestion_verbose(
|
||||||
&format!(
|
&format!(
|
||||||
"consider using the `{}` lifetime",
|
"consider using the `{}` lifetime",
|
||||||
|
|
47
src/test/ui/lifetimes/auxiliary/issue-91763-aux.rs
Normal file
47
src/test/ui/lifetimes/auxiliary/issue-91763-aux.rs
Normal file
|
@ -0,0 +1,47 @@
|
||||||
|
// force-host
|
||||||
|
// no-prefer-dynamic
|
||||||
|
|
||||||
|
#![crate_type = "proc-macro"]
|
||||||
|
|
||||||
|
//#![feature(proc_macro_diagnostic, proc_macro_span, proc_macro_def_site)]
|
||||||
|
|
||||||
|
extern crate proc_macro;
|
||||||
|
|
||||||
|
use proc_macro::{Delimiter, Group, Ident, Punct, Spacing, Span, TokenStream, TokenTree};
|
||||||
|
use std::iter::FromIterator;
|
||||||
|
|
||||||
|
#[proc_macro_attribute]
|
||||||
|
pub fn repro(_args: TokenStream, input: TokenStream) -> TokenStream {
|
||||||
|
let call_site = Span::call_site();
|
||||||
|
let span = input.into_iter().nth(8).unwrap().span();
|
||||||
|
|
||||||
|
//fn f(_: &::std::fmt::Formatter) {}
|
||||||
|
TokenStream::from_iter([
|
||||||
|
TokenTree::Ident(Ident::new("fn", call_site)),
|
||||||
|
TokenTree::Ident(Ident::new("f", call_site)),
|
||||||
|
TokenTree::Group(Group::new(
|
||||||
|
Delimiter::Parenthesis,
|
||||||
|
TokenStream::from_iter([
|
||||||
|
TokenTree::Ident(Ident::new("_", call_site)),
|
||||||
|
TokenTree::Punct(punct(':', Spacing::Alone, call_site)),
|
||||||
|
TokenTree::Punct(punct('&', Spacing::Alone, call_site)),
|
||||||
|
TokenTree::Punct(punct(':', Spacing::Joint, span)),
|
||||||
|
TokenTree::Punct(punct(':', Spacing::Alone, span)),
|
||||||
|
TokenTree::Ident(Ident::new("std", span)),
|
||||||
|
TokenTree::Punct(punct(':', Spacing::Joint, span)),
|
||||||
|
TokenTree::Punct(punct(':', Spacing::Alone, span)),
|
||||||
|
TokenTree::Ident(Ident::new("fmt", span)),
|
||||||
|
TokenTree::Punct(punct(':', Spacing::Joint, span)),
|
||||||
|
TokenTree::Punct(punct(':', Spacing::Alone, span)),
|
||||||
|
TokenTree::Ident(Ident::new("Formatter", span)),
|
||||||
|
]),
|
||||||
|
)),
|
||||||
|
TokenTree::Group(Group::new(Delimiter::Brace, TokenStream::new())),
|
||||||
|
])
|
||||||
|
}
|
||||||
|
|
||||||
|
fn punct(ch: char, spacing: Spacing, span: Span) -> Punct {
|
||||||
|
let mut punct = Punct::new(ch, spacing);
|
||||||
|
punct.set_span(span);
|
||||||
|
punct
|
||||||
|
}
|
11
src/test/ui/lifetimes/issue-91763.rs
Normal file
11
src/test/ui/lifetimes/issue-91763.rs
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
// aux-build:issue-91763-aux.rs
|
||||||
|
|
||||||
|
#![deny(elided_lifetimes_in_paths)]
|
||||||
|
|
||||||
|
extern crate issue_91763_aux;
|
||||||
|
|
||||||
|
#[issue_91763_aux::repro]
|
||||||
|
fn f() -> Ptr<Thing>;
|
||||||
|
//~^ ERROR hidden lifetime parameters in types are deprecated
|
||||||
|
|
||||||
|
fn main() {}
|
14
src/test/ui/lifetimes/issue-91763.stderr
Normal file
14
src/test/ui/lifetimes/issue-91763.stderr
Normal file
|
@ -0,0 +1,14 @@
|
||||||
|
error: hidden lifetime parameters in types are deprecated
|
||||||
|
--> $DIR/issue-91763.rs:8:20
|
||||||
|
|
|
||||||
|
LL | fn f() -> Ptr<Thing>;
|
||||||
|
| ^ expected named lifetime parameter
|
||||||
|
|
|
||||||
|
note: the lint level is defined here
|
||||||
|
--> $DIR/issue-91763.rs:3:9
|
||||||
|
|
|
||||||
|
LL | #![deny(elided_lifetimes_in_paths)]
|
||||||
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
error: aborting due to previous error
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue