Skip to content

Commit 1d788e4

Browse files
committed
Apply review nits
1 parent f9b388b commit 1d788e4

File tree

1 file changed

+8
-11
lines changed

1 file changed

+8
-11
lines changed

compiler/rustc_hir_typeck/src/fallback.rs

+8-11
Original file line numberDiff line numberDiff line change
@@ -8,17 +8,13 @@ use rustc_data_structures::{
88
use rustc_hir as hir;
99
use rustc_hir::intravisit::Visitor;
1010
use rustc_hir::HirId;
11-
use rustc_infer::{
12-
infer::{DefineOpaqueTypes, InferOk},
13-
traits::ObligationCause,
14-
};
11+
use rustc_infer::infer::{DefineOpaqueTypes, InferOk};
1512
use rustc_middle::bug;
1613
use rustc_middle::ty::{self, Ty, TyCtxt, TypeSuperVisitable, TypeVisitable};
1714
use rustc_session::lint;
1815
use rustc_span::DUMMY_SP;
1916
use rustc_span::{def_id::LocalDefId, Span};
20-
use rustc_trait_selection::traits::ObligationCtxt;
21-
use rustc_type_ir::TyVid;
17+
use rustc_trait_selection::traits::{ObligationCause, ObligationCtxt};
2218

2319
#[derive(Copy, Clone)]
2420
pub enum DivergingFallbackBehavior {
@@ -475,7 +471,7 @@ impl<'tcx> FnCtxt<'_, 'tcx> {
475471
fn lint_obligations_broken_by_never_type_fallback_change(
476472
&self,
477473
behavior: DivergingFallbackBehavior,
478-
diverging_vids: &[TyVid],
474+
diverging_vids: &[ty::TyVid],
479475
) {
480476
let DivergingFallbackBehavior::FallbackToUnit = behavior else { return };
481477

@@ -485,7 +481,7 @@ impl<'tcx> FnCtxt<'_, 'tcx> {
485481
}
486482

487483
// Returns errors which happen if fallback is set to `fallback`
488-
let try_out = |fallback| {
484+
let remaining_errors_if_fallback_to = |fallback| {
489485
self.probe(|_| {
490486
let obligations = self.fulfillment_cx.borrow().pending_obligations();
491487
let ocx = ObligationCtxt::new(&self.infcx);
@@ -494,7 +490,8 @@ impl<'tcx> FnCtxt<'_, 'tcx> {
494490
for &diverging_vid in diverging_vids {
495491
let diverging_ty = Ty::new_var(self.tcx, diverging_vid);
496492

497-
_ = ocx.eq(&ObligationCause::dummy(), self.param_env, diverging_ty, fallback);
493+
ocx.eq(&ObligationCause::dummy(), self.param_env, diverging_ty, fallback)
494+
.expect("expected diverging var to be unconstrained");
498495
}
499496

500497
ocx.select_where_possible()
@@ -503,9 +500,9 @@ impl<'tcx> FnCtxt<'_, 'tcx> {
503500

504501
// If we have no errors with `fallback = ()`, but *do* have errors with `fallback = !`,
505502
// then this code will be broken by the never type fallback change.qba
506-
let unit_errors = try_out(self.tcx.types.unit);
503+
let unit_errors = remaining_errors_if_fallback_to(self.tcx.types.unit);
507504
if unit_errors.is_empty()
508-
&& let never_errors = try_out(self.tcx.types.never)
505+
&& let never_errors = remaining_errors_if_fallback_to(self.tcx.types.never)
509506
&& !never_errors.is_empty()
510507
{
511508
self.tcx.emit_node_span_lint(

0 commit comments

Comments
 (0)