diff --git a/compiler/rustc_hir_analysis/src/coherence/orphan.rs b/compiler/rustc_hir_analysis/src/coherence/orphan.rs
index 92e8c459509..1770f7b4e91 100644
--- a/compiler/rustc_hir_analysis/src/coherence/orphan.rs
+++ b/compiler/rustc_hir_analysis/src/coherence/orphan.rs
@@ -283,15 +283,14 @@ fn emit_orphan_check_error<'tcx>(
let self_ty = trait_ref.self_ty();
Err(match err {
traits::OrphanCheckErr::NonLocalInputType(tys) => {
- // FIXME: Someone needs to just turn these into `Subdiag`s and attach
- // them to the `Diag` after creating the error.
- let mut opaque = vec![];
- let mut foreign = vec![];
- let mut name = vec![];
- let mut pointer = vec![];
- let mut ty_diag = vec![];
- let mut adt = vec![];
- let mut sugg = None;
+ let mut diag = tcx.dcx().create_err(match self_ty.kind() {
+ ty::Adt(..) => errors::OnlyCurrentTraits::Outside { span: sp, note: () },
+ _ if self_ty.is_primitive() => {
+ errors::OnlyCurrentTraits::Primitive { span: sp, note: () }
+ }
+ _ => errors::OnlyCurrentTraits::Arbitrary { span: sp, note: () },
+ });
+
for &(mut ty, is_target_ty) in &tys {
let span = if matches!(is_target_ty, IsFirstInputType::Yes) {
// Point at `D` in `impl for C in D`
@@ -303,110 +302,85 @@ fn emit_orphan_check_error<'tcx>(
ty = tcx.erase_regions(ty);
- fn push_to_foreign_or_name<'tcx>(
- is_foreign: bool,
- foreign: &mut Vec,
- name: &mut Vec>,
- span: Span,
- sname: &'tcx str,
- ) {
- if is_foreign {
- foreign.push(errors::OnlyCurrentTraitsForeign { span })
- } else {
- name.push(errors::OnlyCurrentTraitsName { span, name: sname });
- }
- }
-
let is_foreign =
!trait_ref.def_id.is_local() && matches!(is_target_ty, IsFirstInputType::No);
match *ty.kind() {
ty::Slice(_) => {
- push_to_foreign_or_name(
- is_foreign,
- &mut foreign,
- &mut name,
- span,
- "slices",
- );
+ if is_foreign {
+ diag.subdiagnostic(
+ tcx.dcx(),
+ errors::OnlyCurrentTraitsForeign { span },
+ );
+ } else {
+ diag.subdiagnostic(
+ tcx.dcx(),
+ errors::OnlyCurrentTraitsName { span, name: "slices" },
+ );
+ }
}
ty::Array(..) => {
- push_to_foreign_or_name(
- is_foreign,
- &mut foreign,
- &mut name,
- span,
- "arrays",
- );
+ if is_foreign {
+ diag.subdiagnostic(
+ tcx.dcx(),
+ errors::OnlyCurrentTraitsForeign { span },
+ );
+ } else {
+ diag.subdiagnostic(
+ tcx.dcx(),
+ errors::OnlyCurrentTraitsName { span, name: "arrays" },
+ );
+ }
}
ty::Tuple(..) => {
- push_to_foreign_or_name(
- is_foreign,
- &mut foreign,
- &mut name,
- span,
- "tuples",
- );
+ if is_foreign {
+ diag.subdiagnostic(
+ tcx.dcx(),
+ errors::OnlyCurrentTraitsForeign { span },
+ );
+ } else {
+ diag.subdiagnostic(
+ tcx.dcx(),
+ errors::OnlyCurrentTraitsName { span, name: "tuples" },
+ );
+ }
}
ty::Alias(ty::Opaque, ..) => {
- opaque.push(errors::OnlyCurrentTraitsOpaque { span })
+ diag.subdiagnostic(tcx.dcx(), errors::OnlyCurrentTraitsOpaque { span });
}
ty::RawPtr(ptr_ty, mutbl) => {
if !self_ty.has_param() {
- let mut_key = mutbl.prefix_str();
- sugg = Some(errors::OnlyCurrentTraitsPointerSugg {
- wrapper_span: self_ty_span,
- struct_span: full_impl_span.shrink_to_lo(),
- mut_key,
- ptr_ty,
- });
+ diag.subdiagnostic(
+ tcx.dcx(),
+ errors::OnlyCurrentTraitsPointerSugg {
+ wrapper_span: self_ty_span,
+ struct_span: full_impl_span.shrink_to_lo(),
+ mut_key: mutbl.prefix_str(),
+ ptr_ty,
+ },
+ );
}
- pointer.push(errors::OnlyCurrentTraitsPointer { span, pointer: ty });
+ diag.subdiagnostic(
+ tcx.dcx(),
+ errors::OnlyCurrentTraitsPointer { span, pointer: ty },
+ );
+ }
+ ty::Adt(adt_def, _) => {
+ diag.subdiagnostic(
+ tcx.dcx(),
+ errors::OnlyCurrentTraitsAdt {
+ span,
+ name: tcx.def_path_str(adt_def.did()),
+ },
+ );
+ }
+ _ => {
+ diag.subdiagnostic(tcx.dcx(), errors::OnlyCurrentTraitsTy { span, ty });
}
- ty::Adt(adt_def, _) => adt.push(errors::OnlyCurrentTraitsAdt {
- span,
- name: tcx.def_path_str(adt_def.did()),
- }),
- _ => ty_diag.push(errors::OnlyCurrentTraitsTy { span, ty }),
}
}
- let err_struct = match self_ty.kind() {
- ty::Adt(..) => errors::OnlyCurrentTraits::Outside {
- span: sp,
- note: (),
- opaque,
- foreign,
- name,
- pointer,
- ty: ty_diag,
- adt,
- sugg,
- },
- _ if self_ty.is_primitive() => errors::OnlyCurrentTraits::Primitive {
- span: sp,
- note: (),
- opaque,
- foreign,
- name,
- pointer,
- ty: ty_diag,
- adt,
- sugg,
- },
- _ => errors::OnlyCurrentTraits::Arbitrary {
- span: sp,
- note: (),
- opaque,
- foreign,
- name,
- pointer,
- ty: ty_diag,
- adt,
- sugg,
- },
- };
- tcx.dcx().emit_err(err_struct)
+ diag.emit()
}
traits::OrphanCheckErr::UncoveredTy(param_ty, local_type) => {
let mut sp = sp;
diff --git a/compiler/rustc_hir_analysis/src/errors.rs b/compiler/rustc_hir_analysis/src/errors.rs
index 6595ee542e0..2d4742fa1dc 100644
--- a/compiler/rustc_hir_analysis/src/errors.rs
+++ b/compiler/rustc_hir_analysis/src/errors.rs
@@ -1376,7 +1376,7 @@ pub struct TyParamSome<'a> {
}
#[derive(Diagnostic)]
-pub enum OnlyCurrentTraits<'a> {
+pub enum OnlyCurrentTraits {
#[diag(hir_analysis_only_current_traits_outside, code = E0117)]
Outside {
#[primary_span]
@@ -1384,20 +1384,6 @@ pub enum OnlyCurrentTraits<'a> {
span: Span,
#[note(hir_analysis_only_current_traits_note)]
note: (),
- #[subdiagnostic]
- opaque: Vec,
- #[subdiagnostic]
- foreign: Vec,
- #[subdiagnostic]
- name: Vec>,
- #[subdiagnostic]
- pointer: Vec>,
- #[subdiagnostic]
- ty: Vec>,
- #[subdiagnostic]
- adt: Vec,
- #[subdiagnostic]
- sugg: Option>,
},
#[diag(hir_analysis_only_current_traits_primitive, code = E0117)]
Primitive {
@@ -1406,20 +1392,6 @@ pub enum OnlyCurrentTraits<'a> {
span: Span,
#[note(hir_analysis_only_current_traits_note)]
note: (),
- #[subdiagnostic]
- opaque: Vec,
- #[subdiagnostic]
- foreign: Vec,
- #[subdiagnostic]
- name: Vec>,
- #[subdiagnostic]
- pointer: Vec>,
- #[subdiagnostic]
- ty: Vec>,
- #[subdiagnostic]
- adt: Vec,
- #[subdiagnostic]
- sugg: Option>,
},
#[diag(hir_analysis_only_current_traits_arbitrary, code = E0117)]
Arbitrary {
@@ -1428,20 +1400,6 @@ pub enum OnlyCurrentTraits<'a> {
span: Span,
#[note(hir_analysis_only_current_traits_note)]
note: (),
- #[subdiagnostic]
- opaque: Vec,
- #[subdiagnostic]
- foreign: Vec,
- #[subdiagnostic]
- name: Vec>,
- #[subdiagnostic]
- pointer: Vec>,
- #[subdiagnostic]
- ty: Vec>,
- #[subdiagnostic]
- adt: Vec,
- #[subdiagnostic]
- sugg: Option>,
},
}