1use rustc_data_structures::fx::{FxHashSet, FxIndexSet};
2use rustc_errors::codes::*;
3use rustc_errors::formatting::DiagMessageAddArg;
4use rustc_errors::{
5 Applicability, Diag, DiagCtxtHandle, DiagMessage, DiagStyledString, Diagnostic,
6 EmissionGuarantee, IntoDiagArg, Level, MultiSpan, Subdiagnostic, msg,
7};
8use rustc_hir::def::DefKind;
9use rustc_hir::def_id::{DefId, LocalDefId};
10use rustc_hir::intravisit::{Visitor, VisitorExt, walk_ty};
11use rustc_hir::{self as hir, AmbigArg, FnRetTy, GenericParamKind, Node};
12use rustc_macros::{Diagnostic, Subdiagnostic};
13use rustc_middle::ty::print::{PrintTraitRefExt as _, TraitRefPrintOnlyTraitPath};
14use rustc_middle::ty::{self, Binder, ClosureKind, FnSig, GenericArg, Region, Ty, TyCtxt};
15use rustc_span::{BytePos, Ident, Span, Symbol, kw, sym};
16
17use crate::error_reporting::infer::ObligationCauseAsDiagArg;
18use crate::error_reporting::infer::need_type_info::UnderspecifiedArgKind;
19use crate::error_reporting::infer::nice_region_error::placeholder_error::Highlighted;
20
21pub(crate) mod note_and_explain;
22
23#[derive(const _: () =
{
impl<'_sess, 'a, G> rustc_errors::Diagnostic<'_sess, G> for
UnableToConstructConstantValue<'a> where
G: rustc_errors::EmissionGuarantee {
#[track_caller]
fn into_diag(self, dcx: rustc_errors::DiagCtxtHandle<'_sess>,
level: rustc_errors::Level) -> rustc_errors::Diag<'_sess, G> {
match self {
UnableToConstructConstantValue {
span: __binding_0, unevaluated: __binding_1 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("unable to construct a constant value for the unevaluated constant {$unevaluated}")));
;
diag.arg("unevaluated", __binding_1);
diag.span(__binding_0);
diag
}
}
}
}
};Diagnostic)]
24#[diag("unable to construct a constant value for the unevaluated constant {$unevaluated}")]
25pub(crate) struct UnableToConstructConstantValue<'a> {
26 #[primary_span]
27 pub span: Span,
28 pub unevaluated: ty::UnevaluatedConst<'a>,
29}
30
31pub(crate) struct NegativePositiveConflict<'tcx> {
32 pub impl_span: Span,
33 pub trait_desc: ty::TraitRef<'tcx>,
34 pub self_ty: Option<Ty<'tcx>>,
35 pub negative_impl_span: Result<Span, Symbol>,
36 pub positive_impl_span: Result<Span, Symbol>,
37}
38
39impl<G: EmissionGuarantee> Diagnostic<'_, G> for NegativePositiveConflict<'_> {
40 #[track_caller]
41 fn into_diag(self, dcx: DiagCtxtHandle<'_>, level: Level) -> Diag<'_, G> {
42 let mut diag = Diag::new(
43 dcx,
44 level,
45 rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("found both positive and negative implementation of trait `{$trait_desc}`{$self_desc ->\n [none] {\"\"}\n *[default] {\" \"}for type `{$self_desc}`\n }:"))msg!(
46 "found both positive and negative implementation of trait `{$trait_desc}`{$self_desc ->
47 [none] {\"\"}
48 *[default] {\" \"}for type `{$self_desc}`
49 }:"
50 ),
51 );
52 diag.arg("trait_desc", self.trait_desc.print_only_trait_path().to_string());
53 diag.arg("self_desc", self.self_ty.map_or_else(|| "none".to_string(), |ty| ty.to_string()));
54 diag.span(self.impl_span);
55 diag.code(E0751);
56 match self.negative_impl_span {
57 Ok(span) => {
58 diag.span_label(span, rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("negative implementation here"))msg!("negative implementation here"));
59 }
60 Err(cname) => {
61 diag.note(rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("negative implementation in crate `{$negative_impl_cname}`"))msg!("negative implementation in crate `{$negative_impl_cname}`"));
62 diag.arg("negative_impl_cname", cname.to_string());
63 }
64 }
65 match self.positive_impl_span {
66 Ok(span) => {
67 diag.span_label(span, rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("positive implementation here"))msg!("positive implementation here"));
68 }
69 Err(cname) => {
70 diag.note(rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("positive implementation in crate `{$positive_impl_cname}`"))msg!("positive implementation in crate `{$positive_impl_cname}`"));
71 diag.arg("positive_impl_cname", cname.to_string());
72 }
73 }
74 diag
75 }
76}
77
78#[derive(const _: () =
{
impl<'_sess, G> rustc_errors::Diagnostic<'_sess, G> for
InherentProjectionNormalizationOverflow where
G: rustc_errors::EmissionGuarantee {
#[track_caller]
fn into_diag(self, dcx: rustc_errors::DiagCtxtHandle<'_sess>,
level: rustc_errors::Level) -> rustc_errors::Diag<'_sess, G> {
match self {
InherentProjectionNormalizationOverflow {
span: __binding_0, ty: __binding_1 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("overflow evaluating associated type `{$ty}`")));
;
diag.arg("ty", __binding_1);
diag.span(__binding_0);
diag
}
}
}
}
};Diagnostic)]
79#[diag("overflow evaluating associated type `{$ty}`")]
80pub(crate) struct InherentProjectionNormalizationOverflow {
81 #[primary_span]
82 pub span: Span,
83 pub ty: String,
84}
85
86pub(crate) enum AdjustSignatureBorrow {
87 Borrow { to_borrow: Vec<(Span, String)> },
88 RemoveBorrow { remove_borrow: Vec<(Span, String)> },
89}
90
91impl Subdiagnostic for AdjustSignatureBorrow {
92 fn add_to_diag<G: EmissionGuarantee>(self, diag: &mut Diag<'_, G>) {
93 match self {
94 AdjustSignatureBorrow::Borrow { to_borrow } => {
95 diag.arg("borrow_len", to_borrow.len());
96 diag.multipart_suggestion(
97 rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("consider adjusting the signature so it borrows its {$borrow_len ->\n [one] argument\n *[other] arguments\n }"))msg!(
98 "consider adjusting the signature so it borrows its {$borrow_len ->
99 [one] argument
100 *[other] arguments
101 }"
102 ),
103 to_borrow,
104 Applicability::MaybeIncorrect,
105 );
106 }
107 AdjustSignatureBorrow::RemoveBorrow { remove_borrow } => {
108 diag.arg("remove_borrow_len", remove_borrow.len());
109 diag.multipart_suggestion(
110 rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("consider adjusting the signature so it does not borrow its {$remove_borrow_len ->\n [one] argument\n *[other] arguments\n }"))msg!(
111 "consider adjusting the signature so it does not borrow its {$remove_borrow_len ->
112 [one] argument
113 *[other] arguments
114 }"
115 ),
116 remove_borrow,
117 Applicability::MaybeIncorrect,
118 );
119 }
120 }
121 }
122}
123
124#[derive(const _: () =
{
impl<'_sess, G> rustc_errors::Diagnostic<'_sess, G> for
ClosureKindMismatch where G: rustc_errors::EmissionGuarantee {
#[track_caller]
fn into_diag(self, dcx: rustc_errors::DiagCtxtHandle<'_sess>,
level: rustc_errors::Level) -> rustc_errors::Diag<'_sess, G> {
match self {
ClosureKindMismatch {
closure_span: __binding_0,
expected: __binding_1,
found: __binding_2,
cause_span: __binding_3,
trait_prefix: __binding_4,
fn_once_label: __binding_5,
fn_mut_label: __binding_6 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("expected a closure that implements the `{$trait_prefix}{$expected}` trait, but this closure only implements `{$trait_prefix}{$found}`")));
diag.code(E0525);
;
diag.arg("expected", __binding_1);
diag.arg("found", __binding_2);
diag.arg("trait_prefix", __binding_4);
diag.span(__binding_0);
diag.span_label(__binding_0,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("this closure implements `{$trait_prefix}{$found}`, not `{$trait_prefix}{$expected}`")));
diag.span_label(__binding_3,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("the requirement to implement `{$trait_prefix}{$expected}` derives from here")));
if let Some(__binding_5) = __binding_5 {
diag.subdiagnostic(__binding_5);
}
if let Some(__binding_6) = __binding_6 {
diag.subdiagnostic(__binding_6);
}
diag
}
}
}
}
};Diagnostic)]
125#[diag("expected a closure that implements the `{$trait_prefix}{$expected}` trait, but this closure only implements `{$trait_prefix}{$found}`", code = E0525)]
126pub(crate) struct ClosureKindMismatch {
127 #[primary_span]
128 #[label("this closure implements `{$trait_prefix}{$found}`, not `{$trait_prefix}{$expected}`")]
129 pub closure_span: Span,
130 pub expected: ClosureKind,
131 pub found: ClosureKind,
132 #[label("the requirement to implement `{$trait_prefix}{$expected}` derives from here")]
133 pub cause_span: Span,
134
135 pub trait_prefix: &'static str,
136
137 #[subdiagnostic]
138 pub fn_once_label: Option<ClosureFnOnceLabel>,
139
140 #[subdiagnostic]
141 pub fn_mut_label: Option<ClosureFnMutLabel>,
142}
143
144#[derive(const _: () =
{
impl rustc_errors::Subdiagnostic for ClosureFnOnceLabel {
fn add_to_diag<__G>(self, diag: &mut rustc_errors::Diag<'_, __G>)
where __G: rustc_errors::EmissionGuarantee {
match self {
ClosureFnOnceLabel {
span: __binding_0,
place: __binding_1,
trait_prefix: __binding_2 } => {
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("place".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("trait_prefix".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("closure is `{$trait_prefix}FnOnce` because it moves the variable `{$place}` out of its environment")),
&sub_args);
diag.span_label(__binding_0, __message);
}
}
}
}
};Subdiagnostic)]
145#[label(
146 "closure is `{$trait_prefix}FnOnce` because it moves the variable `{$place}` out of its environment"
147)]
148pub(crate) struct ClosureFnOnceLabel {
149 #[primary_span]
150 pub span: Span,
151 pub place: String,
152 pub trait_prefix: &'static str,
153}
154
155#[derive(const _: () =
{
impl rustc_errors::Subdiagnostic for ClosureFnMutLabel {
fn add_to_diag<__G>(self, diag: &mut rustc_errors::Diag<'_, __G>)
where __G: rustc_errors::EmissionGuarantee {
match self {
ClosureFnMutLabel {
span: __binding_0,
place: __binding_1,
trait_prefix: __binding_2 } => {
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("place".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("trait_prefix".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("closure is `{$trait_prefix}FnMut` because it mutates the variable `{$place}` here")),
&sub_args);
diag.span_label(__binding_0, __message);
}
}
}
}
};Subdiagnostic)]
156#[label("closure is `{$trait_prefix}FnMut` because it mutates the variable `{$place}` here")]
157pub(crate) struct ClosureFnMutLabel {
158 #[primary_span]
159 pub span: Span,
160 pub place: String,
161 pub trait_prefix: &'static str,
162}
163
164#[derive(const _: () =
{
impl<'_sess, G> rustc_errors::Diagnostic<'_sess, G> for
CoroClosureNotFn where G: rustc_errors::EmissionGuarantee {
#[track_caller]
fn into_diag(self, dcx: rustc_errors::DiagCtxtHandle<'_sess>,
level: rustc_errors::Level) -> rustc_errors::Diag<'_sess, G> {
match self {
CoroClosureNotFn {
span: __binding_0, kind: __binding_1, coro_kind: __binding_2
} => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("{$coro_kind}closure does not implement `{$kind}` because it captures state from its environment")));
;
diag.arg("kind", __binding_1);
diag.arg("coro_kind", __binding_2);
diag.span(__binding_0);
diag
}
}
}
}
};Diagnostic)]
165#[diag(
166 "{$coro_kind}closure does not implement `{$kind}` because it captures state from its environment"
167)]
168pub(crate) struct CoroClosureNotFn {
169 #[primary_span]
170 pub span: Span,
171 pub kind: &'static str,
172 pub coro_kind: String,
173}
174
175#[derive(const _: () =
{
impl<'_sess, 'a, G> rustc_errors::Diagnostic<'_sess, G> for
AnnotationRequired<'a> where G: rustc_errors::EmissionGuarantee {
#[track_caller]
fn into_diag(self, dcx: rustc_errors::DiagCtxtHandle<'_sess>,
level: rustc_errors::Level) -> rustc_errors::Diag<'_sess, G> {
match self {
AnnotationRequired {
span: __binding_0,
source_kind: __binding_1,
source_name: __binding_2,
failure_span: __binding_3,
bad_label: __binding_4,
infer_subdiags: __binding_5,
multi_suggestions: __binding_6 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("{$source_kind ->\n[closure] type annotations needed for the closure `{$source_name}`\n[normal] type annotations needed for `{$source_name}`\n*[other] type annotations needed\n}")));
diag.code(E0282);
;
diag.arg("source_kind", __binding_1);
diag.arg("source_name", __binding_2);
diag.span(__binding_0);
if let Some(__binding_3) = __binding_3 {
diag.span_label(__binding_3,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("type must be known at this point")));
}
if let Some(__binding_4) = __binding_4 {
diag.subdiagnostic(__binding_4);
}
for __binding_5 in __binding_5 {
diag.subdiagnostic(__binding_5);
}
for __binding_6 in __binding_6 {
diag.subdiagnostic(__binding_6);
}
diag
}
}
}
}
};Diagnostic)]
176#[diag("{$source_kind ->
177[closure] type annotations needed for the closure `{$source_name}`
178[normal] type annotations needed for `{$source_name}`
179*[other] type annotations needed
180}", code = E0282)]
181pub(crate) struct AnnotationRequired<'a> {
182 #[primary_span]
183 pub span: Span,
184 pub source_kind: &'static str,
185 pub source_name: &'a str,
186 #[label("type must be known at this point")]
187 pub failure_span: Option<Span>,
188 #[subdiagnostic]
189 pub bad_label: Option<InferenceBadError<'a>>,
190 #[subdiagnostic]
191 pub infer_subdiags: Vec<SourceKindSubdiag<'a>>,
192 #[subdiagnostic]
193 pub multi_suggestions: Vec<SourceKindMultiSuggestion<'a>>,
194}
195
196#[derive(const _: () =
{
impl<'_sess, 'a, G> rustc_errors::Diagnostic<'_sess, G> for
AmbiguousImpl<'a> where G: rustc_errors::EmissionGuarantee {
#[track_caller]
fn into_diag(self, dcx: rustc_errors::DiagCtxtHandle<'_sess>,
level: rustc_errors::Level) -> rustc_errors::Diag<'_sess, G> {
match self {
AmbiguousImpl {
span: __binding_0,
source_kind: __binding_1,
source_name: __binding_2,
failure_span: __binding_3,
bad_label: __binding_4,
infer_subdiags: __binding_5,
multi_suggestions: __binding_6 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("{$source_kind ->\n[closure] type annotations needed for the closure `{$source_name}`\n[normal] type annotations needed for `{$source_name}`\n*[other] type annotations needed\n}")));
diag.code(E0283);
;
diag.arg("source_kind", __binding_1);
diag.arg("source_name", __binding_2);
diag.span(__binding_0);
if let Some(__binding_3) = __binding_3 {
diag.span_label(__binding_3,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("type must be known at this point")));
}
if let Some(__binding_4) = __binding_4 {
diag.subdiagnostic(__binding_4);
}
for __binding_5 in __binding_5 {
diag.subdiagnostic(__binding_5);
}
for __binding_6 in __binding_6 {
diag.subdiagnostic(__binding_6);
}
diag
}
}
}
}
};Diagnostic)]
198#[diag("{$source_kind ->
199[closure] type annotations needed for the closure `{$source_name}`
200[normal] type annotations needed for `{$source_name}`
201*[other] type annotations needed
202}", code = E0283)]
203pub(crate) struct AmbiguousImpl<'a> {
204 #[primary_span]
205 pub span: Span,
206 pub source_kind: &'static str,
207 pub source_name: &'a str,
208 #[label("type must be known at this point")]
209 pub failure_span: Option<Span>,
210 #[subdiagnostic]
211 pub bad_label: Option<InferenceBadError<'a>>,
212 #[subdiagnostic]
213 pub infer_subdiags: Vec<SourceKindSubdiag<'a>>,
214 #[subdiagnostic]
215 pub multi_suggestions: Vec<SourceKindMultiSuggestion<'a>>,
216}
217
218#[derive(const _: () =
{
impl<'_sess, 'a, G> rustc_errors::Diagnostic<'_sess, G> for
AmbiguousReturn<'a> where G: rustc_errors::EmissionGuarantee {
#[track_caller]
fn into_diag(self, dcx: rustc_errors::DiagCtxtHandle<'_sess>,
level: rustc_errors::Level) -> rustc_errors::Diag<'_sess, G> {
match self {
AmbiguousReturn {
span: __binding_0,
source_kind: __binding_1,
source_name: __binding_2,
failure_span: __binding_3,
bad_label: __binding_4,
infer_subdiags: __binding_5,
multi_suggestions: __binding_6 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("{$source_kind ->\n[closure] type annotations needed for the closure `{$source_name}`\n[normal] type annotations needed for `{$source_name}`\n*[other] type annotations needed\n}")));
diag.code(E0284);
;
diag.arg("source_kind", __binding_1);
diag.arg("source_name", __binding_2);
diag.span(__binding_0);
if let Some(__binding_3) = __binding_3 {
diag.span_label(__binding_3,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("type must be known at this point")));
}
if let Some(__binding_4) = __binding_4 {
diag.subdiagnostic(__binding_4);
}
for __binding_5 in __binding_5 {
diag.subdiagnostic(__binding_5);
}
for __binding_6 in __binding_6 {
diag.subdiagnostic(__binding_6);
}
diag
}
}
}
}
};Diagnostic)]
220#[diag("{$source_kind ->
221[closure] type annotations needed for the closure `{$source_name}`
222[normal] type annotations needed for `{$source_name}`
223*[other] type annotations needed
224}", code = E0284)]
225pub(crate) struct AmbiguousReturn<'a> {
226 #[primary_span]
227 pub span: Span,
228 pub source_kind: &'static str,
229 pub source_name: &'a str,
230 #[label("type must be known at this point")]
231 pub failure_span: Option<Span>,
232 #[subdiagnostic]
233 pub bad_label: Option<InferenceBadError<'a>>,
234 #[subdiagnostic]
235 pub infer_subdiags: Vec<SourceKindSubdiag<'a>>,
236 #[subdiagnostic]
237 pub multi_suggestions: Vec<SourceKindMultiSuggestion<'a>>,
238}
239
240#[derive(const _: () =
{
impl<'a> rustc_errors::Subdiagnostic for InferenceBadError<'a> {
fn add_to_diag<__G>(self, diag: &mut rustc_errors::Diag<'_, __G>)
where __G: rustc_errors::EmissionGuarantee {
match self {
InferenceBadError {
span: __binding_0,
bad_kind: __binding_1,
prefix_kind: __binding_2,
has_parent: __binding_3,
prefix: __binding_4,
parent_prefix: __binding_5,
parent_name: __binding_6,
name: __binding_7 } => {
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("bad_kind".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("prefix_kind".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
sub_args.insert("has_parent".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_3,
&mut diag.long_ty_path));
sub_args.insert("prefix".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_4,
&mut diag.long_ty_path));
sub_args.insert("parent_prefix".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_5,
&mut diag.long_ty_path));
sub_args.insert("parent_name".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_6,
&mut diag.long_ty_path));
sub_args.insert("name".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_7,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("{$bad_kind ->\n*[other] cannot infer type\n[more_info] cannot infer {$prefix_kind ->\n*[type] type for {$prefix}\n[const_with_param] the value of const parameter\n[const] the value of the constant\n} `{$name}`{$has_parent ->\n[true] {\" \"}declared on the {$parent_prefix} `{$parent_name}`\n*[false] {\"\"}\n}\n}")),
&sub_args);
diag.span_label(__binding_0, __message);
}
}
}
}
};Subdiagnostic)]
242#[label(
243 "{$bad_kind ->
244*[other] cannot infer type
245[more_info] cannot infer {$prefix_kind ->
246*[type] type for {$prefix}
247[const_with_param] the value of const parameter
248[const] the value of the constant
249} `{$name}`{$has_parent ->
250[true] {\" \"}declared on the {$parent_prefix} `{$parent_name}`
251*[false] {\"\"}
252}
253}"
254)]
255pub(crate) struct InferenceBadError<'a> {
256 #[primary_span]
257 pub span: Span,
258 pub bad_kind: &'static str,
259 pub prefix_kind: UnderspecifiedArgKind,
260 pub has_parent: bool,
261 pub prefix: &'a str,
262 pub parent_prefix: &'a str,
263 pub parent_name: String,
264 pub name: String,
265}
266
267#[derive(const _: () =
{
impl<'a> rustc_errors::Subdiagnostic for SourceKindSubdiag<'a> {
fn add_to_diag<__G>(self, diag: &mut rustc_errors::Diag<'_, __G>)
where __G: rustc_errors::EmissionGuarantee {
match self {
SourceKindSubdiag::LetLike {
span: __binding_0,
name: __binding_1,
type_name: __binding_2,
kind: __binding_3,
x_kind: __binding_4,
prefix_kind: __binding_5,
prefix: __binding_6,
arg_name: __binding_7 } => {
let __code_0 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!(": {0}", __binding_2))
})].into_iter();
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("name".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("type_name".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
sub_args.insert("kind".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_3,
&mut diag.long_ty_path));
sub_args.insert("x_kind".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_4,
&mut diag.long_ty_path));
sub_args.insert("prefix_kind".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_5,
&mut diag.long_ty_path));
sub_args.insert("prefix".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_6,
&mut diag.long_ty_path));
sub_args.insert("arg_name".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_7,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("{$kind ->\n [with_pattern] consider giving `{$name}` an explicit type\n [closure] consider giving this closure parameter an explicit type\n *[other] consider giving this pattern a type\n }{$x_kind ->\n [has_name] , where the {$prefix_kind ->\n *[type] type for {$prefix}\n [const_with_param] value of const parameter\n [const] value of the constant\n } `{$arg_name}` is specified\n [underscore_single] , where the placeholder `_` is specified\n [underscore_multiple] , where the placeholders `_` are specified\n *[empty] {\"\"}\n }")),
&sub_args);
diag.span_suggestions_with_style(__binding_0, __message,
__code_0, rustc_errors::Applicability::HasPlaceholders,
rustc_errors::SuggestionStyle::ShowAlways);
}
SourceKindSubdiag::GenericLabel {
span: __binding_0,
is_type: __binding_1,
param_name: __binding_2,
parent_exists: __binding_3,
parent_prefix: __binding_4,
parent_name: __binding_5 } => {
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("is_type".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("param_name".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
sub_args.insert("parent_exists".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_3,
&mut diag.long_ty_path));
sub_args.insert("parent_prefix".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_4,
&mut diag.long_ty_path));
sub_args.insert("parent_name".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_5,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("cannot infer {$is_type ->\n [true] type\n *[false] the value\n } of the {$is_type ->\n [true] type\n *[false] const\n } {$parent_exists ->\n [true] parameter `{$param_name}` declared on the {$parent_prefix} `{$parent_name}`\n *[false] parameter {$param_name}\n }")),
&sub_args);
diag.span_label(__binding_0, __message);
}
SourceKindSubdiag::GenericSuggestion {
span: __binding_0, arg_count: __binding_1, args: __binding_2
} => {
let __code_1 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!("::<{0}>", __binding_2))
})].into_iter();
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("arg_count".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("args".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("consider specifying the generic {$arg_count ->\n [one] argument\n *[other] arguments\n }")),
&sub_args);
diag.span_suggestions_with_style(__binding_0, __message,
__code_1, rustc_errors::Applicability::HasPlaceholders,
rustc_errors::SuggestionStyle::ShowAlways);
}
SourceKindSubdiag::GenericTypeSuggestion {
span: __binding_0, param: __binding_1 } => {
let __code_2 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!("::</* Type */>"))
})].into_iter();
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("param".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("consider specifying a concrete type for the type parameter `{$param}`")),
&sub_args);
diag.span_suggestions_with_style(__binding_0, __message,
__code_2, rustc_errors::Applicability::HasPlaceholders,
rustc_errors::SuggestionStyle::ShowAlways);
}
SourceKindSubdiag::ConstGenericSuggestion {
span: __binding_0, param: __binding_1 } => {
let __code_3 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!("::</* CONST */>"))
})].into_iter();
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("param".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("consider specifying a const for the const parameter `{$param}`")),
&sub_args);
diag.span_suggestions_with_style(__binding_0, __message,
__code_3, rustc_errors::Applicability::HasPlaceholders,
rustc_errors::SuggestionStyle::ShowAlways);
}
}
}
}
};Subdiagnostic)]
268pub(crate) enum SourceKindSubdiag<'a> {
269 #[suggestion(
270 "{$kind ->
271 [with_pattern] consider giving `{$name}` an explicit type
272 [closure] consider giving this closure parameter an explicit type
273 *[other] consider giving this pattern a type
274 }{$x_kind ->
275 [has_name] , where the {$prefix_kind ->
276 *[type] type for {$prefix}
277 [const_with_param] value of const parameter
278 [const] value of the constant
279 } `{$arg_name}` is specified
280 [underscore_single] , where the placeholder `_` is specified
281 [underscore_multiple] , where the placeholders `_` are specified
282 *[empty] {\"\"}
283 }",
284 style = "verbose",
285 code = ": {type_name}",
286 applicability = "has-placeholders"
287 )]
288 LetLike {
289 #[primary_span]
290 span: Span,
291 name: String,
292 type_name: String,
293 kind: &'static str,
294 x_kind: &'static str,
295 prefix_kind: UnderspecifiedArgKind,
296 prefix: &'a str,
297 arg_name: String,
298 },
299 #[label(
300 "cannot infer {$is_type ->
301 [true] type
302 *[false] the value
303 } of the {$is_type ->
304 [true] type
305 *[false] const
306 } {$parent_exists ->
307 [true] parameter `{$param_name}` declared on the {$parent_prefix} `{$parent_name}`
308 *[false] parameter {$param_name}
309 }"
310 )]
311 GenericLabel {
312 #[primary_span]
313 span: Span,
314 is_type: bool,
315 param_name: String,
316 parent_exists: bool,
317 parent_prefix: String,
318 parent_name: String,
319 },
320 #[suggestion(
321 "consider specifying the generic {$arg_count ->
322 [one] argument
323 *[other] arguments
324 }",
325 style = "verbose",
326 code = "::<{args}>",
327 applicability = "has-placeholders"
328 )]
329 GenericSuggestion {
330 #[primary_span]
331 span: Span,
332 arg_count: usize,
333 args: String,
334 },
335 #[suggestion(
336 "consider specifying a concrete type for the type parameter `{$param}`",
337 style = "verbose",
338 code = "::</* Type */>",
339 applicability = "has-placeholders"
340 )]
341 GenericTypeSuggestion {
342 #[primary_span]
343 span: Span,
344 param: String,
345 },
346 #[suggestion(
347 "consider specifying a const for the const parameter `{$param}`",
348 style = "verbose",
349 code = "::</* CONST */>",
350 applicability = "has-placeholders"
351 )]
352 ConstGenericSuggestion {
353 #[primary_span]
354 span: Span,
355 param: String,
356 },
357}
358
359#[derive(const _: () =
{
impl<'a> rustc_errors::Subdiagnostic for SourceKindMultiSuggestion<'a>
{
fn add_to_diag<__G>(self, diag: &mut rustc_errors::Diag<'_, __G>)
where __G: rustc_errors::EmissionGuarantee {
match self {
SourceKindMultiSuggestion::FullyQualified {
span_lo: __binding_0,
span_hi: __binding_1,
def_path: __binding_2,
adjustment: __binding_3,
successor_pos: __binding_4 } => {
let mut suggestions = Vec::new();
let __code_4 =
::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{1}({0}", __binding_3,
__binding_2))
});
let __code_5 =
::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0}", __binding_4))
});
suggestions.push((__binding_0, __code_4));
suggestions.push((__binding_1, __code_5));
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("def_path".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
sub_args.insert("adjustment".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_3,
&mut diag.long_ty_path));
sub_args.insert("successor_pos".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_4,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("try using a fully qualified path to specify the expected types")),
&sub_args);
diag.multipart_suggestion_with_style(__message, suggestions,
rustc_errors::Applicability::HasPlaceholders,
rustc_errors::SuggestionStyle::ShowAlways);
}
SourceKindMultiSuggestion::ClosureReturn {
start_span: __binding_0,
start_span_code: __binding_1,
end_span: __binding_2 } => {
let mut suggestions = Vec::new();
let __code_6 =
::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0}", __binding_1))
});
let __code_7 =
::alloc::__export::must_use({
::alloc::fmt::format(format_args!(" }}"))
});
suggestions.push((__binding_0, __code_6));
if let Some(__binding_2) = __binding_2 {
suggestions.push((__binding_2, __code_7));
}
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("start_span_code".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("try giving this closure an explicit return type")),
&sub_args);
diag.multipart_suggestion_with_style(__message, suggestions,
rustc_errors::Applicability::HasPlaceholders,
rustc_errors::SuggestionStyle::ShowAlways);
}
}
}
}
};Subdiagnostic)]
360pub(crate) enum SourceKindMultiSuggestion<'a> {
361 #[multipart_suggestion(
362 "try using a fully qualified path to specify the expected types",
363 style = "verbose",
364 applicability = "has-placeholders"
365 )]
366 FullyQualified {
367 #[suggestion_part(code = "{def_path}({adjustment}")]
368 span_lo: Span,
369 #[suggestion_part(code = "{successor_pos}")]
370 span_hi: Span,
371 def_path: String,
372 adjustment: &'a str,
373 successor_pos: &'a str,
374 },
375 #[multipart_suggestion(
376 "try giving this closure an explicit return type",
377 style = "verbose",
378 applicability = "has-placeholders"
379 )]
380 ClosureReturn {
381 #[suggestion_part(code = "{start_span_code}")]
382 start_span: Span,
383 start_span_code: String,
384 #[suggestion_part(code = " }}")]
385 end_span: Option<Span>,
386 },
387}
388
389impl<'a> SourceKindMultiSuggestion<'a> {
390 pub(crate) fn new_fully_qualified(
391 span: Span,
392 def_path: String,
393 adjustment: &'a str,
394 successor: (&'a str, BytePos),
395 ) -> Self {
396 Self::FullyQualified {
397 span_lo: span.shrink_to_lo(),
398 span_hi: span.shrink_to_hi().with_hi(successor.1),
399 def_path,
400 adjustment,
401 successor_pos: successor.0,
402 }
403 }
404
405 pub(crate) fn new_closure_return(
406 ty_info: String,
407 data: &'a FnRetTy<'a>,
408 should_wrap_expr: Option<Span>,
409 ) -> Self {
410 let arrow = match data {
411 FnRetTy::DefaultReturn(_) => " -> ",
412 _ => "",
413 };
414 let (start_span, start_span_code, end_span) = match should_wrap_expr {
415 Some(end_span) => (data.span(), ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0}{1} {{", arrow, ty_info))
})format!("{arrow}{ty_info} {{"), Some(end_span)),
416 None => (data.span(), ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0}{1}", arrow, ty_info))
})format!("{arrow}{ty_info}"), None),
417 };
418 Self::ClosureReturn { start_span, start_span_code, end_span }
419 }
420}
421
422pub(crate) enum RegionOriginNote<'a> {
423 Plain {
424 span: Span,
425 msg: DiagMessage,
426 },
427 WithName {
428 span: Span,
429 msg: DiagMessage,
430 name: &'a str,
431 continues: bool,
432 },
433 WithRequirement {
434 span: Span,
435 requirement: ObligationCauseAsDiagArg<'a>,
436 expected_found: Option<(DiagStyledString, DiagStyledString)>,
437 },
438}
439
440impl Subdiagnostic for RegionOriginNote<'_> {
441 fn add_to_diag<G: EmissionGuarantee>(self, diag: &mut Diag<'_, G>) {
442 let label_or_note = |diag: &mut Diag<'_, G>, span, msg: DiagMessage| {
443 let sub_count = diag.children.iter().filter(|d| d.span.is_dummy()).count();
444 let expanded_sub_count = diag.children.iter().filter(|d| !d.span.is_dummy()).count();
445 let span_is_primary = diag.span.primary_spans().iter().all(|&sp| sp == span);
446 if span_is_primary && sub_count == 0 && expanded_sub_count == 0 {
447 diag.span_label(span, msg);
448 } else if span_is_primary && expanded_sub_count == 0 {
449 diag.note(msg);
450 } else {
451 diag.span_note(span, msg);
452 }
453 };
454 match self {
455 RegionOriginNote::Plain { span, msg } => {
456 label_or_note(diag, span, msg);
457 }
458 RegionOriginNote::WithName { span, msg, name, continues } => {
459 label_or_note(
460 diag,
461 span,
462 msg.arg("name", name).arg("continues", continues).format(),
463 );
464 }
465 RegionOriginNote::WithRequirement {
466 span,
467 requirement,
468 expected_found: Some((expected, found)),
469 } => {
470 let msg = rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("...so that the {$requirement ->\n [method_compat] method type is compatible with trait\n [type_compat] associated type is compatible with trait\n [const_compat] const is compatible with trait\n [expr_assignable] expression is assignable\n [if_else_different] `if` and `else` have incompatible types\n [no_else] `if` missing an `else` returns `()`\n [fn_main_correct_type] `main` function has the correct type\n [fn_lang_correct_type] lang item function has the correct type\n [intrinsic_correct_type] intrinsic has the correct type\n [method_correct_type] method receiver has the correct type\n *[other] types are compatible\n }"))msg!(
471 "...so that the {$requirement ->
472 [method_compat] method type is compatible with trait
473 [type_compat] associated type is compatible with trait
474 [const_compat] const is compatible with trait
475 [expr_assignable] expression is assignable
476 [if_else_different] `if` and `else` have incompatible types
477 [no_else] `if` missing an `else` returns `()`
478 [fn_main_correct_type] `main` function has the correct type
479 [fn_lang_correct_type] lang item function has the correct type
480 [intrinsic_correct_type] intrinsic has the correct type
481 [method_correct_type] method receiver has the correct type
482 *[other] types are compatible
483 }"
484 )
485 .arg("requirement", requirement)
486 .format();
487 label_or_note(diag, span, msg);
488
489 diag.note_expected_found("", expected, "", found);
490 }
491 RegionOriginNote::WithRequirement { span, requirement, expected_found: None } => {
492 let msg = rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("...so that {$requirement ->\n [method_compat] method type is compatible with trait\n [type_compat] associated type is compatible with trait\n [const_compat] const is compatible with trait\n [expr_assignable] expression is assignable\n [if_else_different] `if` and `else` have incompatible types\n [no_else] `if` missing an `else` returns `()`\n [fn_main_correct_type] `main` function has the correct type\n [fn_lang_correct_type] lang item function has the correct type\n [intrinsic_correct_type] intrinsic has the correct type\n [method_correct_type] method receiver has the correct type\n *[other] types are compatible\n }"))msg!(
496 "...so that {$requirement ->
497 [method_compat] method type is compatible with trait
498 [type_compat] associated type is compatible with trait
499 [const_compat] const is compatible with trait
500 [expr_assignable] expression is assignable
501 [if_else_different] `if` and `else` have incompatible types
502 [no_else] `if` missing an `else` returns `()`
503 [fn_main_correct_type] `main` function has the correct type
504 [fn_lang_correct_type] lang item function has the correct type
505 [intrinsic_correct_type] intrinsic has the correct type
506 [method_correct_type] method receiver has the correct type
507 *[other] types are compatible
508 }"
509 )
510 .arg("requirement", requirement)
511 .format();
512 label_or_note(diag, span, msg);
513 }
514 };
515 }
516}
517
518pub(crate) enum LifetimeMismatchLabels {
519 InRet {
520 param_span: Span,
521 ret_span: Span,
522 span: Span,
523 label_var1: Option<Ident>,
524 },
525 Normal {
526 hir_equal: bool,
527 ty_sup: Span,
528 ty_sub: Span,
529 span: Span,
530 sup: Option<Ident>,
531 sub: Option<Ident>,
532 },
533}
534
535impl Subdiagnostic for LifetimeMismatchLabels {
536 fn add_to_diag<G: EmissionGuarantee>(self, diag: &mut Diag<'_, G>) {
537 match self {
538 LifetimeMismatchLabels::InRet { param_span, ret_span, span, label_var1 } => {
539 diag.span_label(param_span, rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("this parameter and the return type are declared with different lifetimes..."))msg!("this parameter and the return type are declared with different lifetimes..."));
540 diag.span_label(ret_span, rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("{\"\"}"))msg!("{\"\"}"));
541 diag.span_label(
542 span,
543 rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("...but data{$label_var1_exists ->\n [true] {\" \"}from `{$label_var1}`\n *[false] {\"\"}\n } is returned here"))msg!(
544 "...but data{$label_var1_exists ->
545 [true] {\" \"}from `{$label_var1}`
546 *[false] {\"\"}
547 } is returned here"
548 ),
549 );
550 diag.arg("label_var1_exists", label_var1.is_some());
551 diag.arg("label_var1", label_var1.map(|x| x.to_string()).unwrap_or_default());
552 }
553 LifetimeMismatchLabels::Normal {
554 hir_equal,
555 ty_sup,
556 ty_sub,
557 span,
558 sup: label_var1,
559 sub: label_var2,
560 } => {
561 if hir_equal {
562 diag.span_label(
563 ty_sup,
564 rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("this type is declared with multiple lifetimes..."))msg!("this type is declared with multiple lifetimes..."),
565 );
566 diag.span_label(ty_sub, rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("{\"\"}"))msg!("{\"\"}"));
567 diag.span_label(
568 span,
569 rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("...but data with one lifetime flows into the other here"))msg!("...but data with one lifetime flows into the other here"),
570 );
571 } else {
572 diag.span_label(
573 ty_sup,
574 rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("these two types are declared with different lifetimes..."))msg!("these two types are declared with different lifetimes..."),
575 );
576 diag.span_label(ty_sub, rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("{\"\"}"))msg!("{\"\"}"));
577 diag.span_label(
578 span,
579 rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("...but data{$label_var1_exists ->\n [true] {\" \"}from `{$label_var1}`\n *[false] {\"\"}\n } flows{$label_var2_exists ->\n [true] {\" \"}into `{$label_var2}`\n *[false] {\"\"}\n } here"))msg!(
580 "...but data{$label_var1_exists ->
581 [true] {\" \"}from `{$label_var1}`
582 *[false] {\"\"}
583 } flows{$label_var2_exists ->
584 [true] {\" \"}into `{$label_var2}`
585 *[false] {\"\"}
586 } here"
587 ),
588 );
589 diag.arg("label_var1_exists", label_var1.is_some());
590 diag.arg("label_var1", label_var1.map(|x| x.to_string()).unwrap_or_default());
591 diag.arg("label_var2_exists", label_var2.is_some());
592 diag.arg("label_var2", label_var2.map(|x| x.to_string()).unwrap_or_default());
593 }
594 }
595 }
596 }
597}
598
599pub(crate) struct AddLifetimeParamsSuggestion<'a> {
600 pub tcx: TyCtxt<'a>,
601 pub generic_param_scope: LocalDefId,
602 pub sub: Region<'a>,
603 pub ty_sup: &'a hir::Ty<'a>,
604 pub ty_sub: &'a hir::Ty<'a>,
605 pub add_note: bool,
606}
607
608impl Subdiagnostic for AddLifetimeParamsSuggestion<'_> {
609 fn add_to_diag<G: EmissionGuarantee>(self, diag: &mut Diag<'_, G>) {
610 let mut mk_suggestion = || {
611 let Some(anon_reg) = self.tcx.is_suitable_region(self.generic_param_scope, self.sub)
612 else {
613 return false;
614 };
615
616 let node = self.tcx.hir_node_by_def_id(anon_reg.scope);
617 let is_impl = #[allow(non_exhaustive_omitted_patterns)] match &node {
hir::Node::ImplItem(_) => true,
_ => false,
}matches!(&node, hir::Node::ImplItem(_));
618 let (generics, parent_generics) = match node {
619 hir::Node::Item(hir::Item { kind: hir::ItemKind::Fn { generics, .. }, .. })
620 | hir::Node::TraitItem(hir::TraitItem { generics, .. })
621 | hir::Node::ImplItem(hir::ImplItem { generics, .. }) => (
622 generics,
623 match self.tcx.parent_hir_node(self.tcx.local_def_id_to_hir_id(anon_reg.scope))
624 {
625 hir::Node::Item(hir::Item {
626 kind: hir::ItemKind::Trait { generics, .. },
627 ..
628 })
629 | hir::Node::Item(hir::Item {
630 kind: hir::ItemKind::Impl(hir::Impl { generics, .. }),
631 ..
632 }) => Some(generics),
633 _ => None,
634 },
635 ),
636 _ => return false,
637 };
638
639 let suggestion_param_name = generics
640 .params
641 .iter()
642 .filter(|p| #[allow(non_exhaustive_omitted_patterns)] match p.kind {
GenericParamKind::Lifetime { .. } => true,
_ => false,
}matches!(p.kind, GenericParamKind::Lifetime { .. }))
643 .map(|p| p.name.ident().name)
644 .find(|i| *i != kw::UnderscoreLifetime);
645 let introduce_new = suggestion_param_name.is_none();
646
647 let mut default = "'a".to_string();
648 if let Some(parent_generics) = parent_generics {
649 let used: FxHashSet<_> = parent_generics
650 .params
651 .iter()
652 .filter(|p| #[allow(non_exhaustive_omitted_patterns)] match p.kind {
GenericParamKind::Lifetime { .. } => true,
_ => false,
}matches!(p.kind, GenericParamKind::Lifetime { .. }))
653 .map(|p| p.name.ident().name)
654 .filter(|i| *i != kw::UnderscoreLifetime)
655 .map(|l| l.to_string())
656 .collect();
657 if let Some(lt) =
658 ('a'..='z').map(|it| ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("\'{0}", it))
})format!("'{it}")).find(|it| !used.contains(it))
659 {
660 default = lt;
665 }
666 }
667 let suggestion_param_name =
668 suggestion_param_name.map(|n| n.to_string()).unwrap_or_else(|| default);
669
670 struct ImplicitLifetimeFinder {
671 suggestions: Vec<(Span, String)>,
672 suggestion_param_name: String,
673 }
674
675 impl<'v> Visitor<'v> for ImplicitLifetimeFinder {
676 fn visit_ty(&mut self, ty: &'v hir::Ty<'v, AmbigArg>) {
677 match ty.kind {
678 hir::TyKind::Path(hir::QPath::Resolved(_, path)) => {
679 for segment in path.segments {
680 if let Some(args) = segment.args {
681 if args.args.iter().all(|arg| {
682 #[allow(non_exhaustive_omitted_patterns)] match arg {
hir::GenericArg::Lifetime(lifetime) if lifetime.is_implicit() => true,
_ => false,
}matches!(
683 arg,
684 hir::GenericArg::Lifetime(lifetime)
685 if lifetime.is_implicit()
686 )
687 }) {
688 self.suggestions.push((
689 segment.ident.span.shrink_to_hi(),
690 ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("<{0}>",
args.args.iter().map(|_|
self.suggestion_param_name.clone()).collect::<Vec<_>>().join(", ")))
})format!(
691 "<{}>",
692 args.args
693 .iter()
694 .map(|_| self.suggestion_param_name.clone())
695 .collect::<Vec<_>>()
696 .join(", ")
697 ),
698 ));
699 } else {
700 for arg in args.args {
701 if let hir::GenericArg::Lifetime(lifetime) = arg
702 && lifetime.is_anonymous()
703 {
704 self.suggestions.push(
705 lifetime
706 .suggestion(&self.suggestion_param_name),
707 );
708 }
709 }
710 }
711 }
712 }
713 }
714 hir::TyKind::Ref(lifetime, ..) if lifetime.is_anonymous() => {
715 self.suggestions.push(lifetime.suggestion(&self.suggestion_param_name));
716 }
717 _ => {}
718 }
719 walk_ty(self, ty);
720 }
721 }
722 let mut visitor = ImplicitLifetimeFinder {
723 suggestions: ::alloc::vec::Vec::new()vec![],
724 suggestion_param_name: suggestion_param_name.clone(),
725 };
726 if let Some(fn_decl) = node.fn_decl()
727 && let hir::FnRetTy::Return(ty) = fn_decl.output
728 {
729 visitor.visit_ty_unambig(ty);
730 }
731 if visitor.suggestions.is_empty() {
732 visitor.visit_ty_unambig(self.ty_sup);
737 }
738 visitor.visit_ty_unambig(self.ty_sub);
739 if visitor.suggestions.is_empty() {
740 return false;
741 }
742 if introduce_new {
743 let new_param_suggestion = if let Some(first) =
744 generics.params.iter().find(|p| !p.name.ident().span.is_empty())
745 {
746 (first.span.shrink_to_lo(), ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0}, ", suggestion_param_name))
})format!("{suggestion_param_name}, "))
747 } else {
748 (generics.span, ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("<{0}>", suggestion_param_name))
})format!("<{suggestion_param_name}>"))
749 };
750
751 visitor.suggestions.push(new_param_suggestion);
752 }
753 diag.multipart_suggestion(
754 rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("consider {$is_reuse ->\n [true] reusing\n *[false] introducing\n } a named lifetime parameter{$is_impl ->\n [true] {\" \"}and update trait if needed\n *[false] {\"\"}\n }"))msg!(
755 "consider {$is_reuse ->
756 [true] reusing
757 *[false] introducing
758 } a named lifetime parameter{$is_impl ->
759 [true] {\" \"}and update trait if needed
760 *[false] {\"\"}
761 }"
762 ),
763 visitor.suggestions,
764 Applicability::MaybeIncorrect,
765 );
766 diag.arg("is_impl", is_impl);
767 diag.arg("is_reuse", !introduce_new);
768
769 true
770 };
771 if mk_suggestion() && self.add_note {
772 diag.note(rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("each elided lifetime in input position becomes a distinct lifetime"))msg!("each elided lifetime in input position becomes a distinct lifetime"));
773 }
774 }
775}
776
777#[derive(const _: () =
{
impl<'_sess, 'a, G> rustc_errors::Diagnostic<'_sess, G> for
LifetimeMismatch<'a> where G: rustc_errors::EmissionGuarantee {
#[track_caller]
fn into_diag(self, dcx: rustc_errors::DiagCtxtHandle<'_sess>,
level: rustc_errors::Level) -> rustc_errors::Diag<'_sess, G> {
match self {
LifetimeMismatch {
span: __binding_0,
labels: __binding_1,
suggestion: __binding_2 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("lifetime mismatch")));
diag.code(E0623);
;
diag.span(__binding_0);
diag.subdiagnostic(__binding_1);
diag.subdiagnostic(__binding_2);
diag
}
}
}
}
};Diagnostic)]
778#[diag("lifetime mismatch", code = E0623)]
779pub(crate) struct LifetimeMismatch<'a> {
780 #[primary_span]
781 pub span: Span,
782 #[subdiagnostic]
783 pub labels: LifetimeMismatchLabels,
784 #[subdiagnostic]
785 pub suggestion: AddLifetimeParamsSuggestion<'a>,
786}
787
788pub(crate) struct IntroducesStaticBecauseUnmetLifetimeReq {
789 pub unmet_requirements: MultiSpan,
790 pub binding_span: Span,
791}
792
793impl Subdiagnostic for IntroducesStaticBecauseUnmetLifetimeReq {
794 fn add_to_diag<G: EmissionGuarantee>(mut self, diag: &mut Diag<'_, G>) {
795 self.unmet_requirements.push_span_label(
796 self.binding_span,
797 rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("introduces a `'static` lifetime requirement"))msg!("introduces a `'static` lifetime requirement"),
798 );
799 diag.span_note(
800 self.unmet_requirements,
801 rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("because this has an unmet lifetime requirement"))msg!("because this has an unmet lifetime requirement"),
802 );
803 }
804}
805
806#[derive(const _: () =
{
impl rustc_errors::Subdiagnostic for DoesNotOutliveStaticFromImpl {
fn add_to_diag<__G>(self, diag: &mut rustc_errors::Diag<'_, __G>)
where __G: rustc_errors::EmissionGuarantee {
match self {
DoesNotOutliveStaticFromImpl::Spanned { span: __binding_0 }
=> {
let mut sub_args = rustc_errors::DiagArgMap::default();
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("...does not necessarily outlive the static lifetime introduced by the compatible `impl`")),
&sub_args);
diag.span_note(__binding_0, __message);
}
DoesNotOutliveStaticFromImpl::Unspanned => {
let mut sub_args = rustc_errors::DiagArgMap::default();
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("...does not necessarily outlive the static lifetime introduced by the compatible `impl`")),
&sub_args);
diag.note(__message);
}
}
}
}
};Subdiagnostic)]
808pub(crate) enum DoesNotOutliveStaticFromImpl {
809 #[note(
810 "...does not necessarily outlive the static lifetime introduced by the compatible `impl`"
811 )]
812 Spanned {
813 #[primary_span]
814 span: Span,
815 },
816 #[note(
817 "...does not necessarily outlive the static lifetime introduced by the compatible `impl`"
818 )]
819 Unspanned,
820}
821
822#[derive(const _: () =
{
impl rustc_errors::Subdiagnostic for ImplicitStaticLifetimeSubdiag {
fn add_to_diag<__G>(self, diag: &mut rustc_errors::Diag<'_, __G>)
where __G: rustc_errors::EmissionGuarantee {
match self {
ImplicitStaticLifetimeSubdiag::Note { span: __binding_0 } =>
{
let mut sub_args = rustc_errors::DiagArgMap::default();
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("this has an implicit `'static` lifetime requirement")),
&sub_args);
diag.span_note(__binding_0, __message);
}
ImplicitStaticLifetimeSubdiag::Sugg { span: __binding_0 } =>
{
let __code_8 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!(" + \'_"))
})].into_iter();
let mut sub_args = rustc_errors::DiagArgMap::default();
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("consider relaxing the implicit `'static` requirement")),
&sub_args);
diag.span_suggestions_with_style(__binding_0, __message,
__code_8, rustc_errors::Applicability::MaybeIncorrect,
rustc_errors::SuggestionStyle::ShowAlways);
}
}
}
}
};Subdiagnostic)]
823pub(crate) enum ImplicitStaticLifetimeSubdiag {
824 #[note("this has an implicit `'static` lifetime requirement")]
825 Note {
826 #[primary_span]
827 span: Span,
828 },
829 #[suggestion(
830 "consider relaxing the implicit `'static` requirement",
831 style = "verbose",
832 code = " + '_",
833 applicability = "maybe-incorrect"
834 )]
835 Sugg {
836 #[primary_span]
837 span: Span,
838 },
839}
840
841#[derive(const _: () =
{
impl<'_sess, 'a, G> rustc_errors::Diagnostic<'_sess, G> for
MismatchedStaticLifetime<'a> where
G: rustc_errors::EmissionGuarantee {
#[track_caller]
fn into_diag(self, dcx: rustc_errors::DiagCtxtHandle<'_sess>,
level: rustc_errors::Level) -> rustc_errors::Diag<'_sess, G> {
match self {
MismatchedStaticLifetime {
cause_span: __binding_0,
unmet_lifetime_reqs: __binding_1,
expl: __binding_2,
does_not_outlive_static_from_impl: __binding_3,
implicit_static_lifetimes: __binding_4 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("incompatible lifetime on type")));
;
diag.span(__binding_0);
diag.subdiagnostic(__binding_1);
if let Some(__binding_2) = __binding_2 {
diag.subdiagnostic(__binding_2);
}
diag.subdiagnostic(__binding_3);
for __binding_4 in __binding_4 {
diag.subdiagnostic(__binding_4);
}
diag
}
}
}
}
};Diagnostic)]
842#[diag("incompatible lifetime on type")]
843pub(crate) struct MismatchedStaticLifetime<'a> {
844 #[primary_span]
845 pub cause_span: Span,
846 #[subdiagnostic]
847 pub unmet_lifetime_reqs: IntroducesStaticBecauseUnmetLifetimeReq,
848 #[subdiagnostic]
849 pub expl: Option<note_and_explain::RegionExplanation<'a>>,
850 #[subdiagnostic]
851 pub does_not_outlive_static_from_impl: DoesNotOutliveStaticFromImpl,
852 #[subdiagnostic]
853 pub implicit_static_lifetimes: Vec<ImplicitStaticLifetimeSubdiag>,
854}
855
856#[derive(const _: () =
{
impl<'_sess, 'a, G> rustc_errors::Diagnostic<'_sess, G> for
ExplicitLifetimeRequired<'a> where
G: rustc_errors::EmissionGuarantee {
#[track_caller]
fn into_diag(self, dcx: rustc_errors::DiagCtxtHandle<'_sess>,
level: rustc_errors::Level) -> rustc_errors::Diag<'_sess, G> {
match self {
ExplicitLifetimeRequired::WithIdent {
span: __binding_0,
simple_ident: __binding_1,
named: __binding_2,
new_ty_span: __binding_3,
new_ty: __binding_4 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("explicit lifetime required in the type of `{$simple_ident}`")));
let __code_9 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0}", __binding_4))
})].into_iter();
diag.code(E0621);
;
diag.arg("simple_ident", __binding_1);
diag.arg("named", __binding_2);
diag.span(__binding_0);
diag.span_label(__binding_0,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("lifetime `{$named}` required")));
diag.span_suggestions_with_style(__binding_3,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("add explicit lifetime `{$named}` to the type of `{$simple_ident}`")),
__code_9, rustc_errors::Applicability::Unspecified,
rustc_errors::SuggestionStyle::ShowAlways);
diag
}
ExplicitLifetimeRequired::WithParamType {
span: __binding_0,
named: __binding_1,
new_ty_span: __binding_2,
new_ty: __binding_3 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("explicit lifetime required in parameter type")));
let __code_10 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0}", __binding_3))
})].into_iter();
diag.code(E0621);
;
diag.arg("named", __binding_1);
diag.span(__binding_0);
diag.span_label(__binding_0,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("lifetime `{$named}` required")));
diag.span_suggestions_with_style(__binding_2,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("add explicit lifetime `{$named}` to type")),
__code_10, rustc_errors::Applicability::Unspecified,
rustc_errors::SuggestionStyle::ShowAlways);
diag
}
}
}
}
};Diagnostic)]
857pub(crate) enum ExplicitLifetimeRequired<'a> {
858 #[diag("explicit lifetime required in the type of `{$simple_ident}`", code = E0621)]
859 WithIdent {
860 #[primary_span]
861 #[label("lifetime `{$named}` required")]
862 span: Span,
863 simple_ident: Ident,
864 named: String,
865 #[suggestion(
866 "add explicit lifetime `{$named}` to the type of `{$simple_ident}`",
867 code = "{new_ty}",
868 applicability = "unspecified",
869 style = "verbose"
870 )]
871 new_ty_span: Span,
872 #[skip_arg]
873 new_ty: Ty<'a>,
874 },
875 #[diag("explicit lifetime required in parameter type", code = E0621)]
876 WithParamType {
877 #[primary_span]
878 #[label("lifetime `{$named}` required")]
879 span: Span,
880 named: String,
881 #[suggestion(
882 "add explicit lifetime `{$named}` to type",
883 code = "{new_ty}",
884 applicability = "unspecified",
885 style = "verbose"
886 )]
887 new_ty_span: Span,
888 #[skip_arg]
889 new_ty: Ty<'a>,
890 },
891}
892
893pub(crate) enum TyOrSig<'tcx> {
894 Ty(Highlighted<'tcx, Ty<'tcx>>),
895 ClosureSig(Highlighted<'tcx, Binder<'tcx, FnSig<'tcx>>>),
896}
897
898impl IntoDiagArg for TyOrSig<'_> {
899 fn into_diag_arg(self, path: &mut Option<std::path::PathBuf>) -> rustc_errors::DiagArgValue {
900 match self {
901 TyOrSig::Ty(ty) => ty.into_diag_arg(path),
902 TyOrSig::ClosureSig(sig) => sig.into_diag_arg(path),
903 }
904 }
905}
906
907#[derive(const _: () =
{
impl<'tcx> rustc_errors::Subdiagnostic for ActualImplExplNotes<'tcx> {
fn add_to_diag<__G>(self, diag: &mut rustc_errors::Diag<'_, __G>)
where __G: rustc_errors::EmissionGuarantee {
match self {
ActualImplExplNotes::ExpectedSignatureTwo {
leading_ellipsis: __binding_0,
ty_or_sig: __binding_1,
trait_path: __binding_2,
lifetime_1: __binding_3,
lifetime_2: __binding_4 } => {
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("leading_ellipsis".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_0,
&mut diag.long_ty_path));
sub_args.insert("ty_or_sig".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("trait_path".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
sub_args.insert("lifetime_1".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_3,
&mut diag.long_ty_path));
sub_args.insert("lifetime_2".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_4,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("{$leading_ellipsis ->\n [true] ...\n *[false] {\"\"}\n }closure with signature `{$ty_or_sig}` must implement `{$trait_path}`, for any two lifetimes `'{$lifetime_1}` and `'{$lifetime_2}`...")),
&sub_args);
diag.note(__message);
}
ActualImplExplNotes::ExpectedSignatureAny {
leading_ellipsis: __binding_0,
ty_or_sig: __binding_1,
trait_path: __binding_2,
lifetime_1: __binding_3 } => {
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("leading_ellipsis".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_0,
&mut diag.long_ty_path));
sub_args.insert("ty_or_sig".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("trait_path".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
sub_args.insert("lifetime_1".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_3,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("{$leading_ellipsis ->\n [true] ...\n *[false] {\"\"}\n }closure with signature `{$ty_or_sig}` must implement `{$trait_path}`, for any lifetime `'{$lifetime_1}`...")),
&sub_args);
diag.note(__message);
}
ActualImplExplNotes::ExpectedSignatureSome {
leading_ellipsis: __binding_0,
ty_or_sig: __binding_1,
trait_path: __binding_2,
lifetime_1: __binding_3 } => {
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("leading_ellipsis".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_0,
&mut diag.long_ty_path));
sub_args.insert("ty_or_sig".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("trait_path".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
sub_args.insert("lifetime_1".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_3,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("{$leading_ellipsis ->\n [true] ...\n *[false] {\"\"}\n }closure with signature `{$ty_or_sig}` must implement `{$trait_path}`, for some specific lifetime `'{$lifetime_1}`...")),
&sub_args);
diag.note(__message);
}
ActualImplExplNotes::ExpectedSignatureNothing {
leading_ellipsis: __binding_0,
ty_or_sig: __binding_1,
trait_path: __binding_2 } => {
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("leading_ellipsis".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_0,
&mut diag.long_ty_path));
sub_args.insert("ty_or_sig".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("trait_path".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("{$leading_ellipsis ->\n [true] ...\n *[false] {\"\"}\n }closure with signature `{$ty_or_sig}` must implement `{$trait_path}`")),
&sub_args);
diag.note(__message);
}
ActualImplExplNotes::ExpectedPassiveTwo {
leading_ellipsis: __binding_0,
ty_or_sig: __binding_1,
trait_path: __binding_2,
lifetime_1: __binding_3,
lifetime_2: __binding_4 } => {
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("leading_ellipsis".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_0,
&mut diag.long_ty_path));
sub_args.insert("ty_or_sig".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("trait_path".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
sub_args.insert("lifetime_1".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_3,
&mut diag.long_ty_path));
sub_args.insert("lifetime_2".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_4,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("{$leading_ellipsis ->\n [true] ...\n *[false] {\"\"}\n }`{$trait_path}` would have to be implemented for the type `{$ty_or_sig}`, for any two lifetimes `'{$lifetime_1}` and `'{$lifetime_2}`...")),
&sub_args);
diag.note(__message);
}
ActualImplExplNotes::ExpectedPassiveAny {
leading_ellipsis: __binding_0,
ty_or_sig: __binding_1,
trait_path: __binding_2,
lifetime_1: __binding_3 } => {
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("leading_ellipsis".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_0,
&mut diag.long_ty_path));
sub_args.insert("ty_or_sig".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("trait_path".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
sub_args.insert("lifetime_1".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_3,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("{$leading_ellipsis ->\n [true] ...\n *[false] {\"\"}\n }`{$trait_path}` would have to be implemented for the type `{$ty_or_sig}`, for any lifetime `'{$lifetime_1}`...")),
&sub_args);
diag.note(__message);
}
ActualImplExplNotes::ExpectedPassiveSome {
leading_ellipsis: __binding_0,
ty_or_sig: __binding_1,
trait_path: __binding_2,
lifetime_1: __binding_3 } => {
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("leading_ellipsis".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_0,
&mut diag.long_ty_path));
sub_args.insert("ty_or_sig".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("trait_path".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
sub_args.insert("lifetime_1".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_3,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("{$leading_ellipsis ->\n [true] ...\n *[false] {\"\"}\n }`{$trait_path}` would have to be implemented for the type `{$ty_or_sig}`, for some specific lifetime `'{$lifetime_1}`...")),
&sub_args);
diag.note(__message);
}
ActualImplExplNotes::ExpectedPassiveNothing {
leading_ellipsis: __binding_0,
ty_or_sig: __binding_1,
trait_path: __binding_2 } => {
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("leading_ellipsis".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_0,
&mut diag.long_ty_path));
sub_args.insert("ty_or_sig".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("trait_path".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("{$leading_ellipsis ->\n [true] ...\n *[false] {\"\"}\n }`{$trait_path}` would have to be implemented for the type `{$ty_or_sig}`")),
&sub_args);
diag.note(__message);
}
ActualImplExplNotes::ExpectedOtherTwo {
leading_ellipsis: __binding_0,
ty_or_sig: __binding_1,
trait_path: __binding_2,
lifetime_1: __binding_3,
lifetime_2: __binding_4 } => {
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("leading_ellipsis".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_0,
&mut diag.long_ty_path));
sub_args.insert("ty_or_sig".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("trait_path".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
sub_args.insert("lifetime_1".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_3,
&mut diag.long_ty_path));
sub_args.insert("lifetime_2".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_4,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("{$leading_ellipsis ->\n [true] ...\n *[false] {\"\"}\n }`{$ty_or_sig}` must implement `{$trait_path}`, for any two lifetimes `'{$lifetime_1}` and `'{$lifetime_2}`...")),
&sub_args);
diag.note(__message);
}
ActualImplExplNotes::ExpectedOtherAny {
leading_ellipsis: __binding_0,
ty_or_sig: __binding_1,
trait_path: __binding_2,
lifetime_1: __binding_3 } => {
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("leading_ellipsis".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_0,
&mut diag.long_ty_path));
sub_args.insert("ty_or_sig".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("trait_path".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
sub_args.insert("lifetime_1".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_3,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("{$leading_ellipsis ->\n [true] ...\n *[false] {\"\"}\n }`{$ty_or_sig}` must implement `{$trait_path}`, for any lifetime `'{$lifetime_1}`...")),
&sub_args);
diag.note(__message);
}
ActualImplExplNotes::ExpectedOtherSome {
leading_ellipsis: __binding_0,
ty_or_sig: __binding_1,
trait_path: __binding_2,
lifetime_1: __binding_3 } => {
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("leading_ellipsis".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_0,
&mut diag.long_ty_path));
sub_args.insert("ty_or_sig".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("trait_path".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
sub_args.insert("lifetime_1".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_3,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("{$leading_ellipsis ->\n [true] ...\n *[false] {\"\"}\n }`{$ty_or_sig}` must implement `{$trait_path}`, for some specific lifetime `'{$lifetime_1}`...")),
&sub_args);
diag.note(__message);
}
ActualImplExplNotes::ExpectedOtherNothing {
leading_ellipsis: __binding_0,
ty_or_sig: __binding_1,
trait_path: __binding_2 } => {
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("leading_ellipsis".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_0,
&mut diag.long_ty_path));
sub_args.insert("ty_or_sig".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("trait_path".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("{$leading_ellipsis ->\n [true] ...\n *[false] {\"\"}\n }`{$ty_or_sig}` must implement `{$trait_path}`")),
&sub_args);
diag.note(__message);
}
ActualImplExplNotes::ButActuallyImplementsTrait {
trait_path: __binding_0,
has_lifetime: __binding_1,
lifetime: __binding_2 } => {
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("trait_path".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_0,
&mut diag.long_ty_path));
sub_args.insert("has_lifetime".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("lifetime".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("...but it actually implements `{$trait_path}`{$has_lifetime ->\n [true] , for some specific lifetime `'{$lifetime}`\n *[false] {\"\"}\n }")),
&sub_args);
diag.note(__message);
}
ActualImplExplNotes::ButActuallyImplementedForTy {
trait_path: __binding_0,
has_lifetime: __binding_1,
lifetime: __binding_2,
ty: __binding_3 } => {
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("trait_path".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_0,
&mut diag.long_ty_path));
sub_args.insert("has_lifetime".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("lifetime".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
sub_args.insert("ty".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_3,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("...but `{$trait_path}` is actually implemented for the type `{$ty}`{$has_lifetime ->\n [true] , for some specific lifetime `'{$lifetime}`\n *[false] {\"\"}\n }")),
&sub_args);
diag.note(__message);
}
ActualImplExplNotes::ButActuallyTyImplements {
trait_path: __binding_0,
has_lifetime: __binding_1,
lifetime: __binding_2,
ty: __binding_3 } => {
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("trait_path".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_0,
&mut diag.long_ty_path));
sub_args.insert("has_lifetime".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("lifetime".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
sub_args.insert("ty".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_3,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("...but `{$ty}` actually implements `{$trait_path}`{$has_lifetime ->\n [true] , for some specific lifetime `'{$lifetime}`\n *[false] {\"\"}\n }")),
&sub_args);
diag.note(__message);
}
}
}
}
};Subdiagnostic)]
908pub(crate) enum ActualImplExplNotes<'tcx> {
909 #[note("{$leading_ellipsis ->
910 [true] ...
911 *[false] {\"\"}
912 }closure with signature `{$ty_or_sig}` must implement `{$trait_path}`, for any two lifetimes `'{$lifetime_1}` and `'{$lifetime_2}`...")]
913 ExpectedSignatureTwo {
914 leading_ellipsis: bool,
915 ty_or_sig: TyOrSig<'tcx>,
916 trait_path: Highlighted<'tcx, TraitRefPrintOnlyTraitPath<'tcx>>,
917 lifetime_1: usize,
918 lifetime_2: usize,
919 },
920 #[note("{$leading_ellipsis ->
921 [true] ...
922 *[false] {\"\"}
923 }closure with signature `{$ty_or_sig}` must implement `{$trait_path}`, for any lifetime `'{$lifetime_1}`...")]
924 ExpectedSignatureAny {
925 leading_ellipsis: bool,
926 ty_or_sig: TyOrSig<'tcx>,
927 trait_path: Highlighted<'tcx, TraitRefPrintOnlyTraitPath<'tcx>>,
928 lifetime_1: usize,
929 },
930 #[note("{$leading_ellipsis ->
931 [true] ...
932 *[false] {\"\"}
933 }closure with signature `{$ty_or_sig}` must implement `{$trait_path}`, for some specific lifetime `'{$lifetime_1}`...")]
934 ExpectedSignatureSome {
935 leading_ellipsis: bool,
936 ty_or_sig: TyOrSig<'tcx>,
937 trait_path: Highlighted<'tcx, TraitRefPrintOnlyTraitPath<'tcx>>,
938 lifetime_1: usize,
939 },
940 #[note(
941 "{$leading_ellipsis ->
942 [true] ...
943 *[false] {\"\"}
944 }closure with signature `{$ty_or_sig}` must implement `{$trait_path}`"
945 )]
946 ExpectedSignatureNothing {
947 leading_ellipsis: bool,
948 ty_or_sig: TyOrSig<'tcx>,
949 trait_path: Highlighted<'tcx, TraitRefPrintOnlyTraitPath<'tcx>>,
950 },
951 #[note("{$leading_ellipsis ->
952 [true] ...
953 *[false] {\"\"}
954 }`{$trait_path}` would have to be implemented for the type `{$ty_or_sig}`, for any two lifetimes `'{$lifetime_1}` and `'{$lifetime_2}`...")]
955 ExpectedPassiveTwo {
956 leading_ellipsis: bool,
957 ty_or_sig: TyOrSig<'tcx>,
958 trait_path: Highlighted<'tcx, TraitRefPrintOnlyTraitPath<'tcx>>,
959 lifetime_1: usize,
960 lifetime_2: usize,
961 },
962 #[note("{$leading_ellipsis ->
963 [true] ...
964 *[false] {\"\"}
965 }`{$trait_path}` would have to be implemented for the type `{$ty_or_sig}`, for any lifetime `'{$lifetime_1}`...")]
966 ExpectedPassiveAny {
967 leading_ellipsis: bool,
968 ty_or_sig: TyOrSig<'tcx>,
969 trait_path: Highlighted<'tcx, TraitRefPrintOnlyTraitPath<'tcx>>,
970 lifetime_1: usize,
971 },
972 #[note("{$leading_ellipsis ->
973 [true] ...
974 *[false] {\"\"}
975 }`{$trait_path}` would have to be implemented for the type `{$ty_or_sig}`, for some specific lifetime `'{$lifetime_1}`...")]
976 ExpectedPassiveSome {
977 leading_ellipsis: bool,
978 ty_or_sig: TyOrSig<'tcx>,
979 trait_path: Highlighted<'tcx, TraitRefPrintOnlyTraitPath<'tcx>>,
980 lifetime_1: usize,
981 },
982 #[note(
983 "{$leading_ellipsis ->
984 [true] ...
985 *[false] {\"\"}
986 }`{$trait_path}` would have to be implemented for the type `{$ty_or_sig}`"
987 )]
988 ExpectedPassiveNothing {
989 leading_ellipsis: bool,
990 ty_or_sig: TyOrSig<'tcx>,
991 trait_path: Highlighted<'tcx, TraitRefPrintOnlyTraitPath<'tcx>>,
992 },
993 #[note("{$leading_ellipsis ->
994 [true] ...
995 *[false] {\"\"}
996 }`{$ty_or_sig}` must implement `{$trait_path}`, for any two lifetimes `'{$lifetime_1}` and `'{$lifetime_2}`...")]
997 ExpectedOtherTwo {
998 leading_ellipsis: bool,
999 ty_or_sig: TyOrSig<'tcx>,
1000 trait_path: Highlighted<'tcx, TraitRefPrintOnlyTraitPath<'tcx>>,
1001 lifetime_1: usize,
1002 lifetime_2: usize,
1003 },
1004 #[note(
1005 "{$leading_ellipsis ->
1006 [true] ...
1007 *[false] {\"\"}
1008 }`{$ty_or_sig}` must implement `{$trait_path}`, for any lifetime `'{$lifetime_1}`..."
1009 )]
1010 ExpectedOtherAny {
1011 leading_ellipsis: bool,
1012 ty_or_sig: TyOrSig<'tcx>,
1013 trait_path: Highlighted<'tcx, TraitRefPrintOnlyTraitPath<'tcx>>,
1014 lifetime_1: usize,
1015 },
1016 #[note(
1017 "{$leading_ellipsis ->
1018 [true] ...
1019 *[false] {\"\"}
1020 }`{$ty_or_sig}` must implement `{$trait_path}`, for some specific lifetime `'{$lifetime_1}`..."
1021 )]
1022 ExpectedOtherSome {
1023 leading_ellipsis: bool,
1024 ty_or_sig: TyOrSig<'tcx>,
1025 trait_path: Highlighted<'tcx, TraitRefPrintOnlyTraitPath<'tcx>>,
1026 lifetime_1: usize,
1027 },
1028 #[note(
1029 "{$leading_ellipsis ->
1030 [true] ...
1031 *[false] {\"\"}
1032 }`{$ty_or_sig}` must implement `{$trait_path}`"
1033 )]
1034 ExpectedOtherNothing {
1035 leading_ellipsis: bool,
1036 ty_or_sig: TyOrSig<'tcx>,
1037 trait_path: Highlighted<'tcx, TraitRefPrintOnlyTraitPath<'tcx>>,
1038 },
1039 #[note(
1040 "...but it actually implements `{$trait_path}`{$has_lifetime ->
1041 [true] , for some specific lifetime `'{$lifetime}`
1042 *[false] {\"\"}
1043 }"
1044 )]
1045 ButActuallyImplementsTrait {
1046 trait_path: Highlighted<'tcx, TraitRefPrintOnlyTraitPath<'tcx>>,
1047 has_lifetime: bool,
1048 lifetime: usize,
1049 },
1050 #[note(
1051 "...but `{$trait_path}` is actually implemented for the type `{$ty}`{$has_lifetime ->
1052 [true] , for some specific lifetime `'{$lifetime}`
1053 *[false] {\"\"}
1054 }"
1055 )]
1056 ButActuallyImplementedForTy {
1057 trait_path: Highlighted<'tcx, TraitRefPrintOnlyTraitPath<'tcx>>,
1058 has_lifetime: bool,
1059 lifetime: usize,
1060 ty: String,
1061 },
1062 #[note(
1063 "...but `{$ty}` actually implements `{$trait_path}`{$has_lifetime ->
1064 [true] , for some specific lifetime `'{$lifetime}`
1065 *[false] {\"\"}
1066 }"
1067 )]
1068 ButActuallyTyImplements {
1069 trait_path: Highlighted<'tcx, TraitRefPrintOnlyTraitPath<'tcx>>,
1070 has_lifetime: bool,
1071 lifetime: usize,
1072 ty: String,
1073 },
1074}
1075
1076pub(crate) enum ActualImplExpectedKind {
1077 Signature,
1078 Passive,
1079 Other,
1080}
1081
1082pub(crate) enum ActualImplExpectedLifetimeKind {
1083 Two,
1084 Any,
1085 Some,
1086 Nothing,
1087}
1088
1089impl<'tcx> ActualImplExplNotes<'tcx> {
1090 pub(crate) fn new_expected(
1091 kind: ActualImplExpectedKind,
1092 lt_kind: ActualImplExpectedLifetimeKind,
1093 leading_ellipsis: bool,
1094 ty_or_sig: TyOrSig<'tcx>,
1095 trait_path: Highlighted<'tcx, TraitRefPrintOnlyTraitPath<'tcx>>,
1096 lifetime_1: usize,
1097 lifetime_2: usize,
1098 ) -> Self {
1099 match (kind, lt_kind) {
1100 (ActualImplExpectedKind::Signature, ActualImplExpectedLifetimeKind::Two) => {
1101 Self::ExpectedSignatureTwo {
1102 leading_ellipsis,
1103 ty_or_sig,
1104 trait_path,
1105 lifetime_1,
1106 lifetime_2,
1107 }
1108 }
1109 (ActualImplExpectedKind::Signature, ActualImplExpectedLifetimeKind::Any) => {
1110 Self::ExpectedSignatureAny { leading_ellipsis, ty_or_sig, trait_path, lifetime_1 }
1111 }
1112 (ActualImplExpectedKind::Signature, ActualImplExpectedLifetimeKind::Some) => {
1113 Self::ExpectedSignatureSome { leading_ellipsis, ty_or_sig, trait_path, lifetime_1 }
1114 }
1115 (ActualImplExpectedKind::Signature, ActualImplExpectedLifetimeKind::Nothing) => {
1116 Self::ExpectedSignatureNothing { leading_ellipsis, ty_or_sig, trait_path }
1117 }
1118 (ActualImplExpectedKind::Passive, ActualImplExpectedLifetimeKind::Two) => {
1119 Self::ExpectedPassiveTwo {
1120 leading_ellipsis,
1121 ty_or_sig,
1122 trait_path,
1123 lifetime_1,
1124 lifetime_2,
1125 }
1126 }
1127 (ActualImplExpectedKind::Passive, ActualImplExpectedLifetimeKind::Any) => {
1128 Self::ExpectedPassiveAny { leading_ellipsis, ty_or_sig, trait_path, lifetime_1 }
1129 }
1130 (ActualImplExpectedKind::Passive, ActualImplExpectedLifetimeKind::Some) => {
1131 Self::ExpectedPassiveSome { leading_ellipsis, ty_or_sig, trait_path, lifetime_1 }
1132 }
1133 (ActualImplExpectedKind::Passive, ActualImplExpectedLifetimeKind::Nothing) => {
1134 Self::ExpectedPassiveNothing { leading_ellipsis, ty_or_sig, trait_path }
1135 }
1136 (ActualImplExpectedKind::Other, ActualImplExpectedLifetimeKind::Two) => {
1137 Self::ExpectedOtherTwo {
1138 leading_ellipsis,
1139 ty_or_sig,
1140 trait_path,
1141 lifetime_1,
1142 lifetime_2,
1143 }
1144 }
1145 (ActualImplExpectedKind::Other, ActualImplExpectedLifetimeKind::Any) => {
1146 Self::ExpectedOtherAny { leading_ellipsis, ty_or_sig, trait_path, lifetime_1 }
1147 }
1148 (ActualImplExpectedKind::Other, ActualImplExpectedLifetimeKind::Some) => {
1149 Self::ExpectedOtherSome { leading_ellipsis, ty_or_sig, trait_path, lifetime_1 }
1150 }
1151 (ActualImplExpectedKind::Other, ActualImplExpectedLifetimeKind::Nothing) => {
1152 Self::ExpectedOtherNothing { leading_ellipsis, ty_or_sig, trait_path }
1153 }
1154 }
1155 }
1156}
1157
1158#[derive(const _: () =
{
impl<'_sess, 'tcx, G> rustc_errors::Diagnostic<'_sess, G> for
TraitPlaceholderMismatch<'tcx> where
G: rustc_errors::EmissionGuarantee {
#[track_caller]
fn into_diag(self, dcx: rustc_errors::DiagCtxtHandle<'_sess>,
level: rustc_errors::Level) -> rustc_errors::Diag<'_sess, G> {
match self {
TraitPlaceholderMismatch {
span: __binding_0,
satisfy_span: __binding_1,
where_span: __binding_2,
dup_span: __binding_3,
def_id: __binding_4,
trait_def_id: __binding_5,
actual_impl_expl_notes: __binding_6 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("implementation of `{$trait_def_id}` is not general enough")));
;
diag.arg("def_id", __binding_4);
diag.arg("trait_def_id", __binding_5);
diag.span(__binding_0);
if let Some(__binding_1) = __binding_1 {
diag.span_label(__binding_1,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("doesn't satisfy where-clause")));
}
if let Some(__binding_2) = __binding_2 {
diag.span_label(__binding_2,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("due to a where-clause on `{$def_id}`...")));
}
if let Some(__binding_3) = __binding_3 {
diag.span_label(__binding_3,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("implementation of `{$trait_def_id}` is not general enough")));
}
for __binding_6 in __binding_6 {
diag.subdiagnostic(__binding_6);
}
diag
}
}
}
}
};Diagnostic)]
1159#[diag("implementation of `{$trait_def_id}` is not general enough")]
1160pub(crate) struct TraitPlaceholderMismatch<'tcx> {
1161 #[primary_span]
1162 pub span: Span,
1163 #[label("doesn't satisfy where-clause")]
1164 pub satisfy_span: Option<Span>,
1165 #[label("due to a where-clause on `{$def_id}`...")]
1166 pub where_span: Option<Span>,
1167 #[label("implementation of `{$trait_def_id}` is not general enough")]
1168 pub dup_span: Option<Span>,
1169 pub def_id: String,
1170 pub trait_def_id: String,
1171
1172 #[subdiagnostic]
1173 pub actual_impl_expl_notes: Vec<ActualImplExplNotes<'tcx>>,
1174}
1175
1176pub(crate) struct ConsiderBorrowingParamHelp {
1177 pub spans: Vec<Span>,
1178}
1179
1180impl Subdiagnostic for ConsiderBorrowingParamHelp {
1181 fn add_to_diag<G: EmissionGuarantee>(self, diag: &mut Diag<'_, G>) {
1182 let mut type_param_span: MultiSpan = self.spans.clone().into();
1183 for &span in &self.spans {
1184 type_param_span
1186 .push_span_label(span, rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("consider borrowing this type parameter in the trait"))msg!("consider borrowing this type parameter in the trait"));
1187 }
1188 let msg = rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("the lifetime requirements from the `impl` do not correspond to the requirements in the `trait`"))msg!(
1189 "the lifetime requirements from the `impl` do not correspond to the requirements in the `trait`"
1190 );
1191 diag.span_help(type_param_span, msg);
1192 }
1193}
1194
1195#[derive(const _: () =
{
impl<'_sess, G> rustc_errors::Diagnostic<'_sess, G> for TraitImplDiff
where G: rustc_errors::EmissionGuarantee {
#[track_caller]
fn into_diag(self, dcx: rustc_errors::DiagCtxtHandle<'_sess>,
level: rustc_errors::Level) -> rustc_errors::Diag<'_sess, G> {
match self {
TraitImplDiff {
sp: __binding_0,
trait_sp: __binding_1,
note: __binding_2,
param_help: __binding_3,
rel_help: __binding_4,
expected: __binding_5,
found: __binding_6 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("`impl` item signature doesn't match `trait` item signature")));
;
diag.arg("expected", __binding_5);
diag.arg("found", __binding_6);
diag.span(__binding_0);
diag.span_label(__binding_0,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("found `{$found}`")));
diag.span_label(__binding_1,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("expected `{$expected}`")));
diag.note(rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("expected signature `{$expected}`\n {\" \"}found signature `{$found}`")));
diag.subdiagnostic(__binding_3);
if __binding_4 {
diag.help(rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("verify the lifetime relationships in the `trait` and `impl` between the `self` argument, the other inputs and its output")));
}
diag
}
}
}
}
};Diagnostic)]
1196#[diag("`impl` item signature doesn't match `trait` item signature")]
1197pub(crate) struct TraitImplDiff {
1198 #[primary_span]
1199 #[label("found `{$found}`")]
1200 pub sp: Span,
1201 #[label("expected `{$expected}`")]
1202 pub trait_sp: Span,
1203 #[note(
1204 "expected signature `{$expected}`
1205 {\" \"}found signature `{$found}`"
1206 )]
1207 pub note: (),
1208 #[subdiagnostic]
1209 pub param_help: ConsiderBorrowingParamHelp,
1210 #[help(
1211 "verify the lifetime relationships in the `trait` and `impl` between the `self` argument, the other inputs and its output"
1212 )]
1213 pub rel_help: bool,
1214 pub expected: String,
1215 pub found: String,
1216}
1217
1218#[derive(const _: () =
{
impl<'_sess, G> rustc_errors::Diagnostic<'_sess, G> for
ButNeedsToSatisfy where G: rustc_errors::EmissionGuarantee {
#[track_caller]
fn into_diag(self, dcx: rustc_errors::DiagCtxtHandle<'_sess>,
level: rustc_errors::Level) -> rustc_errors::Diag<'_sess, G> {
match self {
ButNeedsToSatisfy {
sp: __binding_0,
influencer_point: __binding_1,
spans: __binding_2,
require_span_as_label: __binding_3,
require_span_as_note: __binding_4,
bound: __binding_5,
has_param_name: __binding_6,
param_name: __binding_7,
spans_empty: __binding_8,
has_lifetime: __binding_9,
lifetime: __binding_10 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("{$has_param_name ->\n [true] `{$param_name}`\n *[false] `fn` parameter\n} has {$has_lifetime ->\n [true] lifetime `{$lifetime}`\n *[false] an anonymous lifetime `'_`\n} but it needs to satisfy a `'static` lifetime requirement")));
diag.code(E0759);
;
diag.arg("has_param_name", __binding_6);
diag.arg("param_name", __binding_7);
diag.arg("spans_empty", __binding_8);
diag.arg("has_lifetime", __binding_9);
diag.arg("lifetime", __binding_10);
diag.span(__binding_0);
diag.span_label(__binding_1,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("this data with {$has_lifetime ->\n [true] lifetime `{$lifetime}`\n *[false] an anonymous lifetime `'_`\n }...")));
for __binding_2 in __binding_2 {
diag.span_label(__binding_2,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("...is used here...")));
}
if let Some(__binding_3) = __binding_3 {
diag.span_label(__binding_3,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("{$spans_empty ->\n *[true] ...is used and required to live as long as `'static` here\n [false] ...and is required to live as long as `'static` here\n }")));
}
if let Some(__binding_4) = __binding_4 {
diag.span_note(__binding_4,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("{$spans_empty ->\n *[true] ...is used and required to live as long as `'static` here\n [false] ...and is required to live as long as `'static` here\n }")));
}
if let Some(__binding_5) = __binding_5 {
diag.span_note(__binding_5,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("`'static` lifetime requirement introduced by this bound")));
}
diag
}
}
}
}
};Diagnostic)]
1219#[diag("{$has_param_name ->
1220 [true] `{$param_name}`
1221 *[false] `fn` parameter
1222} has {$has_lifetime ->
1223 [true] lifetime `{$lifetime}`
1224 *[false] an anonymous lifetime `'_`
1225} but it needs to satisfy a `'static` lifetime requirement", code = E0759)]
1226pub(crate) struct ButNeedsToSatisfy {
1227 #[primary_span]
1228 pub sp: Span,
1229 #[label(
1230 "this data with {$has_lifetime ->
1231 [true] lifetime `{$lifetime}`
1232 *[false] an anonymous lifetime `'_`
1233 }..."
1234 )]
1235 pub influencer_point: Span,
1236 #[label("...is used here...")]
1237 pub spans: Vec<Span>,
1238 #[label(
1239 "{$spans_empty ->
1240 *[true] ...is used and required to live as long as `'static` here
1241 [false] ...and is required to live as long as `'static` here
1242 }"
1243 )]
1244 pub require_span_as_label: Option<Span>,
1245 #[note(
1246 "{$spans_empty ->
1247 *[true] ...is used and required to live as long as `'static` here
1248 [false] ...and is required to live as long as `'static` here
1249 }"
1250 )]
1251 pub require_span_as_note: Option<Span>,
1252 #[note("`'static` lifetime requirement introduced by this bound")]
1253 pub bound: Option<Span>,
1254
1255 pub has_param_name: bool,
1256 pub param_name: String,
1257 pub spans_empty: bool,
1258 pub has_lifetime: bool,
1259 pub lifetime: String,
1260}
1261
1262#[derive(const _: () =
{
impl<'_sess, 'a, G> rustc_errors::Diagnostic<'_sess, G> for
OutlivesContent<'a> where G: rustc_errors::EmissionGuarantee {
#[track_caller]
fn into_diag(self, dcx: rustc_errors::DiagCtxtHandle<'_sess>,
level: rustc_errors::Level) -> rustc_errors::Diag<'_sess, G> {
match self {
OutlivesContent { span: __binding_0, notes: __binding_1 } =>
{
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("lifetime of reference outlives lifetime of borrowed content...")));
diag.code(E0312);
;
diag.span(__binding_0);
for __binding_1 in __binding_1 {
diag.subdiagnostic(__binding_1);
}
diag
}
}
}
}
};Diagnostic)]
1263#[diag("lifetime of reference outlives lifetime of borrowed content...", code = E0312)]
1264pub(crate) struct OutlivesContent<'a> {
1265 #[primary_span]
1266 pub span: Span,
1267 #[subdiagnostic]
1268 pub notes: Vec<note_and_explain::RegionExplanation<'a>>,
1269}
1270
1271#[derive(const _: () =
{
impl<'_sess, 'a, G> rustc_errors::Diagnostic<'_sess, G> for
OutlivesBound<'a> where G: rustc_errors::EmissionGuarantee {
#[track_caller]
fn into_diag(self, dcx: rustc_errors::DiagCtxtHandle<'_sess>,
level: rustc_errors::Level) -> rustc_errors::Diag<'_sess, G> {
match self {
OutlivesBound { span: __binding_0, notes: __binding_1 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("lifetime of the source pointer does not outlive lifetime bound of the object type")));
diag.code(E0476);
;
diag.span(__binding_0);
for __binding_1 in __binding_1 {
diag.subdiagnostic(__binding_1);
}
diag
}
}
}
}
};Diagnostic)]
1272#[diag("lifetime of the source pointer does not outlive lifetime bound of the object type", code = E0476)]
1273pub(crate) struct OutlivesBound<'a> {
1274 #[primary_span]
1275 pub span: Span,
1276 #[subdiagnostic]
1277 pub notes: Vec<note_and_explain::RegionExplanation<'a>>,
1278}
1279
1280#[derive(const _: () =
{
impl<'_sess, 'a, G> rustc_errors::Diagnostic<'_sess, G> for
FulfillReqLifetime<'a> where G: rustc_errors::EmissionGuarantee {
#[track_caller]
fn into_diag(self, dcx: rustc_errors::DiagCtxtHandle<'_sess>,
level: rustc_errors::Level) -> rustc_errors::Diag<'_sess, G> {
match self {
FulfillReqLifetime {
span: __binding_0, ty: __binding_1, note: __binding_2 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("the type `{$ty}` does not fulfill the required lifetime")));
diag.code(E0477);
;
diag.arg("ty", __binding_1);
diag.span(__binding_0);
if let Some(__binding_2) = __binding_2 {
diag.subdiagnostic(__binding_2);
}
diag
}
}
}
}
};Diagnostic)]
1281#[diag("the type `{$ty}` does not fulfill the required lifetime", code = E0477)]
1282pub(crate) struct FulfillReqLifetime<'a> {
1283 #[primary_span]
1284 pub span: Span,
1285 pub ty: Ty<'a>,
1286 #[subdiagnostic]
1287 pub note: Option<note_and_explain::RegionExplanation<'a>>,
1288}
1289
1290#[derive(const _: () =
{
impl<'_sess, 'a, G> rustc_errors::Diagnostic<'_sess, G> for
LfBoundNotSatisfied<'a> where G: rustc_errors::EmissionGuarantee {
#[track_caller]
fn into_diag(self, dcx: rustc_errors::DiagCtxtHandle<'_sess>,
level: rustc_errors::Level) -> rustc_errors::Diag<'_sess, G> {
match self {
LfBoundNotSatisfied { span: __binding_0, notes: __binding_1
} => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("lifetime bound not satisfied")));
diag.code(E0478);
;
diag.span(__binding_0);
for __binding_1 in __binding_1 {
diag.subdiagnostic(__binding_1);
}
diag
}
}
}
}
};Diagnostic)]
1291#[diag("lifetime bound not satisfied", code = E0478)]
1292pub(crate) struct LfBoundNotSatisfied<'a> {
1293 #[primary_span]
1294 pub span: Span,
1295 #[subdiagnostic]
1296 pub notes: Vec<note_and_explain::RegionExplanation<'a>>,
1297}
1298
1299#[derive(const _: () =
{
impl<'_sess, 'a, G> rustc_errors::Diagnostic<'_sess, G> for
RefLongerThanData<'a> where G: rustc_errors::EmissionGuarantee {
#[track_caller]
fn into_diag(self, dcx: rustc_errors::DiagCtxtHandle<'_sess>,
level: rustc_errors::Level) -> rustc_errors::Diag<'_sess, G> {
match self {
RefLongerThanData {
span: __binding_0, ty: __binding_1, notes: __binding_2 } =>
{
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("in type `{$ty}`, reference has a longer lifetime than the data it references")));
diag.code(E0491);
;
diag.arg("ty", __binding_1);
diag.span(__binding_0);
for __binding_2 in __binding_2 {
diag.subdiagnostic(__binding_2);
}
diag
}
}
}
}
};Diagnostic)]
1300#[diag("in type `{$ty}`, reference has a longer lifetime than the data it references", code = E0491)]
1301pub(crate) struct RefLongerThanData<'a> {
1302 #[primary_span]
1303 pub span: Span,
1304 pub ty: Ty<'a>,
1305 #[subdiagnostic]
1306 pub notes: Vec<note_and_explain::RegionExplanation<'a>>,
1307}
1308
1309#[derive(const _: () =
{
impl rustc_errors::Subdiagnostic for WhereClauseSuggestions {
fn add_to_diag<__G>(self, diag: &mut rustc_errors::Diag<'_, __G>)
where __G: rustc_errors::EmissionGuarantee {
match self {
WhereClauseSuggestions::Remove { span: __binding_0 } => {
let __code_11 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!(""))
})].into_iter();
let mut sub_args = rustc_errors::DiagArgMap::default();
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("remove the `where` clause")),
&sub_args);
diag.span_suggestions_with_style(__binding_0, __message,
__code_11, rustc_errors::Applicability::MachineApplicable,
rustc_errors::SuggestionStyle::ShowAlways);
}
WhereClauseSuggestions::CopyPredicates {
span: __binding_0,
space: __binding_1,
trait_predicates: __binding_2 } => {
let __code_12 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0}where {1}",
__binding_1, __binding_2))
})].into_iter();
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("space".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("trait_predicates".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("copy the `where` clause predicates from the trait")),
&sub_args);
diag.span_suggestions_with_style(__binding_0, __message,
__code_12, rustc_errors::Applicability::MachineApplicable,
rustc_errors::SuggestionStyle::ShowAlways);
}
}
}
}
};Subdiagnostic)]
1310pub(crate) enum WhereClauseSuggestions {
1311 #[suggestion(
1312 "remove the `where` clause",
1313 code = "",
1314 applicability = "machine-applicable",
1315 style = "verbose"
1316 )]
1317 Remove {
1318 #[primary_span]
1319 span: Span,
1320 },
1321 #[suggestion(
1322 "copy the `where` clause predicates from the trait",
1323 code = "{space}where {trait_predicates}",
1324 applicability = "machine-applicable",
1325 style = "verbose"
1326 )]
1327 CopyPredicates {
1328 #[primary_span]
1329 span: Span,
1330 space: &'static str,
1331 trait_predicates: String,
1332 },
1333}
1334
1335#[derive(const _: () =
{
impl rustc_errors::Subdiagnostic for SuggestRemoveSemiOrReturnBinding
{
fn add_to_diag<__G>(self, diag: &mut rustc_errors::Diag<'_, __G>)
where __G: rustc_errors::EmissionGuarantee {
match self {
SuggestRemoveSemiOrReturnBinding::RemoveAndBox {
first_lo: __binding_0,
first_hi: __binding_1,
second_lo: __binding_2,
second_hi: __binding_3,
sp: __binding_4 } => {
let mut suggestions = Vec::new();
let __code_13 =
::alloc::__export::must_use({
::alloc::fmt::format(format_args!("Box::new("))
});
let __code_14 =
::alloc::__export::must_use({
::alloc::fmt::format(format_args!(")"))
});
let __code_15 =
::alloc::__export::must_use({
::alloc::fmt::format(format_args!("Box::new("))
});
let __code_16 =
::alloc::__export::must_use({
::alloc::fmt::format(format_args!(")"))
});
let __code_17 =
::alloc::__export::must_use({
::alloc::fmt::format(format_args!(""))
});
suggestions.push((__binding_0, __code_13));
suggestions.push((__binding_1, __code_14));
suggestions.push((__binding_2, __code_15));
suggestions.push((__binding_3, __code_16));
suggestions.push((__binding_4, __code_17));
let mut sub_args = rustc_errors::DiagArgMap::default();
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("consider removing this semicolon and boxing the expressions")),
&sub_args);
diag.multipart_suggestion_with_style(__message, suggestions,
rustc_errors::Applicability::MachineApplicable,
rustc_errors::SuggestionStyle::ShowCode);
}
SuggestRemoveSemiOrReturnBinding::Remove { sp: __binding_0 }
=> {
let __code_18 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!(""))
})].into_iter();
let mut sub_args = rustc_errors::DiagArgMap::default();
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("consider removing this semicolon")),
&sub_args);
diag.span_suggestions_with_style(__binding_0, __message,
__code_18, rustc_errors::Applicability::MachineApplicable,
rustc_errors::SuggestionStyle::HideCodeInline);
}
SuggestRemoveSemiOrReturnBinding::Add {
sp: __binding_0, code: __binding_1, ident: __binding_2 } =>
{
let __code_19 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0}", __binding_1))
})].into_iter();
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("code".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("ident".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("consider returning the local binding `{$ident}`")),
&sub_args);
diag.span_suggestions_with_style(__binding_0, __message,
__code_19, rustc_errors::Applicability::MaybeIncorrect,
rustc_errors::SuggestionStyle::ShowAlways);
}
SuggestRemoveSemiOrReturnBinding::AddOne {
spans: __binding_0 } => {
let mut sub_args = rustc_errors::DiagArgMap::default();
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("consider returning one of these bindings")),
&sub_args);
diag.span_note(__binding_0, __message);
}
}
}
}
};Subdiagnostic)]
1336pub(crate) enum SuggestRemoveSemiOrReturnBinding {
1337 #[multipart_suggestion(
1338 "consider removing this semicolon and boxing the expressions",
1339 applicability = "machine-applicable"
1340 )]
1341 RemoveAndBox {
1342 #[suggestion_part(code = "Box::new(")]
1343 first_lo: Span,
1344 #[suggestion_part(code = ")")]
1345 first_hi: Span,
1346 #[suggestion_part(code = "Box::new(")]
1347 second_lo: Span,
1348 #[suggestion_part(code = ")")]
1349 second_hi: Span,
1350 #[suggestion_part(code = "")]
1351 sp: Span,
1352 },
1353 #[suggestion(
1354 "consider removing this semicolon",
1355 style = "short",
1356 code = "",
1357 applicability = "machine-applicable"
1358 )]
1359 Remove {
1360 #[primary_span]
1361 sp: Span,
1362 },
1363 #[suggestion(
1364 "consider returning the local binding `{$ident}`",
1365 style = "verbose",
1366 code = "{code}",
1367 applicability = "maybe-incorrect"
1368 )]
1369 Add {
1370 #[primary_span]
1371 sp: Span,
1372 code: String,
1373 ident: Ident,
1374 },
1375 #[note("consider returning one of these bindings")]
1376 AddOne {
1377 #[primary_span]
1378 spans: MultiSpan,
1379 },
1380}
1381
1382#[derive(const _: () =
{
impl rustc_errors::Subdiagnostic for ConsiderAddingAwait {
fn add_to_diag<__G>(self, diag: &mut rustc_errors::Diag<'_, __G>)
where __G: rustc_errors::EmissionGuarantee {
match self {
ConsiderAddingAwait::BothFuturesHelp => {
let mut sub_args = rustc_errors::DiagArgMap::default();
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("consider `await`ing on both `Future`s")),
&sub_args);
diag.help(__message);
}
ConsiderAddingAwait::BothFuturesSugg {
first: __binding_0, second: __binding_1 } => {
let mut suggestions = Vec::new();
let __code_20 =
::alloc::__export::must_use({
::alloc::fmt::format(format_args!(".await"))
});
let __code_21 =
::alloc::__export::must_use({
::alloc::fmt::format(format_args!(".await"))
});
suggestions.push((__binding_0, __code_20));
suggestions.push((__binding_1, __code_21));
let mut sub_args = rustc_errors::DiagArgMap::default();
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("consider `await`ing on both `Future`s")),
&sub_args);
diag.multipart_suggestion_with_style(__message, suggestions,
rustc_errors::Applicability::MaybeIncorrect,
rustc_errors::SuggestionStyle::ShowCode);
}
ConsiderAddingAwait::FutureSugg { span: __binding_0 } => {
let __code_22 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!(".await"))
})].into_iter();
let mut sub_args = rustc_errors::DiagArgMap::default();
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("consider `await`ing on the `Future`")),
&sub_args);
diag.span_suggestions_with_style(__binding_0, __message,
__code_22, rustc_errors::Applicability::MaybeIncorrect,
rustc_errors::SuggestionStyle::ShowAlways);
}
ConsiderAddingAwait::FutureSuggNote { span: __binding_0 } =>
{
let mut sub_args = rustc_errors::DiagArgMap::default();
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("calling an async function returns a future")),
&sub_args);
diag.span_note(__binding_0, __message);
}
ConsiderAddingAwait::FutureSuggMultiple { spans: __binding_0
} => {
let mut suggestions = Vec::new();
let __code_23 =
::alloc::__export::must_use({
::alloc::fmt::format(format_args!(".await"))
});
for __binding_0 in __binding_0 {
suggestions.push((__binding_0, __code_23.clone()));
}
let mut sub_args = rustc_errors::DiagArgMap::default();
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("consider `await`ing on the `Future`")),
&sub_args);
diag.multipart_suggestion_with_style(__message, suggestions,
rustc_errors::Applicability::MaybeIncorrect,
rustc_errors::SuggestionStyle::ShowAlways);
}
}
}
}
};Subdiagnostic)]
1383pub(crate) enum ConsiderAddingAwait {
1384 #[help("consider `await`ing on both `Future`s")]
1385 BothFuturesHelp,
1386 #[multipart_suggestion(
1387 "consider `await`ing on both `Future`s",
1388 applicability = "maybe-incorrect"
1389 )]
1390 BothFuturesSugg {
1391 #[suggestion_part(code = ".await")]
1392 first: Span,
1393 #[suggestion_part(code = ".await")]
1394 second: Span,
1395 },
1396 #[suggestion(
1397 "consider `await`ing on the `Future`",
1398 code = ".await",
1399 style = "verbose",
1400 applicability = "maybe-incorrect"
1401 )]
1402 FutureSugg {
1403 #[primary_span]
1404 span: Span,
1405 },
1406 #[note("calling an async function returns a future")]
1407 FutureSuggNote {
1408 #[primary_span]
1409 span: Span,
1410 },
1411 #[multipart_suggestion(
1412 "consider `await`ing on the `Future`",
1413 style = "verbose",
1414 applicability = "maybe-incorrect"
1415 )]
1416 FutureSuggMultiple {
1417 #[suggestion_part(code = ".await")]
1418 spans: Vec<Span>,
1419 },
1420}
1421
1422#[derive(const _: () =
{
impl<'_sess, G> rustc_errors::Diagnostic<'_sess, G> for
PlaceholderRelationLfNotSatisfied where
G: rustc_errors::EmissionGuarantee {
#[track_caller]
fn into_diag(self, dcx: rustc_errors::DiagCtxtHandle<'_sess>,
level: rustc_errors::Level) -> rustc_errors::Diag<'_sess, G> {
match self {
PlaceholderRelationLfNotSatisfied::HasBoth {
span: __binding_0,
sub_span: __binding_1,
sup_span: __binding_2,
sub_symbol: __binding_3,
sup_symbol: __binding_4,
note: __binding_5 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("lifetime bound not satisfied")));
;
diag.arg("sub_symbol", __binding_3);
diag.arg("sup_symbol", __binding_4);
diag.span(__binding_0);
diag.span_note(__binding_1,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("the lifetime `{$sub_symbol}` defined here...")));
diag.span_note(__binding_2,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("...must outlive the lifetime `{$sup_symbol}` defined here")));
diag.note(rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("this is a known limitation that will be removed in the future (see issue #100013 <https://github.com/rust-lang/rust/issues/100013> for more information)")));
diag
}
PlaceholderRelationLfNotSatisfied::HasSub {
span: __binding_0,
sub_span: __binding_1,
sup_span: __binding_2,
sub_symbol: __binding_3,
note: __binding_4 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("lifetime bound not satisfied")));
;
diag.arg("sub_symbol", __binding_3);
diag.span(__binding_0);
diag.span_note(__binding_1,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("the lifetime `{$sub_symbol}` defined here...")));
diag.span_note(__binding_2,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("...must outlive the lifetime defined here")));
diag.note(rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("this is a known limitation that will be removed in the future (see issue #100013 <https://github.com/rust-lang/rust/issues/100013> for more information)")));
diag
}
PlaceholderRelationLfNotSatisfied::HasSup {
span: __binding_0,
sub_span: __binding_1,
sup_span: __binding_2,
sup_symbol: __binding_3,
note: __binding_4 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("lifetime bound not satisfied")));
;
diag.arg("sup_symbol", __binding_3);
diag.span(__binding_0);
diag.span_note(__binding_1,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("the lifetime defined here...")));
diag.span_note(__binding_2,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("...must outlive the lifetime `{$sup_symbol}` defined here")));
diag.note(rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("this is a known limitation that will be removed in the future (see issue #100013 <https://github.com/rust-lang/rust/issues/100013> for more information)")));
diag
}
PlaceholderRelationLfNotSatisfied::HasNone {
span: __binding_0,
sub_span: __binding_1,
sup_span: __binding_2,
note: __binding_3 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("lifetime bound not satisfied")));
;
diag.span(__binding_0);
diag.span_note(__binding_1,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("the lifetime defined here...")));
diag.span_note(__binding_2,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("...must outlive the lifetime defined here")));
diag.note(rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("this is a known limitation that will be removed in the future (see issue #100013 <https://github.com/rust-lang/rust/issues/100013> for more information)")));
diag
}
PlaceholderRelationLfNotSatisfied::OnlyPrimarySpan {
span: __binding_0, note: __binding_1 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("lifetime bound not satisfied")));
;
diag.span(__binding_0);
diag.note(rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("this is a known limitation that will be removed in the future (see issue #100013 <https://github.com/rust-lang/rust/issues/100013> for more information)")));
diag
}
}
}
}
};Diagnostic)]
1423pub(crate) enum PlaceholderRelationLfNotSatisfied {
1424 #[diag("lifetime bound not satisfied")]
1425 HasBoth {
1426 #[primary_span]
1427 span: Span,
1428 #[note("the lifetime `{$sub_symbol}` defined here...")]
1429 sub_span: Span,
1430 #[note("...must outlive the lifetime `{$sup_symbol}` defined here")]
1431 sup_span: Span,
1432 sub_symbol: Symbol,
1433 sup_symbol: Symbol,
1434 #[note(
1435 "this is a known limitation that will be removed in the future (see issue #100013 <https://github.com/rust-lang/rust/issues/100013> for more information)"
1436 )]
1437 note: (),
1438 },
1439 #[diag("lifetime bound not satisfied")]
1440 HasSub {
1441 #[primary_span]
1442 span: Span,
1443 #[note("the lifetime `{$sub_symbol}` defined here...")]
1444 sub_span: Span,
1445 #[note("...must outlive the lifetime defined here")]
1446 sup_span: Span,
1447 sub_symbol: Symbol,
1448 #[note(
1449 "this is a known limitation that will be removed in the future (see issue #100013 <https://github.com/rust-lang/rust/issues/100013> for more information)"
1450 )]
1451 note: (),
1452 },
1453 #[diag("lifetime bound not satisfied")]
1454 HasSup {
1455 #[primary_span]
1456 span: Span,
1457 #[note("the lifetime defined here...")]
1458 sub_span: Span,
1459 #[note("...must outlive the lifetime `{$sup_symbol}` defined here")]
1460 sup_span: Span,
1461 sup_symbol: Symbol,
1462 #[note(
1463 "this is a known limitation that will be removed in the future (see issue #100013 <https://github.com/rust-lang/rust/issues/100013> for more information)"
1464 )]
1465 note: (),
1466 },
1467 #[diag("lifetime bound not satisfied")]
1468 HasNone {
1469 #[primary_span]
1470 span: Span,
1471 #[note("the lifetime defined here...")]
1472 sub_span: Span,
1473 #[note("...must outlive the lifetime defined here")]
1474 sup_span: Span,
1475 #[note(
1476 "this is a known limitation that will be removed in the future (see issue #100013 <https://github.com/rust-lang/rust/issues/100013> for more information)"
1477 )]
1478 note: (),
1479 },
1480 #[diag("lifetime bound not satisfied")]
1481 OnlyPrimarySpan {
1482 #[primary_span]
1483 span: Span,
1484 #[note(
1485 "this is a known limitation that will be removed in the future (see issue #100013 <https://github.com/rust-lang/rust/issues/100013> for more information)"
1486 )]
1487 note: (),
1488 },
1489}
1490
1491#[derive(const _: () =
{
impl<'_sess, 'tcx, G> rustc_errors::Diagnostic<'_sess, G> for
OpaqueCapturesLifetime<'tcx> where
G: rustc_errors::EmissionGuarantee {
#[track_caller]
fn into_diag(self, dcx: rustc_errors::DiagCtxtHandle<'_sess>,
level: rustc_errors::Level) -> rustc_errors::Diag<'_sess, G> {
match self {
OpaqueCapturesLifetime {
span: __binding_0,
opaque_ty_span: __binding_1,
opaque_ty: __binding_2 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("hidden type for `{$opaque_ty}` captures lifetime that does not appear in bounds")));
diag.code(E0700);
;
diag.arg("opaque_ty", __binding_2);
diag.span(__binding_0);
diag.span_label(__binding_1,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("opaque type defined here")));
diag
}
}
}
}
};Diagnostic)]
1492#[diag("hidden type for `{$opaque_ty}` captures lifetime that does not appear in bounds", code = E0700)]
1493pub(crate) struct OpaqueCapturesLifetime<'tcx> {
1494 #[primary_span]
1495 pub span: Span,
1496 #[label("opaque type defined here")]
1497 pub opaque_ty_span: Span,
1498 pub opaque_ty: Ty<'tcx>,
1499}
1500
1501#[derive(const _: () =
{
impl<'a> rustc_errors::Subdiagnostic for FunctionPointerSuggestion<'a>
{
fn add_to_diag<__G>(self, diag: &mut rustc_errors::Diag<'_, __G>)
where __G: rustc_errors::EmissionGuarantee {
match self {
FunctionPointerSuggestion::UseRef { span: __binding_0 } => {
let __code_24 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!("&"))
})].into_iter();
let mut sub_args = rustc_errors::DiagArgMap::default();
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("consider using a reference")),
&sub_args);
diag.span_suggestions_with_style(__binding_0, __message,
__code_24, rustc_errors::Applicability::MaybeIncorrect,
rustc_errors::SuggestionStyle::ShowAlways);
}
FunctionPointerSuggestion::RemoveRef {
span: __binding_0, fn_name: __binding_1 } => {
let __code_25 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0}", __binding_1))
})].into_iter();
let mut sub_args = rustc_errors::DiagArgMap::default();
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("consider removing the reference")),
&sub_args);
diag.span_suggestions_with_style(__binding_0, __message,
__code_25, rustc_errors::Applicability::MaybeIncorrect,
rustc_errors::SuggestionStyle::ShowAlways);
}
FunctionPointerSuggestion::CastRef {
span: __binding_0, fn_name: __binding_1, sig: __binding_2 }
=> {
let __code_26 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!("&({0} as {1})",
__binding_1, __binding_2))
})].into_iter();
let mut sub_args = rustc_errors::DiagArgMap::default();
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("consider casting to a fn pointer")),
&sub_args);
diag.span_suggestions_with_style(__binding_0, __message,
__code_26, rustc_errors::Applicability::MaybeIncorrect,
rustc_errors::SuggestionStyle::ShowAlways);
}
FunctionPointerSuggestion::Cast {
span: __binding_0, sig: __binding_1 } => {
let __code_27 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!(" as {0}", __binding_1))
})].into_iter();
let mut sub_args = rustc_errors::DiagArgMap::default();
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("consider casting to a fn pointer")),
&sub_args);
diag.span_suggestions_with_style(__binding_0, __message,
__code_27, rustc_errors::Applicability::MaybeIncorrect,
rustc_errors::SuggestionStyle::ShowAlways);
}
FunctionPointerSuggestion::CastBoth {
span: __binding_0,
found_sig: __binding_1,
expected_sig: __binding_2 } => {
let __code_28 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!(" as {0}", __binding_1))
})].into_iter();
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("expected_sig".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("consider casting both fn items to fn pointers using `as {$expected_sig}`")),
&sub_args);
diag.span_suggestions_with_style(__binding_0, __message,
__code_28, rustc_errors::Applicability::MaybeIncorrect,
rustc_errors::SuggestionStyle::HideCodeAlways);
}
FunctionPointerSuggestion::CastBothRef {
span: __binding_0,
fn_name: __binding_1,
found_sig: __binding_2,
expected_sig: __binding_3 } => {
let __code_29 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!("&({0} as {1})",
__binding_1, __binding_2))
})].into_iter();
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("expected_sig".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_3,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("consider casting both fn items to fn pointers using `as {$expected_sig}`")),
&sub_args);
diag.span_suggestions_with_style(__binding_0, __message,
__code_29, rustc_errors::Applicability::MaybeIncorrect,
rustc_errors::SuggestionStyle::HideCodeAlways);
}
}
}
}
};Subdiagnostic)]
1502pub(crate) enum FunctionPointerSuggestion<'a> {
1503 #[suggestion(
1504 "consider using a reference",
1505 code = "&",
1506 style = "verbose",
1507 applicability = "maybe-incorrect"
1508 )]
1509 UseRef {
1510 #[primary_span]
1511 span: Span,
1512 },
1513 #[suggestion(
1514 "consider removing the reference",
1515 code = "{fn_name}",
1516 style = "verbose",
1517 applicability = "maybe-incorrect"
1518 )]
1519 RemoveRef {
1520 #[primary_span]
1521 span: Span,
1522 #[skip_arg]
1523 fn_name: String,
1524 },
1525 #[suggestion(
1526 "consider casting to a fn pointer",
1527 code = "&({fn_name} as {sig})",
1528 style = "verbose",
1529 applicability = "maybe-incorrect"
1530 )]
1531 CastRef {
1532 #[primary_span]
1533 span: Span,
1534 #[skip_arg]
1535 fn_name: String,
1536 #[skip_arg]
1537 sig: Binder<'a, FnSig<'a>>,
1538 },
1539 #[suggestion(
1540 "consider casting to a fn pointer",
1541 code = " as {sig}",
1542 style = "verbose",
1543 applicability = "maybe-incorrect"
1544 )]
1545 Cast {
1546 #[primary_span]
1547 span: Span,
1548 #[skip_arg]
1549 sig: Binder<'a, FnSig<'a>>,
1550 },
1551 #[suggestion(
1552 "consider casting both fn items to fn pointers using `as {$expected_sig}`",
1553 code = " as {found_sig}",
1554 style = "hidden",
1555 applicability = "maybe-incorrect"
1556 )]
1557 CastBoth {
1558 #[primary_span]
1559 span: Span,
1560 #[skip_arg]
1561 found_sig: Binder<'a, FnSig<'a>>,
1562 expected_sig: Binder<'a, FnSig<'a>>,
1563 },
1564 #[suggestion(
1565 "consider casting both fn items to fn pointers using `as {$expected_sig}`",
1566 code = "&({fn_name} as {found_sig})",
1567 style = "hidden",
1568 applicability = "maybe-incorrect"
1569 )]
1570 CastBothRef {
1571 #[primary_span]
1572 span: Span,
1573 #[skip_arg]
1574 fn_name: String,
1575 #[skip_arg]
1576 found_sig: Binder<'a, FnSig<'a>>,
1577 expected_sig: Binder<'a, FnSig<'a>>,
1578 },
1579}
1580
1581#[derive(const _: () =
{
impl rustc_errors::Subdiagnostic for FnItemsAreDistinct {
fn add_to_diag<__G>(self, diag: &mut rustc_errors::Diag<'_, __G>)
where __G: rustc_errors::EmissionGuarantee {
match self {
FnItemsAreDistinct => {
let mut sub_args = rustc_errors::DiagArgMap::default();
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("fn items are distinct from fn pointers")),
&sub_args);
diag.note(__message);
}
}
}
}
};Subdiagnostic)]
1582#[note("fn items are distinct from fn pointers")]
1583pub(crate) struct FnItemsAreDistinct;
1584
1585#[derive(const _: () =
{
impl rustc_errors::Subdiagnostic for FnUniqTypes {
fn add_to_diag<__G>(self, diag: &mut rustc_errors::Diag<'_, __G>)
where __G: rustc_errors::EmissionGuarantee {
match self {
FnUniqTypes => {
let mut sub_args = rustc_errors::DiagArgMap::default();
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("different fn items have unique types, even if their signatures are the same")),
&sub_args);
diag.note(__message);
}
}
}
}
};Subdiagnostic)]
1586#[note("different fn items have unique types, even if their signatures are the same")]
1587pub(crate) struct FnUniqTypes;
1588
1589#[derive(const _: () =
{
impl rustc_errors::Subdiagnostic for FnConsiderCasting {
fn add_to_diag<__G>(self, diag: &mut rustc_errors::Diag<'_, __G>)
where __G: rustc_errors::EmissionGuarantee {
match self {
FnConsiderCasting { casting: __binding_0 } => {
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("casting".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_0,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("consider casting the fn item to a fn pointer: `{$casting}`")),
&sub_args);
diag.help(__message);
}
}
}
}
};Subdiagnostic)]
1590#[help("consider casting the fn item to a fn pointer: `{$casting}`")]
1591pub(crate) struct FnConsiderCasting {
1592 pub casting: String,
1593}
1594
1595#[derive(const _: () =
{
impl<'a> rustc_errors::Subdiagnostic for FnConsiderCastingBoth<'a> {
fn add_to_diag<__G>(self, diag: &mut rustc_errors::Diag<'_, __G>)
where __G: rustc_errors::EmissionGuarantee {
match self {
FnConsiderCastingBoth { sig: __binding_0 } => {
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("sig".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_0,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("consider casting both fn items to fn pointers using `as {$sig}`")),
&sub_args);
diag.help(__message);
}
}
}
}
};Subdiagnostic)]
1596#[help("consider casting both fn items to fn pointers using `as {$sig}`")]
1597pub(crate) struct FnConsiderCastingBoth<'a> {
1598 pub sig: Binder<'a, FnSig<'a>>,
1599}
1600
1601#[derive(const _: () =
{
impl<'a> rustc_errors::Subdiagnostic for SuggestAccessingField<'a> {
fn add_to_diag<__G>(self, diag: &mut rustc_errors::Diag<'_, __G>)
where __G: rustc_errors::EmissionGuarantee {
match self {
SuggestAccessingField::Safe {
span: __binding_0,
snippet: __binding_1,
name: __binding_2,
ty: __binding_3 } => {
let __code_30 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{1}.{0}", __binding_2,
__binding_1))
})].into_iter();
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("snippet".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("name".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
sub_args.insert("ty".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_3,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("you might have meant to use field `{$name}` whose type is `{$ty}`")),
&sub_args);
diag.span_suggestions_with_style(__binding_0, __message,
__code_30, rustc_errors::Applicability::MaybeIncorrect,
rustc_errors::SuggestionStyle::ShowAlways);
}
SuggestAccessingField::Unsafe {
span: __binding_0,
snippet: __binding_1,
name: __binding_2,
ty: __binding_3 } => {
let __code_31 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!("unsafe {{ {1}.{0} }}",
__binding_2, __binding_1))
})].into_iter();
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("snippet".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("name".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
sub_args.insert("ty".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_3,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("you might have meant to use field `{$name}` whose type is `{$ty}`")),
&sub_args);
diag.span_suggestions_with_style(__binding_0, __message,
__code_31, rustc_errors::Applicability::MaybeIncorrect,
rustc_errors::SuggestionStyle::ShowAlways);
}
}
}
}
};Subdiagnostic)]
1602pub(crate) enum SuggestAccessingField<'a> {
1603 #[suggestion(
1604 "you might have meant to use field `{$name}` whose type is `{$ty}`",
1605 code = "{snippet}.{name}",
1606 applicability = "maybe-incorrect",
1607 style = "verbose"
1608 )]
1609 Safe {
1610 #[primary_span]
1611 span: Span,
1612 snippet: String,
1613 name: Symbol,
1614 ty: Ty<'a>,
1615 },
1616 #[suggestion(
1617 "you might have meant to use field `{$name}` whose type is `{$ty}`",
1618 code = "unsafe {{ {snippet}.{name} }}",
1619 applicability = "maybe-incorrect",
1620 style = "verbose"
1621 )]
1622 Unsafe {
1623 #[primary_span]
1624 span: Span,
1625 snippet: String,
1626 name: Symbol,
1627 ty: Ty<'a>,
1628 },
1629}
1630
1631#[derive(const _: () =
{
impl rustc_errors::Subdiagnostic for SuggestTuplePatternOne {
fn add_to_diag<__G>(self, diag: &mut rustc_errors::Diag<'_, __G>)
where __G: rustc_errors::EmissionGuarantee {
match self {
SuggestTuplePatternOne {
variant: __binding_0,
span_low: __binding_1,
span_high: __binding_2 } => {
let mut suggestions = Vec::new();
let __code_32 =
::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0}(", __binding_0))
});
let __code_33 =
::alloc::__export::must_use({
::alloc::fmt::format(format_args!(")"))
});
suggestions.push((__binding_1, __code_32));
suggestions.push((__binding_2, __code_33));
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("variant".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_0,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("try wrapping the pattern in `{$variant}`")),
&sub_args);
diag.multipart_suggestion_with_style(__message, suggestions,
rustc_errors::Applicability::MaybeIncorrect,
rustc_errors::SuggestionStyle::ShowCode);
}
}
}
}
};Subdiagnostic)]
1632#[multipart_suggestion(
1633 "try wrapping the pattern in `{$variant}`",
1634 applicability = "maybe-incorrect"
1635)]
1636pub(crate) struct SuggestTuplePatternOne {
1637 pub variant: String,
1638 #[suggestion_part(code = "{variant}(")]
1639 pub span_low: Span,
1640 #[suggestion_part(code = ")")]
1641 pub span_high: Span,
1642}
1643
1644pub(crate) struct SuggestTuplePatternMany {
1645 pub path: String,
1646 pub cause_span: Span,
1647 pub compatible_variants: Vec<String>,
1648}
1649
1650impl Subdiagnostic for SuggestTuplePatternMany {
1651 fn add_to_diag<G: EmissionGuarantee>(self, diag: &mut Diag<'_, G>) {
1652 diag.arg("path", self.path);
1653 let message = rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("try wrapping the pattern in a variant of `{$path}`"))msg!("try wrapping the pattern in a variant of `{$path}`");
1654 diag.multipart_suggestions(
1655 message,
1656 self.compatible_variants.into_iter().map(|variant| {
1657 ::alloc::boxed::box_assume_init_into_vec_unsafe(::alloc::intrinsics::write_box_via_move(::alloc::boxed::Box::new_uninit(),
[(self.cause_span.shrink_to_lo(),
::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0}(", variant))
})), (self.cause_span.shrink_to_hi(), ")".to_string())]))vec![
1658 (self.cause_span.shrink_to_lo(), format!("{variant}(")),
1659 (self.cause_span.shrink_to_hi(), ")".to_string()),
1660 ]
1661 }),
1662 rustc_errors::Applicability::MaybeIncorrect,
1663 );
1664 }
1665}
1666
1667#[derive(const _: () =
{
impl rustc_errors::Subdiagnostic for TypeErrorAdditionalDiags {
fn add_to_diag<__G>(self, diag: &mut rustc_errors::Diag<'_, __G>)
where __G: rustc_errors::EmissionGuarantee {
match self {
TypeErrorAdditionalDiags::MeantByteLiteral {
span: __binding_0, code: __binding_1 } => {
let __code_34 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!("b\'{0}\'", __binding_1))
})].into_iter();
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("code".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("if you meant to write a byte literal, prefix with `b`")),
&sub_args);
diag.span_suggestions_with_style(__binding_0, __message,
__code_34, rustc_errors::Applicability::MachineApplicable,
rustc_errors::SuggestionStyle::ShowAlways);
}
TypeErrorAdditionalDiags::MeantCharLiteral {
span: __binding_0, code: __binding_1 } => {
let __code_35 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!("\'{0}\'", __binding_1))
})].into_iter();
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("code".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("if you meant to write a `char` literal, use single quotes")),
&sub_args);
diag.span_suggestions_with_style(__binding_0, __message,
__code_35, rustc_errors::Applicability::MachineApplicable,
rustc_errors::SuggestionStyle::ShowAlways);
}
TypeErrorAdditionalDiags::MeantStrLiteral {
start: __binding_0, end: __binding_1 } => {
let mut suggestions = Vec::new();
let __code_36 =
::alloc::__export::must_use({
::alloc::fmt::format(format_args!("\""))
});
let __code_37 =
::alloc::__export::must_use({
::alloc::fmt::format(format_args!("\""))
});
suggestions.push((__binding_0, __code_36));
suggestions.push((__binding_1, __code_37));
let mut sub_args = rustc_errors::DiagArgMap::default();
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("if you meant to write a string literal, use double quotes")),
&sub_args);
diag.multipart_suggestion_with_style(__message, suggestions,
rustc_errors::Applicability::MachineApplicable,
rustc_errors::SuggestionStyle::ShowCode);
}
TypeErrorAdditionalDiags::ConsiderSpecifyingLength {
span: __binding_0, length: __binding_1 } => {
let __code_38 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0}", __binding_1))
})].into_iter();
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("length".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("consider specifying the actual array length")),
&sub_args);
diag.span_suggestions_with_style(__binding_0, __message,
__code_38, rustc_errors::Applicability::MaybeIncorrect,
rustc_errors::SuggestionStyle::ShowAlways);
}
TypeErrorAdditionalDiags::TryCannotConvert {
found: __binding_0, expected: __binding_1 } => {
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("found".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_0,
&mut diag.long_ty_path));
sub_args.insert("expected".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("`?` operator cannot convert from `{$found}` to `{$expected}`")),
&sub_args);
diag.note(__message);
}
TypeErrorAdditionalDiags::TupleOnlyComma { span: __binding_0
} => {
let __code_39 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!(","))
})].into_iter();
let mut sub_args = rustc_errors::DiagArgMap::default();
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("use a trailing comma to create a tuple with one element")),
&sub_args);
diag.span_suggestions_with_style(__binding_0, __message,
__code_39, rustc_errors::Applicability::MachineApplicable,
rustc_errors::SuggestionStyle::ShowCode);
}
TypeErrorAdditionalDiags::TupleAlsoParentheses {
span_low: __binding_0, span_high: __binding_1 } => {
let mut suggestions = Vec::new();
let __code_40 =
::alloc::__export::must_use({
::alloc::fmt::format(format_args!("("))
});
let __code_41 =
::alloc::__export::must_use({
::alloc::fmt::format(format_args!(",)"))
});
suggestions.push((__binding_0, __code_40));
suggestions.push((__binding_1, __code_41));
let mut sub_args = rustc_errors::DiagArgMap::default();
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("use a trailing comma to create a tuple with one element")),
&sub_args);
diag.multipart_suggestion_with_style(__message, suggestions,
rustc_errors::Applicability::MachineApplicable,
rustc_errors::SuggestionStyle::ShowCode);
}
TypeErrorAdditionalDiags::AddLetForLetChains {
span: __binding_0 } => {
let __code_42 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!("let "))
})].into_iter();
let mut sub_args = rustc_errors::DiagArgMap::default();
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("consider adding `let`")),
&sub_args);
diag.span_suggestions_with_style(__binding_0, __message,
__code_42, rustc_errors::Applicability::MachineApplicable,
rustc_errors::SuggestionStyle::ShowAlways);
}
}
}
}
};Subdiagnostic)]
1668pub enum TypeErrorAdditionalDiags {
1669 #[suggestion(
1670 "if you meant to write a byte literal, prefix with `b`",
1671 code = "b'{code}'",
1672 applicability = "machine-applicable",
1673 style = "verbose"
1674 )]
1675 MeantByteLiteral {
1676 #[primary_span]
1677 span: Span,
1678 code: String,
1679 },
1680 #[suggestion(
1681 "if you meant to write a `char` literal, use single quotes",
1682 code = "'{code}'",
1683 applicability = "machine-applicable",
1684 style = "verbose"
1685 )]
1686 MeantCharLiteral {
1687 #[primary_span]
1688 span: Span,
1689 code: String,
1690 },
1691 #[multipart_suggestion(
1692 "if you meant to write a string literal, use double quotes",
1693 applicability = "machine-applicable"
1694 )]
1695 MeantStrLiteral {
1696 #[suggestion_part(code = "\"")]
1697 start: Span,
1698 #[suggestion_part(code = "\"")]
1699 end: Span,
1700 },
1701 #[suggestion(
1702 "consider specifying the actual array length",
1703 code = "{length}",
1704 applicability = "maybe-incorrect",
1705 style = "verbose"
1706 )]
1707 ConsiderSpecifyingLength {
1708 #[primary_span]
1709 span: Span,
1710 length: u64,
1711 },
1712 #[note("`?` operator cannot convert from `{$found}` to `{$expected}`")]
1713 TryCannotConvert { found: String, expected: String },
1714 #[suggestion(
1715 "use a trailing comma to create a tuple with one element",
1716 code = ",",
1717 applicability = "machine-applicable"
1718 )]
1719 TupleOnlyComma {
1720 #[primary_span]
1721 span: Span,
1722 },
1723 #[multipart_suggestion(
1724 "use a trailing comma to create a tuple with one element",
1725 applicability = "machine-applicable"
1726 )]
1727 TupleAlsoParentheses {
1728 #[suggestion_part(code = "(")]
1729 span_low: Span,
1730 #[suggestion_part(code = ",)")]
1731 span_high: Span,
1732 },
1733 #[suggestion(
1734 "consider adding `let`",
1735 style = "verbose",
1736 applicability = "machine-applicable",
1737 code = "let "
1738 )]
1739 AddLetForLetChains {
1740 #[primary_span]
1741 span: Span,
1742 },
1743}
1744
1745#[derive(const _: () =
{
impl<'_sess, G> rustc_errors::Diagnostic<'_sess, G> for
ObligationCauseFailureCode where
G: rustc_errors::EmissionGuarantee {
#[track_caller]
fn into_diag(self, dcx: rustc_errors::DiagCtxtHandle<'_sess>,
level: rustc_errors::Level) -> rustc_errors::Diag<'_sess, G> {
match self {
ObligationCauseFailureCode::MethodCompat {
span: __binding_0, subdiags: __binding_1 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("method not compatible with trait")));
diag.code(E0308);
;
diag.span(__binding_0);
for __binding_1 in __binding_1 {
diag.subdiagnostic(__binding_1);
}
diag
}
ObligationCauseFailureCode::TypeCompat {
span: __binding_0, subdiags: __binding_1 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("type not compatible with trait")));
diag.code(E0308);
;
diag.span(__binding_0);
for __binding_1 in __binding_1 {
diag.subdiagnostic(__binding_1);
}
diag
}
ObligationCauseFailureCode::ConstCompat {
span: __binding_0, subdiags: __binding_1 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("const not compatible with trait")));
diag.code(E0308);
;
diag.span(__binding_0);
for __binding_1 in __binding_1 {
diag.subdiagnostic(__binding_1);
}
diag
}
ObligationCauseFailureCode::TryCompat {
span: __binding_0, subdiags: __binding_1 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("`?` operator has incompatible types")));
diag.code(E0308);
;
diag.span(__binding_0);
for __binding_1 in __binding_1 {
diag.subdiagnostic(__binding_1);
}
diag
}
ObligationCauseFailureCode::MatchCompat {
span: __binding_0, subdiags: __binding_1 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("`match` arms have incompatible types")));
diag.code(E0308);
;
diag.span(__binding_0);
for __binding_1 in __binding_1 {
diag.subdiagnostic(__binding_1);
}
diag
}
ObligationCauseFailureCode::IfElseDifferent {
span: __binding_0, subdiags: __binding_1 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("`if` and `else` have incompatible types")));
diag.code(E0308);
;
diag.span(__binding_0);
for __binding_1 in __binding_1 {
diag.subdiagnostic(__binding_1);
}
diag
}
ObligationCauseFailureCode::NoElse { span: __binding_0 } =>
{
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("`if` may be missing an `else` clause")));
diag.code(E0317);
;
diag.span(__binding_0);
diag
}
ObligationCauseFailureCode::NoDiverge {
span: __binding_0, subdiags: __binding_1 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("`else` clause of `let...else` does not diverge")));
diag.code(E0308);
;
diag.span(__binding_0);
for __binding_1 in __binding_1 {
diag.subdiagnostic(__binding_1);
}
diag
}
ObligationCauseFailureCode::FnMainCorrectType {
span: __binding_0 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("`main` function has wrong type")));
diag.code(E0580);
;
diag.span(__binding_0);
diag
}
ObligationCauseFailureCode::FnLangCorrectType {
span: __binding_0,
subdiags: __binding_1,
lang_item_name: __binding_2 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("{$lang_item_name ->\n [panic_impl] `#[panic_handler]`\n *[lang_item_name] lang item `{$lang_item_name}`\n } function has wrong type")));
diag.code(E0308);
;
diag.arg("lang_item_name", __binding_2);
diag.span(__binding_0);
for __binding_1 in __binding_1 {
diag.subdiagnostic(__binding_1);
}
diag
}
ObligationCauseFailureCode::IntrinsicCorrectType {
span: __binding_0, subdiags: __binding_1 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("intrinsic has wrong type")));
diag.code(E0308);
;
diag.span(__binding_0);
for __binding_1 in __binding_1 {
diag.subdiagnostic(__binding_1);
}
diag
}
ObligationCauseFailureCode::MethodCorrectType {
span: __binding_0, subdiags: __binding_1 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("mismatched `self` parameter type")));
diag.code(E0308);
;
diag.span(__binding_0);
for __binding_1 in __binding_1 {
diag.subdiagnostic(__binding_1);
}
diag
}
ObligationCauseFailureCode::ClosureSelfref {
span: __binding_0 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("closure/coroutine type that references itself")));
diag.code(E0644);
;
diag.span(__binding_0);
diag
}
ObligationCauseFailureCode::CantCoerceForceInline {
span: __binding_0, subdiags: __binding_1 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("cannot coerce functions which must be inlined to function pointers")));
diag.code(E0308);
;
diag.span(__binding_0);
for __binding_1 in __binding_1 {
diag.subdiagnostic(__binding_1);
}
diag
}
ObligationCauseFailureCode::CantCoerceIntrinsic {
span: __binding_0, subdiags: __binding_1 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("cannot coerce intrinsics to function pointers")));
diag.code(E0308);
;
diag.span(__binding_0);
for __binding_1 in __binding_1 {
diag.subdiagnostic(__binding_1);
}
diag
}
ObligationCauseFailureCode::Generic {
span: __binding_0, subdiags: __binding_1 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("mismatched types")));
diag.code(E0308);
;
diag.span(__binding_0);
for __binding_1 in __binding_1 {
diag.subdiagnostic(__binding_1);
}
diag
}
}
}
}
};Diagnostic)]
1746pub enum ObligationCauseFailureCode {
1747 #[diag("method not compatible with trait", code = E0308)]
1748 MethodCompat {
1749 #[primary_span]
1750 span: Span,
1751 #[subdiagnostic]
1752 subdiags: Vec<TypeErrorAdditionalDiags>,
1753 },
1754 #[diag("type not compatible with trait", code = E0308)]
1755 TypeCompat {
1756 #[primary_span]
1757 span: Span,
1758 #[subdiagnostic]
1759 subdiags: Vec<TypeErrorAdditionalDiags>,
1760 },
1761 #[diag("const not compatible with trait", code = E0308)]
1762 ConstCompat {
1763 #[primary_span]
1764 span: Span,
1765 #[subdiagnostic]
1766 subdiags: Vec<TypeErrorAdditionalDiags>,
1767 },
1768 #[diag("`?` operator has incompatible types", code = E0308)]
1769 TryCompat {
1770 #[primary_span]
1771 span: Span,
1772 #[subdiagnostic]
1773 subdiags: Vec<TypeErrorAdditionalDiags>,
1774 },
1775 #[diag("`match` arms have incompatible types", code = E0308)]
1776 MatchCompat {
1777 #[primary_span]
1778 span: Span,
1779 #[subdiagnostic]
1780 subdiags: Vec<TypeErrorAdditionalDiags>,
1781 },
1782 #[diag("`if` and `else` have incompatible types", code = E0308)]
1783 IfElseDifferent {
1784 #[primary_span]
1785 span: Span,
1786 #[subdiagnostic]
1787 subdiags: Vec<TypeErrorAdditionalDiags>,
1788 },
1789 #[diag("`if` may be missing an `else` clause", code = E0317)]
1790 NoElse {
1791 #[primary_span]
1792 span: Span,
1793 },
1794 #[diag("`else` clause of `let...else` does not diverge", code = E0308)]
1795 NoDiverge {
1796 #[primary_span]
1797 span: Span,
1798 #[subdiagnostic]
1799 subdiags: Vec<TypeErrorAdditionalDiags>,
1800 },
1801 #[diag("`main` function has wrong type", code = E0580)]
1802 FnMainCorrectType {
1803 #[primary_span]
1804 span: Span,
1805 },
1806 #[diag(
1807 "{$lang_item_name ->
1808 [panic_impl] `#[panic_handler]`
1809 *[lang_item_name] lang item `{$lang_item_name}`
1810 } function has wrong type"
1811 , code = E0308)]
1812 FnLangCorrectType {
1813 #[primary_span]
1814 span: Span,
1815 #[subdiagnostic]
1816 subdiags: Vec<TypeErrorAdditionalDiags>,
1817 lang_item_name: Symbol,
1818 },
1819 #[diag("intrinsic has wrong type", code = E0308)]
1820 IntrinsicCorrectType {
1821 #[primary_span]
1822 span: Span,
1823 #[subdiagnostic]
1824 subdiags: Vec<TypeErrorAdditionalDiags>,
1825 },
1826 #[diag("mismatched `self` parameter type", code = E0308)]
1827 MethodCorrectType {
1828 #[primary_span]
1829 span: Span,
1830 #[subdiagnostic]
1831 subdiags: Vec<TypeErrorAdditionalDiags>,
1832 },
1833 #[diag("closure/coroutine type that references itself", code = E0644)]
1834 ClosureSelfref {
1835 #[primary_span]
1836 span: Span,
1837 },
1838 #[diag("cannot coerce functions which must be inlined to function pointers", code = E0308)]
1839 CantCoerceForceInline {
1840 #[primary_span]
1841 span: Span,
1842 #[subdiagnostic]
1843 subdiags: Vec<TypeErrorAdditionalDiags>,
1844 },
1845 #[diag("cannot coerce intrinsics to function pointers", code = E0308)]
1846 CantCoerceIntrinsic {
1847 #[primary_span]
1848 span: Span,
1849 #[subdiagnostic]
1850 subdiags: Vec<TypeErrorAdditionalDiags>,
1851 },
1852 #[diag("mismatched types", code = E0308)]
1853 Generic {
1854 #[primary_span]
1855 span: Span,
1856 #[subdiagnostic]
1857 subdiags: Vec<TypeErrorAdditionalDiags>,
1858 },
1859}
1860
1861#[derive(const _: () =
{
impl rustc_errors::Subdiagnostic for AddPreciseCapturing {
fn add_to_diag<__G>(self, diag: &mut rustc_errors::Diag<'_, __G>)
where __G: rustc_errors::EmissionGuarantee {
match self {
AddPreciseCapturing::New {
span: __binding_0,
new_lifetime: __binding_1,
concatenated_bounds: __binding_2 } => {
let __code_43 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!(" + use<{0}>",
__binding_2))
})].into_iter();
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("new_lifetime".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("concatenated_bounds".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("add a `use<...>` bound to explicitly capture `{$new_lifetime}`")),
&sub_args);
diag.span_suggestions_with_style(__binding_0, __message,
__code_43, rustc_errors::Applicability::MachineApplicable,
rustc_errors::SuggestionStyle::ShowAlways);
}
AddPreciseCapturing::Existing {
span: __binding_0,
new_lifetime: __binding_1,
pre: __binding_2,
post: __binding_3 } => {
let __code_44 =
[::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{2}{0}{1}", __binding_1,
__binding_3, __binding_2))
})].into_iter();
let mut sub_args = rustc_errors::DiagArgMap::default();
sub_args.insert("new_lifetime".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_1,
&mut diag.long_ty_path));
sub_args.insert("pre".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_2,
&mut diag.long_ty_path));
sub_args.insert("post".into(),
rustc_errors::IntoDiagArg::into_diag_arg(__binding_3,
&mut diag.long_ty_path));
let __message =
rustc_errors::format_diag_message(&rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("add `{$new_lifetime}` to the `use<...>` bound to explicitly capture it")),
&sub_args);
diag.span_suggestions_with_style(__binding_0, __message,
__code_44, rustc_errors::Applicability::MachineApplicable,
rustc_errors::SuggestionStyle::ShowAlways);
}
}
}
}
};Subdiagnostic)]
1862pub(crate) enum AddPreciseCapturing {
1863 #[suggestion(
1864 "add a `use<...>` bound to explicitly capture `{$new_lifetime}`",
1865 style = "verbose",
1866 code = " + use<{concatenated_bounds}>",
1867 applicability = "machine-applicable"
1868 )]
1869 New {
1870 #[primary_span]
1871 span: Span,
1872 new_lifetime: Symbol,
1873 concatenated_bounds: String,
1874 },
1875 #[suggestion(
1876 "add `{$new_lifetime}` to the `use<...>` bound to explicitly capture it",
1877 style = "verbose",
1878 code = "{pre}{new_lifetime}{post}",
1879 applicability = "machine-applicable"
1880 )]
1881 Existing {
1882 #[primary_span]
1883 span: Span,
1884 new_lifetime: Symbol,
1885 pre: &'static str,
1886 post: &'static str,
1887 },
1888}
1889
1890pub(crate) struct AddPreciseCapturingAndParams {
1891 pub suggs: Vec<(Span, String)>,
1892 pub new_lifetime: Symbol,
1893 pub apit_spans: Vec<Span>,
1894}
1895
1896impl Subdiagnostic for AddPreciseCapturingAndParams {
1897 fn add_to_diag<G: EmissionGuarantee>(self, diag: &mut Diag<'_, G>) {
1898 diag.arg("new_lifetime", self.new_lifetime);
1899 diag.multipart_suggestion(
1900 rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("add a `use<...>` bound to explicitly capture `{$new_lifetime}` after turning all argument-position `impl Trait` into type parameters, noting that this possibly affects the API of this crate"))msg!("add a `use<...>` bound to explicitly capture `{$new_lifetime}` after turning all argument-position `impl Trait` into type parameters, noting that this possibly affects the API of this crate"),
1901 self.suggs,
1902 Applicability::MaybeIncorrect,
1903 );
1904 diag.span_note(
1905 self.apit_spans,
1906 rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("you could use a `use<...>` bound to explicitly capture `{$new_lifetime}`, but argument-position `impl Trait`s are not nameable"))msg!("you could use a `use<...>` bound to explicitly capture `{$new_lifetime}`, but argument-position `impl Trait`s are not nameable"),
1907 );
1908 }
1909}
1910
1911pub fn impl_trait_overcapture_suggestion<'tcx>(
1916 tcx: TyCtxt<'tcx>,
1917 opaque_def_id: LocalDefId,
1918 fn_def_id: LocalDefId,
1919 captured_args: FxIndexSet<DefId>,
1920) -> Option<AddPreciseCapturingForOvercapture> {
1921 let generics = tcx.generics_of(fn_def_id);
1922
1923 let mut captured_lifetimes = FxIndexSet::default();
1924 let mut captured_non_lifetimes = FxIndexSet::default();
1925 let mut synthetics = ::alloc::vec::Vec::new()vec![];
1926
1927 for arg in captured_args {
1928 if tcx.def_kind(arg) == DefKind::LifetimeParam {
1929 captured_lifetimes.insert(tcx.item_name(arg));
1930 } else {
1931 let idx = generics.param_def_id_to_index(tcx, arg).expect("expected arg in scope");
1932 let param = generics.param_at(idx as usize, tcx);
1933 if param.kind.is_synthetic() {
1934 synthetics.push((tcx.def_span(arg), param.name));
1935 } else {
1936 captured_non_lifetimes.insert(tcx.item_name(arg));
1937 }
1938 }
1939 }
1940
1941 let mut next_fresh_param = || {
1942 ['T', 'U', 'V', 'W', 'X', 'Y', 'A', 'B', 'C']
1943 .into_iter()
1944 .map(sym::character)
1945 .chain((0..).map(|i| Symbol::intern(&::alloc::__export::must_use({ ::alloc::fmt::format(format_args!("T{0}", i)) })format!("T{i}"))))
1946 .find(|s| captured_non_lifetimes.insert(*s))
1947 .unwrap()
1948 };
1949
1950 let mut suggs = ::alloc::vec::Vec::new()vec![];
1951 let mut apit_spans = ::alloc::vec::Vec::new()vec![];
1952
1953 if !synthetics.is_empty() {
1954 let mut new_params = String::new();
1955 for (i, (span, name)) in synthetics.into_iter().enumerate() {
1956 apit_spans.push(span);
1957
1958 let fresh_param = next_fresh_param();
1959
1960 suggs.push((span, fresh_param.to_string()));
1962
1963 if i > 0 {
1971 new_params += ", ";
1972 }
1973 let name_as_bounds = name.as_str().trim_start_matches("impl").trim_start();
1974 new_params += fresh_param.as_str();
1975 new_params += ": ";
1976 new_params += name_as_bounds;
1977 }
1978
1979 let Some(generics) = tcx.hir_get_generics(fn_def_id) else {
1980 return None;
1982 };
1983
1984 suggs.push(if let Some(params_span) = generics.span_for_param_suggestion() {
1986 (params_span, ::alloc::__export::must_use({
::alloc::fmt::format(format_args!(", {0}", new_params))
})format!(", {new_params}"))
1987 } else {
1988 (generics.span, ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("<{0}>", new_params))
})format!("<{new_params}>"))
1989 });
1990 }
1991
1992 let concatenated_bounds = captured_lifetimes
1993 .into_iter()
1994 .chain(captured_non_lifetimes)
1995 .map(|sym| sym.to_string())
1996 .collect::<Vec<_>>()
1997 .join(", ");
1998
1999 let opaque_hir_id = tcx.local_def_id_to_hir_id(opaque_def_id);
2000 let (lparen, rparen) = match tcx
2002 .hir_parent_iter(opaque_hir_id)
2003 .nth(1)
2004 .expect("expected ty to have a parent always")
2005 .1
2006 {
2007 Node::PathSegment(segment)
2008 if segment.args().paren_sugar_output().is_some_and(|ty| ty.hir_id == opaque_hir_id) =>
2009 {
2010 ("(", ")")
2011 }
2012 Node::Ty(ty) => match ty.kind {
2013 rustc_hir::TyKind::Ptr(_) | rustc_hir::TyKind::Ref(..) => ("(", ")"),
2014 _ => ("", ""),
2018 },
2019 _ => ("", ""),
2020 };
2021
2022 let rpit_span = tcx.def_span(opaque_def_id);
2023 if !lparen.is_empty() {
2024 suggs.push((rpit_span.shrink_to_lo(), lparen.to_string()));
2025 }
2026 suggs.push((rpit_span.shrink_to_hi(), ::alloc::__export::must_use({
::alloc::fmt::format(format_args!(" + use<{0}>{1}",
concatenated_bounds, rparen))
})format!(" + use<{concatenated_bounds}>{rparen}")));
2027
2028 Some(AddPreciseCapturingForOvercapture { suggs, apit_spans })
2029}
2030
2031pub struct AddPreciseCapturingForOvercapture {
2032 pub suggs: Vec<(Span, String)>,
2033 pub apit_spans: Vec<Span>,
2034}
2035
2036impl Subdiagnostic for AddPreciseCapturingForOvercapture {
2037 fn add_to_diag<G: EmissionGuarantee>(self, diag: &mut Diag<'_, G>) {
2038 let applicability = if self.apit_spans.is_empty() {
2039 Applicability::MachineApplicable
2040 } else {
2041 Applicability::MaybeIncorrect
2045 };
2046 diag.multipart_suggestion(
2047 rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("use the precise capturing `use<...>` syntax to make the captures explicit"))msg!("use the precise capturing `use<...>` syntax to make the captures explicit"),
2048 self.suggs,
2049 applicability,
2050 );
2051 if !self.apit_spans.is_empty() {
2052 diag.span_note(
2053 self.apit_spans,
2054 rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("you could use a `use<...>` bound to explicitly specify captures, but argument-position `impl Trait`s are not nameable"))msg!("you could use a `use<...>` bound to explicitly specify captures, but argument-position `impl Trait`s are not nameable"),
2055 );
2056 }
2057 }
2058}
2059
2060#[derive(const _: () =
{
impl<'_sess, 'a, 'tcx, G> rustc_errors::Diagnostic<'_sess, G> for
NonGenericOpaqueTypeParam<'a, 'tcx> where
G: rustc_errors::EmissionGuarantee {
#[track_caller]
fn into_diag(self, dcx: rustc_errors::DiagCtxtHandle<'_sess>,
level: rustc_errors::Level) -> rustc_errors::Diag<'_sess, G> {
match self {
NonGenericOpaqueTypeParam {
arg: __binding_0,
kind: __binding_1,
span: __binding_2,
param_span: __binding_3 } => {
let mut diag =
rustc_errors::Diag::new(dcx, level,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("expected generic {$kind} parameter, found `{$arg}`")));
diag.code(E0792);
;
diag.arg("arg", __binding_0);
diag.arg("kind", __binding_1);
diag.span(__binding_2);
diag.span_label(__binding_3,
rustc_errors::DiagMessage::Inline(std::borrow::Cow::Borrowed("{STREQ($arg, \"'static\") ->\n [true] cannot use static lifetime; use a bound lifetime instead or remove the lifetime parameter from the opaque type\n *[other] this generic parameter must be used with a generic {$kind} parameter\n }")));
diag
}
}
}
}
};Diagnostic)]
2061#[diag("expected generic {$kind} parameter, found `{$arg}`", code = E0792)]
2062pub(crate) struct NonGenericOpaqueTypeParam<'a, 'tcx> {
2063 pub arg: GenericArg<'tcx>,
2064 pub kind: &'a str,
2065 #[primary_span]
2066 pub span: Span,
2067 #[label("{STREQ($arg, \"'static\") ->
2068 [true] cannot use static lifetime; use a bound lifetime instead or remove the lifetime parameter from the opaque type
2069 *[other] this generic parameter must be used with a generic {$kind} parameter
2070 }")]
2071 pub param_span: Span,
2072}