make Representability::Infinite carry ErrorGuaranteed

This commit is contained in:
Lukas Markeffsky
2024-03-13 18:52:25 +01:00
parent 30f74ff0dc
commit 0e7e1bfdbc
5 changed files with 9 additions and 9 deletions

View File

@@ -601,5 +601,5 @@ impl<'tcx> AdtDef<'tcx> {
#[derive(HashStable)]
pub enum Representability {
Representable,
Infinite,
Infinite(ErrorGuaranteed),
}

View File

@@ -61,7 +61,7 @@ pub(crate) fn provide(providers: &mut Providers) {
/// requires calling [`InhabitedPredicate::instantiate`]
fn inhabited_predicate_adt(tcx: TyCtxt<'_>, def_id: DefId) -> InhabitedPredicate<'_> {
if let Some(def_id) = def_id.as_local() {
if matches!(tcx.representability(def_id), ty::Representability::Infinite) {
if matches!(tcx.representability(def_id), ty::Representability::Infinite(_)) {
return InhabitedPredicate::True;
}
}

View File

@@ -106,8 +106,8 @@ impl<'tcx> Value<TyCtxt<'tcx>> for Representability {
representable_ids.insert(def_id);
}
}
recursive_type_error(tcx, item_and_field_ids, &representable_ids);
Representability::Infinite
let guar = recursive_type_error(tcx, item_and_field_ids, &representable_ids);
Representability::Infinite(guar)
}
}
@@ -268,7 +268,7 @@ pub fn recursive_type_error(
tcx: TyCtxt<'_>,
mut item_and_field_ids: Vec<(LocalDefId, LocalDefId)>,
representable_ids: &FxHashSet<LocalDefId>,
) {
) -> ErrorGuaranteed {
const ITEM_LIMIT: usize = 5;
// Rotate the cycle so that the item with the lowest span is first
@@ -344,7 +344,7 @@ pub fn recursive_type_error(
suggestion,
Applicability::HasPlaceholders,
)
.emit();
.emit()
}
fn find_item_ty_spans(